MIPS R6 removed the BEQL instruction so do not try to emulate it if the R2-to-R6 emulator is not present. Signed-off-by: Markos Chandras <markos.chandras@xxxxxxxxxx> --- arch/mips/kernel/branch.c | 4 ++++ arch/mips/math-emu/cp1emu.c | 3 +++ 2 files changed, 7 insertions(+) diff --git a/arch/mips/kernel/branch.c b/arch/mips/kernel/branch.c index 2273307f7c51..a21bbda1ea9e 100644 --- a/arch/mips/kernel/branch.c +++ b/arch/mips/kernel/branch.c @@ -569,6 +569,10 @@ int __compute_return_epc_for_insn(struct pt_regs *regs, */ case beq_op: case beql_op: + if (NO_R6EMU && (insn.i_format.opcode == beql_op)) { + ret = -SIGILL; + break; + } if (regs->regs[insn.i_format.rs] == regs->regs[insn.i_format.rt]) { epc = epc + 4 + (insn.i_format.simmediate << 2); diff --git a/arch/mips/math-emu/cp1emu.c b/arch/mips/math-emu/cp1emu.c index 8aa6a451104b..c8ab23e96310 100644 --- a/arch/mips/math-emu/cp1emu.c +++ b/arch/mips/math-emu/cp1emu.c @@ -522,6 +522,9 @@ static int isBranchInstr(struct pt_regs *regs, struct mm_decoded_insn dec_insn, return 1; case beq_op: case beql_op: + if (NO_R6EMU && (insn.i_format.opcode == beql_op)) + break; + if (regs->regs[insn.i_format.rs] == regs->regs[insn.i_format.rt]) *contpc = regs->cp0_epc + -- 2.2.1