aboutsummaryrefslogtreecommitdiff
path: root/tools/testing/radix-tree/regression1.c
diff options
context:
space:
mode:
authorPaul Burton <[email protected]>2016-09-02 15:17:31 +0100
committerRalf Baechle <[email protected]>2016-09-29 18:59:49 +0200
commit058effe7fdc5776b017356f690976a857eea473f (patch)
treefb493ec17acf848dcdcb2d6d4e6a09a615ef3035 /tools/testing/radix-tree/regression1.c
parent305723ab439e14debc1d339aa04e835d488b8253 (diff)
MIPS: Fix detection of unsupported highmem with cache aliases
The paging_init() function contains code which detects that highmem is in use but unsupported due to dcache aliasing. However this code was ineffective because it was being run before the caches are probed, meaning that cpu_has_dc_aliases would always evaluate to false (unless a platform overrides it to a compile-time constant) and the detection of the unsupported case is never triggered. The kernel would then go on to attempt to use highmem & either hit coherency issues or trigger the BUG_ON in flush_kernel_dcache_page(). Fix this by running paging_init() later than cpu_cache_init(), such that the cpu_has_dc_aliases macro will evaluate correctly & the unsupported highmem case will be detected successfully. This then leads to a formerly hidden issue in that mem_init_free_highmem() will attempt to free all highmem pages, even though we're avoiding use of them & don't have valid page structs for them. This leads to an invalid pointer dereference & a TLB exception. Avoid this by skipping the loop in mem_init_free_highmem() if cpu_has_dc_aliases evaluates true. Signed-off-by: Paul Burton <[email protected]> Cc: Rabin Vincent <[email protected]> Cc: Matt Redfearn <[email protected]> Cc: Jerome Marchand <[email protected]> Cc: Alexander Sverdlin <[email protected]> Cc: Aurelien Jarno <[email protected]> Cc: Jaedon Shin <[email protected]> Cc: Toshi Kani <[email protected]> Cc: James Hogan <[email protected]> Cc: Sergey Ryazanov <[email protected]> Cc: Jonas Gorski <[email protected]> Cc: Kirill A. Shutemov <[email protected]> Cc: [email protected] Cc: [email protected] Patchwork: https://patchwork.linux-mips.org/patch/14184/ Signed-off-by: Ralf Baechle <[email protected]>
Diffstat (limited to 'tools/testing/radix-tree/regression1.c')
0 files changed, 0 insertions, 0 deletions