mirror of
https://github.com/mikage-emu/mikage-dev.git
synced 2025-01-08 14:30:59 +01:00
Thumb: Fix missing upper register bits in CMP
This commit is contained in:
parent
d76b0dd8ff
commit
f859b5e94f
1 changed files with 13 additions and 0 deletions
|
@ -1,5 +1,7 @@
|
||||||
#include "thumb.hpp"
|
#include "thumb.hpp"
|
||||||
|
|
||||||
|
#include <framework/exceptions.hpp>
|
||||||
|
|
||||||
namespace ARM {
|
namespace ARM {
|
||||||
|
|
||||||
DecodedThumbInstr DecodeThumb(ARM::ThumbInstr instr) {
|
DecodedThumbInstr DecodeThumb(ARM::ThumbInstr instr) {
|
||||||
|
@ -400,8 +402,19 @@ DecodedThumbInstr DecodeThumb(ARM::ThumbInstr instr) {
|
||||||
} else if (instr.opcode_upper8 == 0b0100'0101) {
|
} else if (instr.opcode_upper8 == 0b0100'0101) {
|
||||||
// CMP (3) - Compare
|
// CMP (3) - Compare
|
||||||
ARM::ARMInstr arm_instr;
|
ARM::ARMInstr arm_instr;
|
||||||
|
if (!instr.idx_rd_upperbit && !instr.idx_rm_upperbit) {
|
||||||
|
throw Mikage::Exceptions::Invalid("Unpredictable configuration");
|
||||||
|
}
|
||||||
|
if (instr.idx_rm_upperbit && instr.idx_rm == 7) {
|
||||||
|
throw Mikage::Exceptions::Invalid("Unpredictable configuration");
|
||||||
|
}
|
||||||
|
if (instr.idx_rd_upperbit && instr.idx_rd_low == 7) {
|
||||||
|
throw Mikage::Exceptions::NotImplemented("Cannot use PC for this instruction, yet");
|
||||||
|
}
|
||||||
arm_instr.raw = (0b111000010101ul << 20)
|
arm_instr.raw = (0b111000010101ul << 20)
|
||||||
|
| (uint32_t { instr.idx_rd_upperbit } << 19)
|
||||||
| (uint32_t { instr.idx_rd_low } << 16)
|
| (uint32_t { instr.idx_rd_low } << 16)
|
||||||
|
| (uint32_t { instr.idx_rm_upperbit } << 3)
|
||||||
| instr.idx_rm;
|
| instr.idx_rm;
|
||||||
return { arm_instr };
|
return { arm_instr };
|
||||||
} else if (instr.opcode_upper5 == 0b11000) {
|
} else if (instr.opcode_upper5 == 0b11000) {
|
||||||
|
|
Loading…
Reference in a new issue