mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-11-28 12:33:36 +08:00
Thumb BL instruction: Do not set LR to pc + 2, it has already been advanced.
This commit is contained in:
parent
3139facc61
commit
7378e198a5
@ -1,3 +1,8 @@
|
||||
2002-05-27 Nick Clifton <nickc@cambridge.redhat.com>
|
||||
|
||||
* thumbemu.c (ARMul_ThumbDecode, Case 31): Do not set LR to pc +
|
||||
2, it has already been advanced.
|
||||
|
||||
2002-05-23 Nick Clifton <nickc@cambridge.redhat.com>
|
||||
|
||||
* thumbemu.c (ARMul_ThumbDecode): When decoding a BLX(1)
|
||||
|
@ -489,7 +489,7 @@ tdstate ARMul_ThumbDecode (state, pc, tinstr, ainstr)
|
||||
if r14 is not suitably initialised. */
|
||||
{
|
||||
ARMword tmp = (pc + 2);
|
||||
|
||||
|
||||
state->Reg[15] = ((state->Reg[14] + ((tinstr & 0x07FF) << 1))
|
||||
& 0xFFFFFFFC);
|
||||
CLEART;
|
||||
@ -509,8 +509,9 @@ tdstate ARMul_ThumbDecode (state, pc, tinstr, ainstr)
|
||||
second half of this BL, and if it is we simulate it
|
||||
immediately. */
|
||||
state->Reg[14] = state->Reg[15] \
|
||||
+(((tinstr & 0x07FF) << 12) \
|
||||
|((tinstr & (1 << 10)) ? 0xFF800000 : 0));
|
||||
+ (((tinstr & 0x07FF) << 12) \
|
||||
| ((tinstr & (1 << 10)) ? 0xFF800000 : 0));
|
||||
|
||||
valid = t_branch; /* in-case we don't have the 2nd half */
|
||||
tinstr = next_instr; /* move the instruction down */
|
||||
pc += 2; /* point the pc at the 2nd half */
|
||||
@ -543,7 +544,8 @@ tdstate ARMul_ThumbDecode (state, pc, tinstr, ainstr)
|
||||
the simulation of it on its own, with undefined results if
|
||||
r14 is not suitably initialised. */
|
||||
{
|
||||
ARMword tmp = (pc + 2);
|
||||
ARMword tmp = pc;
|
||||
|
||||
state->Reg[15] = (state->Reg[14] + ((tinstr & 0x07FF) << 1));
|
||||
state->Reg[14] = (tmp | 1);
|
||||
valid = t_branch;
|
||||
|
Loading…
Reference in New Issue
Block a user