MIPS: unaligned: Remove FP & MSA code when unsupported

When CONFIG_MIPS_FP_SUPPORT=n we don't support floating point, so remove
support for floating point instructions from emulate_load_store_insn() &
emulate_load_store_microMIPS(). This code should not be needed & relies
upon access to FPU state in struct task_struct which will later be
removed.

Similarly & for the same reasons, when CONFIG_CPU_HAS_MSA=n remove
support for MSA instructions. Since MSA support depends upon FP support
this is implied when CONFIG_MIPS_FP_SUPPORT=n.

Signed-off-by: Paul Burton <paul.burton@mips.com>
Patchwork: https://patchwork.linux-mips.org/patch/21020/
Cc: linux-mips@linux-mips.org
This commit is contained in:
Paul Burton 2018-11-07 23:14:07 +00:00
parent 6a1cc218b9
commit 85164fd8b0
No known key found for this signature in database
GPG Key ID: 3EA79FACB57500DD
1 changed files with 24 additions and 12 deletions

View File

@ -882,18 +882,12 @@ do { \
static void emulate_load_store_insn(struct pt_regs *regs, static void emulate_load_store_insn(struct pt_regs *regs,
void __user *addr, unsigned int __user *pc) void __user *addr, unsigned int __user *pc)
{ {
unsigned long origpc, orig31, value;
union mips_instruction insn; union mips_instruction insn;
unsigned long value; unsigned int res;
unsigned int res, preempted;
unsigned long origpc;
unsigned long orig31;
void __user *fault_addr = NULL;
#ifdef CONFIG_EVA #ifdef CONFIG_EVA
mm_segment_t seg; mm_segment_t seg;
#endif #endif
union fpureg *fpr;
enum msa_2b_fmt df;
unsigned int wd;
origpc = (unsigned long)pc; origpc = (unsigned long)pc;
orig31 = regs->regs[31]; orig31 = regs->regs[31];
@ -1212,11 +1206,15 @@ static void emulate_load_store_insn(struct pt_regs *regs,
/* Cannot handle 64-bit instructions in 32-bit kernel */ /* Cannot handle 64-bit instructions in 32-bit kernel */
goto sigill; goto sigill;
#ifdef CONFIG_MIPS_FP_SUPPORT
case lwc1_op: case lwc1_op:
case ldc1_op: case ldc1_op:
case swc1_op: case swc1_op:
case sdc1_op: case sdc1_op:
case cop1x_op: case cop1x_op: {
void __user *fault_addr = NULL;
die_if_kernel("Unaligned FP access in kernel code", regs); die_if_kernel("Unaligned FP access in kernel code", regs);
BUG_ON(!used_math()); BUG_ON(!used_math());
@ -1230,8 +1228,16 @@ static void emulate_load_store_insn(struct pt_regs *regs,
if (res == 0) if (res == 0)
break; break;
return; return;
}
#endif /* CONFIG_MIPS_FP_SUPPORT */
#ifdef CONFIG_CPU_HAS_MSA
case msa_op: {
unsigned int wd, preempted;
enum msa_2b_fmt df;
union fpureg *fpr;
case msa_op:
if (!cpu_has_msa) if (!cpu_has_msa)
goto sigill; goto sigill;
@ -1308,6 +1314,8 @@ static void emulate_load_store_insn(struct pt_regs *regs,
compute_return_epc(regs); compute_return_epc(regs);
break; break;
}
#endif /* CONFIG_CPU_HAS_MSA */
#ifndef CONFIG_CPU_MIPSR6 #ifndef CONFIG_CPU_MIPSR6
/* /*
@ -1392,7 +1400,6 @@ static void emulate_load_store_microMIPS(struct pt_regs *regs,
unsigned long origpc, contpc; unsigned long origpc, contpc;
union mips_instruction insn; union mips_instruction insn;
struct mm_decoded_insn mminsn; struct mm_decoded_insn mminsn;
void __user *fault_addr = NULL;
origpc = regs->cp0_epc; origpc = regs->cp0_epc;
orig31 = regs->regs[31]; orig31 = regs->regs[31];
@ -1708,6 +1715,7 @@ static void emulate_load_store_microMIPS(struct pt_regs *regs,
/* LL,SC,LLD,SCD are not serviced */ /* LL,SC,LLD,SCD are not serviced */
goto sigbus; goto sigbus;
#ifdef CONFIG_MIPS_FP_SUPPORT
case mm_pool32f_op: case mm_pool32f_op:
switch (insn.mm_x_format.func) { switch (insn.mm_x_format.func) {
case mm_lwxc1_func: case mm_lwxc1_func:
@ -1722,7 +1730,9 @@ static void emulate_load_store_microMIPS(struct pt_regs *regs,
case mm_ldc132_op: case mm_ldc132_op:
case mm_sdc132_op: case mm_sdc132_op:
case mm_lwc132_op: case mm_lwc132_op:
case mm_swc132_op: case mm_swc132_op: {
void __user *fault_addr = NULL;
fpu_emul: fpu_emul:
/* roll back jump/branch */ /* roll back jump/branch */
regs->cp0_epc = origpc; regs->cp0_epc = origpc;
@ -1742,6 +1752,8 @@ fpu_emul:
if (res == 0) if (res == 0)
goto success; goto success;
return; return;
}
#endif /* CONFIG_MIPS_FP_SUPPORT */
case mm_lh32_op: case mm_lh32_op:
reg = insn.mm_i_format.rt; reg = insn.mm_i_format.rt;