mirror of
https://github.com/mikage-emu/mikage-dev.git
synced 2025-01-25 06:38:17 +01:00
34 lines
704 B
C++
34 lines
704 B
C++
|
#pragma once
|
||
|
|
||
|
#include "../arm.h"
|
||
|
|
||
|
#include <optional>
|
||
|
|
||
|
namespace ARM {
|
||
|
|
||
|
struct DecodedThumbInstr {
|
||
|
// Equivalent ARM instruction, if any
|
||
|
std::optional<ARM::ARMInstr> arm_equivalent;
|
||
|
bool may_read_pc = false;
|
||
|
bool may_modify_pc = false;
|
||
|
|
||
|
DecodedThumbInstr& SetMayReadPC() {
|
||
|
may_read_pc = true;
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
DecodedThumbInstr& SetMayModifyPC() {
|
||
|
may_modify_pc = true;
|
||
|
return *this;
|
||
|
}
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Translates the given THUMB instruction to an equivalent ARM encoding.
|
||
|
* If this is not possible, the caller is responsible for interpreting
|
||
|
* the instruction manually.
|
||
|
*/
|
||
|
DecodedThumbInstr DecodeThumb(ARM::ThumbInstr);
|
||
|
|
||
|
} // namespace ARM
|