Commit b506923e authored by Christophe Leroy's avatar Christophe Leroy Committed by Michael Ellerman

Revert "powerpc/kasan: Fix shadow pages allocation failure"

This reverts commit d2a91cef.

This commit moved too much work in kasan_init(). The allocation
of shadow pages has to be moved for the reason explained in that
patch, but the allocation of page tables still need to be done
before switching to the final hash table.

First revert the incorrect commit, following patch redoes it
properly.

Fixes: d2a91cef ("powerpc/kasan: Fix shadow pages allocation failure")
Cc: stable@vger.kernel.org
Reported-by: default avatarErhard F. <erhard_f@mailbox.org>
Signed-off-by: default avatarChristophe Leroy <christophe.leroy@csgroup.eu>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://bugzilla.kernel.org/show_bug.cgi?id=208181
Link: https://lore.kernel.org/r/3667deb0911affbf999b99f87c31c77d5e870cd2.1593690707.git.christophe.leroy@csgroup.eu
parent 7d38f089
...@@ -27,10 +27,12 @@ ...@@ -27,10 +27,12 @@
#ifdef CONFIG_KASAN #ifdef CONFIG_KASAN
void kasan_early_init(void); void kasan_early_init(void);
void kasan_mmu_init(void);
void kasan_init(void); void kasan_init(void);
void kasan_late_init(void); void kasan_late_init(void);
#else #else
static inline void kasan_init(void) { } static inline void kasan_init(void) { }
static inline void kasan_mmu_init(void) { }
static inline void kasan_late_init(void) { } static inline void kasan_late_init(void) { }
#endif #endif
......
...@@ -171,6 +171,8 @@ void __init MMU_init(void) ...@@ -171,6 +171,8 @@ void __init MMU_init(void)
btext_unmap(); btext_unmap();
#endif #endif
kasan_mmu_init();
setup_kup(); setup_kup();
/* Shortly after that, the entire linear mapping will be available */ /* Shortly after that, the entire linear mapping will be available */
......
...@@ -117,7 +117,7 @@ static void __init kasan_unmap_early_shadow_vmalloc(void) ...@@ -117,7 +117,7 @@ static void __init kasan_unmap_early_shadow_vmalloc(void)
kasan_update_early_region(k_start, k_end, __pte(0)); kasan_update_early_region(k_start, k_end, __pte(0));
} }
static void __init kasan_mmu_init(void) void __init kasan_mmu_init(void)
{ {
int ret; int ret;
struct memblock_region *reg; struct memblock_region *reg;
...@@ -146,8 +146,6 @@ static void __init kasan_mmu_init(void) ...@@ -146,8 +146,6 @@ static void __init kasan_mmu_init(void)
void __init kasan_init(void) void __init kasan_init(void)
{ {
kasan_mmu_init();
kasan_remap_early_shadow_ro(); kasan_remap_early_shadow_ro();
clear_page(kasan_early_shadow_page); clear_page(kasan_early_shadow_page);
......
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