aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mips/kernel
diff options
context:
space:
mode:
authorMarkos Chandras <markos.chandras@imgtec.com>2014-11-25 10:54:14 -0500
committerMarkos Chandras <markos.chandras@imgtec.com>2015-02-17 10:37:31 -0500
commit5f9f41c474befb4ebbc40b27f65bb7d649241581 (patch)
tree26108ad80ca556ac12466aac3f03fc29d0a8a4ca /arch/mips/kernel
parentb5ad2c21934951bbf6aadd8adbdd9889baad0ac0 (diff)
MIPS: kernel: Prepare the JR instruction for emulation on MIPS R6
The MIPS R6 JR instruction is an alias to the JALR one, so it may need emulation for non-R6 userlands. Signed-off-by: Markos Chandras <markos.chandras@imgtec.com>
Diffstat (limited to 'arch/mips/kernel')
-rw-r--r--arch/mips/kernel/branch.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/arch/mips/kernel/branch.c b/arch/mips/kernel/branch.c
index 4d7d99d601cc..5736949896d1 100644
--- a/arch/mips/kernel/branch.c
+++ b/arch/mips/kernel/branch.c
@@ -417,6 +417,8 @@ int __compute_return_epc_for_insn(struct pt_regs *regs,
417 regs->regs[insn.r_format.rd] = epc + 8; 417 regs->regs[insn.r_format.rd] = epc + 8;
418 /* Fall through */ 418 /* Fall through */
419 case jr_op: 419 case jr_op:
420 if (NO_R6EMU && insn.r_format.func == jr_op)
421 goto sigill_r6;
420 regs->cp0_epc = regs->regs[insn.r_format.rs]; 422 regs->cp0_epc = regs->regs[insn.r_format.rs];
421 break; 423 break;
422 } 424 }
@@ -477,7 +479,7 @@ int __compute_return_epc_for_insn(struct pt_regs *regs,
477 479
478 case bposge32_op: 480 case bposge32_op:
479 if (!cpu_has_dsp) 481 if (!cpu_has_dsp)
480 goto sigill; 482 goto sigill_dsp;
481 483
482 dspcontrol = rddsp(0x01); 484 dspcontrol = rddsp(0x01);
483 485
@@ -631,10 +633,15 @@ int __compute_return_epc_for_insn(struct pt_regs *regs,
631 633
632 return ret; 634 return ret;
633 635
634sigill: 636sigill_dsp:
635 printk("%s: DSP branch but not DSP ASE - sending SIGBUS.\n", current->comm); 637 printk("%s: DSP branch but not DSP ASE - sending SIGBUS.\n", current->comm);
636 force_sig(SIGBUS, current); 638 force_sig(SIGBUS, current);
637 return -EFAULT; 639 return -EFAULT;
640sigill_r6:
641 pr_info("%s: R2 branch but r2-to-r6 emulator is not preset - sending SIGILL.\n",
642 current->comm);
643 force_sig(SIGILL, current);
644 return -EFAULT;
638} 645}
639EXPORT_SYMBOL_GPL(__compute_return_epc_for_insn); 646EXPORT_SYMBOL_GPL(__compute_return_epc_for_insn);
640 647