From 0a8fa63cb87497b74f8e7c43d5e0cdb865336266 Mon Sep 17 00:00:00 2001 From: Jeff Law Date: Tue, 10 Jun 1997 18:32:40 +0000 Subject: * simops.c: Fix return address computation for "call" instructions. --- sim/mn10300/simops.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'sim/mn10300/simops.c') diff --git a/sim/mn10300/simops.c b/sim/mn10300/simops.c index 8f86609..a913f4c 100644 --- a/sim/mn10300/simops.c +++ b/sim/mn10300/simops.c @@ -2535,7 +2535,7 @@ void OP_CD000000 (insn, extension) unsigned long mask; sp = State.regs[REG_SP]; - next_pc = State.regs[REG_PC] + 2; + next_pc = State.regs[REG_PC] + 5; State.mem[sp] = next_pc & 0xff; State.mem[sp+1] = (next_pc & 0xff00) >> 8; State.mem[sp+2] = (next_pc & 0xff0000) >> 16; @@ -2601,7 +2601,7 @@ void OP_DD000000 (insn, extension) unsigned long mask; sp = State.regs[REG_SP]; - next_pc = State.regs[REG_PC] + 2; + next_pc = State.regs[REG_PC] + 7; State.mem[sp] = next_pc & 0xff; State.mem[sp+1] = (next_pc & 0xff00) >> 8; State.mem[sp+2] = (next_pc & 0xff0000) >> 16; -- cgit v1.1