X-Git-Url: https://git.openpandora.org/cgi-bin/gitweb.cgi?p=pandora-kernel.git;a=blobdiff_plain;f=arch%2Farm%2Fmm%2Falignment.c;h=a4d3fd3952e164b96ed7a482913f8fbfdfaff471;hp=13e96ab542546c1dcf1ec03427e121ba9259d1c3;hb=f7c3ff94a296f2daf8f5f2e8be3e459636c3fdfd;hpb=7a99657f9dc3c00998e6313295832687b70ed52f;ds=sidebyside diff --git a/arch/arm/mm/alignment.c b/arch/arm/mm/alignment.c index 13e96ab54254..a4d3fd3952e1 100644 --- a/arch/arm/mm/alignment.c +++ b/arch/arm/mm/alignment.c @@ -38,6 +38,7 @@ * This code is not portable to processors with late data abort handling. */ #define CODING_BITS(i) (i & 0x0e000000) +#define COND_BITS(i) (i & 0xf0000000) #define LDST_I_BIT(i) (i & (1 << 26)) /* Immediate constant */ #define LDST_P_BIT(i) (i & (1 << 24)) /* Preindex */ @@ -812,6 +813,8 @@ do_alignment(unsigned long addr, unsigned int fsr, struct pt_regs *regs) break; case 0x04000000: /* ldr or str immediate */ + if (COND_BITS(instr) == 0xf0000000) /* NEON VLDn, VSTn */ + goto bad; offset.un = OFFSET_BITS(instr); handler = do_alignment_ldrstr; break;