diff options
author | Ralf Baechle <ralf@linux-mips.org> | 2005-04-12 07:04:15 -0400 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2005-10-29 14:31:04 -0400 |
commit | 6dd04688520d7abe4883b2a79fa720291d76b140 (patch) | |
tree | 4d64b3bcad2b840ea6b8586ad018ea4077671c69 /arch/mips/kernel/traps.c | |
parent | ac5d8c022f91d790888cc8c627b8010d3c31a300 (diff) |
When simulating ll/sc compute the return EPC before modifying the
registers.
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch/mips/kernel/traps.c')
-rw-r--r-- | arch/mips/kernel/traps.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/arch/mips/kernel/traps.c b/arch/mips/kernel/traps.c index f9a6a5665559..77f796b9975e 100644 --- a/arch/mips/kernel/traps.c +++ b/arch/mips/kernel/traps.c | |||
@@ -408,9 +408,10 @@ static inline void simulate_ll(struct pt_regs *regs, unsigned int opcode) | |||
408 | 408 | ||
409 | preempt_enable(); | 409 | preempt_enable(); |
410 | 410 | ||
411 | compute_return_epc(regs); | ||
412 | |||
411 | regs->regs[(opcode & RT) >> 16] = value; | 413 | regs->regs[(opcode & RT) >> 16] = value; |
412 | 414 | ||
413 | compute_return_epc(regs); | ||
414 | return; | 415 | return; |
415 | 416 | ||
416 | sig: | 417 | sig: |
@@ -459,9 +460,9 @@ static inline void simulate_sc(struct pt_regs *regs, unsigned int opcode) | |||
459 | goto sig; | 460 | goto sig; |
460 | } | 461 | } |
461 | 462 | ||
463 | compute_return_epc(regs); | ||
462 | regs->regs[reg] = 1; | 464 | regs->regs[reg] = 1; |
463 | 465 | ||
464 | compute_return_epc(regs); | ||
465 | return; | 466 | return; |
466 | 467 | ||
467 | sig: | 468 | sig: |