Commit 3cc070c1 authored by afzal mohammed's avatar afzal mohammed Committed by Russell King

ARM: 8665/1: nommu: access ID_PFR1 only if CPUID scheme

Greg upon trying to boot no-MMU Kernel on ARM926EJ reported boot
failure. He root caused it to ID_PFR1 access introduced by the
commit mentioned in the fixes tag below.

All CP15 processors need not have processor feature registers, only
for architectures defined by CPUID scheme would have it. Hence check
for it before accessing processor feature register, ID_PFR1.

Fixes: f8300a0b ("ARM: 8647/2: nommu: dynamic exception base address setting")
Reported-by: default avatarGreg Ungerer <gerg@uclinux.org>
Signed-off-by: default avatarafzal mohammed <afzal.mohd.ma@gmail.com>
Tested-by: default avatarGreg Ungerer <gerg@uclinux.org>
Signed-off-by: default avatarRussell King <rmk+kernel@armlinux.org.uk>
parent 916a008b
...@@ -303,7 +303,10 @@ static inline void set_vbar(unsigned long val) ...@@ -303,7 +303,10 @@ static inline void set_vbar(unsigned long val)
*/ */
static inline bool security_extensions_enabled(void) static inline bool security_extensions_enabled(void)
{ {
return !!cpuid_feature_extract(CPUID_EXT_PFR1, 4); /* Check CPUID Identification Scheme before ID_PFR1 read */
if ((read_cpuid_id() & 0x000f0000) == 0x000f0000)
return !!cpuid_feature_extract(CPUID_EXT_PFR1, 4);
return 0;
} }
static unsigned long __init setup_vectors_base(void) static unsigned long __init setup_vectors_base(void)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment