diff options
Diffstat (limited to 'c/src/lib/libbsp/lm32/shared/gdbstub/lm32-stub.c')
-rw-r--r-- | c/src/lib/libbsp/lm32/shared/gdbstub/lm32-stub.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/c/src/lib/libbsp/lm32/shared/gdbstub/lm32-stub.c b/c/src/lib/libbsp/lm32/shared/gdbstub/lm32-stub.c index 14c5fb0ea1..eeba61d1be 100644 --- a/c/src/lib/libbsp/lm32/shared/gdbstub/lm32-stub.c +++ b/c/src/lib/libbsp/lm32/shared/gdbstub/lm32-stub.c @@ -740,7 +740,7 @@ void handle_exception(void) { branch_step = 1; branch_target = registers[LM32_REG_PC] - + ((signed)(insn & 0x3ffffff) << 2); + + (((signed)insn << 6) >> 4); } else if ( (opcode == 0x44000000) || (opcode == 0x48000000) @@ -752,7 +752,7 @@ void handle_exception(void) { branch_step = 1; branch_target = registers[LM32_REG_PC] + - + ((signed)(insn & 0x0000ffff) << 2); + + (((signed)insn << 16) >> 14); } else if ( (opcode == 0xd8000000) || (opcode == 0xc0000000) |