Skip to content

Commit 2f46791

Browse files
sverdlingregkh
authored andcommitted
ARM: 8642/1: LPAE: catch pending imprecise abort on unmask
commit 97a98ae5b8acf08d07d972c087b2def060bc9b73 upstream. Asynchronous external abort is coded differently in DFSR with LPAE enabled. Fixes: 9254970 "ARM: 8447/1: catch pending imprecise abort on unmask". Signed-off-by: Alexander Sverdlin <alexander.sverdlin@nokia.com> Cc: Russell King <linux@armlinux.org.uk> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: linux-arm-kernel@lists.infradead.org Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent 04ed4a9 commit 2f46791

2 files changed

Lines changed: 6 additions & 2 deletions

File tree

arch/arm/mm/fault.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -610,9 +610,9 @@ static int __init early_abort_handler(unsigned long addr, unsigned int fsr,
610610

611611
void __init early_abt_enable(void)
612612
{
613-
fsr_info[22].fn = early_abort_handler;
613+
fsr_info[FSR_FS_AEA].fn = early_abort_handler;
614614
local_abt_enable();
615-
fsr_info[22].fn = do_bad;
615+
fsr_info[FSR_FS_AEA].fn = do_bad;
616616
}
617617

618618
#ifndef CONFIG_ARM_LPAE

arch/arm/mm/fault.h

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11,11 +11,15 @@
1111
#define FSR_FS5_0 (0x3f)
1212

1313
#ifdef CONFIG_ARM_LPAE
14+
#define FSR_FS_AEA 17
15+
1416
static inline int fsr_fs(unsigned int fsr)
1517
{
1618
return fsr & FSR_FS5_0;
1719
}
1820
#else
21+
#define FSR_FS_AEA 22
22+
1923
static inline int fsr_fs(unsigned int fsr)
2024
{
2125
return (fsr & FSR_FS3_0) | (fsr & FSR_FS4) >> 6;

0 commit comments

Comments
 (0)