diff options
Diffstat (limited to 'arch/arm/mm')
| -rw-r--r-- | arch/arm/mm/ioremap.c | 8 | ||||
| -rw-r--r-- | arch/arm/mm/mmu.c | 4 | ||||
| -rw-r--r-- | arch/arm/mm/proc-v7.S | 10 |
3 files changed, 17 insertions, 5 deletions
diff --git a/arch/arm/mm/ioremap.c b/arch/arm/mm/ioremap.c index ab506272b2d3..17e7b0b57e49 100644 --- a/arch/arm/mm/ioremap.c +++ b/arch/arm/mm/ioremap.c | |||
| @@ -204,8 +204,12 @@ void __iomem * __arm_ioremap_pfn_caller(unsigned long pfn, | |||
| 204 | /* | 204 | /* |
| 205 | * Don't allow RAM to be mapped - this causes problems with ARMv6+ | 205 | * Don't allow RAM to be mapped - this causes problems with ARMv6+ |
| 206 | */ | 206 | */ |
| 207 | if (WARN_ON(pfn_valid(pfn))) | 207 | if (pfn_valid(pfn)) { |
| 208 | return NULL; | 208 | printk(KERN_WARNING "BUG: Your driver calls ioremap() on system memory. This leads\n" |
| 209 | KERN_WARNING "to architecturally unpredictable behaviour on ARMv6+, and ioremap()\n" | ||
| 210 | KERN_WARNING "will fail in the next kernel release. Please fix your driver.\n"); | ||
| 211 | WARN_ON(1); | ||
| 212 | } | ||
| 209 | 213 | ||
| 210 | type = get_mem_type(mtype); | 214 | type = get_mem_type(mtype); |
| 211 | if (!type) | 215 | if (!type) |
diff --git a/arch/arm/mm/mmu.c b/arch/arm/mm/mmu.c index 6a3a2d0cd6db..e8ed9dc461fe 100644 --- a/arch/arm/mm/mmu.c +++ b/arch/arm/mm/mmu.c | |||
| @@ -248,7 +248,7 @@ static struct mem_type mem_types[] = { | |||
| 248 | }, | 248 | }, |
| 249 | [MT_MEMORY] = { | 249 | [MT_MEMORY] = { |
| 250 | .prot_pte = L_PTE_PRESENT | L_PTE_YOUNG | L_PTE_DIRTY | | 250 | .prot_pte = L_PTE_PRESENT | L_PTE_YOUNG | L_PTE_DIRTY | |
| 251 | L_PTE_USER | L_PTE_EXEC, | 251 | L_PTE_WRITE | L_PTE_EXEC, |
| 252 | .prot_l1 = PMD_TYPE_TABLE, | 252 | .prot_l1 = PMD_TYPE_TABLE, |
| 253 | .prot_sect = PMD_TYPE_SECT | PMD_SECT_AP_WRITE, | 253 | .prot_sect = PMD_TYPE_SECT | PMD_SECT_AP_WRITE, |
| 254 | .domain = DOMAIN_KERNEL, | 254 | .domain = DOMAIN_KERNEL, |
| @@ -259,7 +259,7 @@ static struct mem_type mem_types[] = { | |||
| 259 | }, | 259 | }, |
| 260 | [MT_MEMORY_NONCACHED] = { | 260 | [MT_MEMORY_NONCACHED] = { |
| 261 | .prot_pte = L_PTE_PRESENT | L_PTE_YOUNG | L_PTE_DIRTY | | 261 | .prot_pte = L_PTE_PRESENT | L_PTE_YOUNG | L_PTE_DIRTY | |
| 262 | L_PTE_USER | L_PTE_EXEC | L_PTE_MT_BUFFERABLE, | 262 | L_PTE_WRITE | L_PTE_EXEC | L_PTE_MT_BUFFERABLE, |
| 263 | .prot_l1 = PMD_TYPE_TABLE, | 263 | .prot_l1 = PMD_TYPE_TABLE, |
| 264 | .prot_sect = PMD_TYPE_SECT | PMD_SECT_AP_WRITE, | 264 | .prot_sect = PMD_TYPE_SECT | PMD_SECT_AP_WRITE, |
| 265 | .domain = DOMAIN_KERNEL, | 265 | .domain = DOMAIN_KERNEL, |
diff --git a/arch/arm/mm/proc-v7.S b/arch/arm/mm/proc-v7.S index 7563ff0141bd..197f21bed5e9 100644 --- a/arch/arm/mm/proc-v7.S +++ b/arch/arm/mm/proc-v7.S | |||
| @@ -253,6 +253,14 @@ __v7_setup: | |||
| 253 | orreq r10, r10, #1 << 22 @ set bit #22 | 253 | orreq r10, r10, #1 << 22 @ set bit #22 |
| 254 | mcreq p15, 0, r10, c15, c0, 1 @ write diagnostic register | 254 | mcreq p15, 0, r10, c15, c0, 1 @ write diagnostic register |
| 255 | #endif | 255 | #endif |
| 256 | #ifdef CONFIG_ARM_ERRATA_743622 | ||
| 257 | teq r6, #0x20 @ present in r2p0 | ||
| 258 | teqne r6, #0x21 @ present in r2p1 | ||
| 259 | teqne r6, #0x22 @ present in r2p2 | ||
| 260 | mrceq p15, 0, r10, c15, c0, 1 @ read diagnostic register | ||
| 261 | orreq r10, r10, #1 << 6 @ set bit #6 | ||
| 262 | mcreq p15, 0, r10, c15, c0, 1 @ write diagnostic register | ||
| 263 | #endif | ||
| 256 | 264 | ||
| 257 | 3: mov r10, #0 | 265 | 3: mov r10, #0 |
| 258 | #ifdef HARVARD_CACHE | 266 | #ifdef HARVARD_CACHE |
| @@ -365,7 +373,7 @@ __v7_ca9mp_proc_info: | |||
| 365 | b __v7_ca9mp_setup | 373 | b __v7_ca9mp_setup |
| 366 | .long cpu_arch_name | 374 | .long cpu_arch_name |
| 367 | .long cpu_elf_name | 375 | .long cpu_elf_name |
| 368 | .long HWCAP_SWP|HWCAP_HALF|HWCAP_THUMB|HWCAP_FAST_MULT|HWCAP_EDSP | 376 | .long HWCAP_SWP|HWCAP_HALF|HWCAP_THUMB|HWCAP_FAST_MULT|HWCAP_EDSP|HWCAP_TLS |
| 369 | .long cpu_v7_name | 377 | .long cpu_v7_name |
| 370 | .long v7_processor_functions | 378 | .long v7_processor_functions |
| 371 | .long v7wbi_tlb_fns | 379 | .long v7wbi_tlb_fns |
