linux/arch
Christophe Leroy d37823c352 powerpc/32s: Fix kasan_init_region() for KASAN
It has been reported some configuration where the kernel doesn't
boot with KASAN enabled.

This is due to wrong BAT allocation for the KASAN area:

	---[ Data Block Address Translation ]---
	0: 0xc0000000-0xcfffffff 0x00000000       256M Kernel rw      m
	1: 0xd0000000-0xdfffffff 0x10000000       256M Kernel rw      m
	2: 0xe0000000-0xefffffff 0x20000000       256M Kernel rw      m
	3: 0xf8000000-0xf9ffffff 0x2a000000        32M Kernel rw      m
	4: 0xfa000000-0xfdffffff 0x2c000000        64M Kernel rw      m

A BAT must have both virtual and physical addresses alignment matching
the size of the BAT. This is not the case for BAT 4 above.

Fix kasan_init_region() by using block_size() function that is in
book3s32/mmu.c. To be able to reuse it here, make it non static and
change its name to bat_block_size() in order to avoid name conflict
with block_size() defined in <linux/blkdev.h>

Also reuse find_free_bat() to avoid an error message from setbat()
when no BAT is available.

And allocate memory outside of linear memory mapping to avoid
wasting that precious space.

With this change we get correct alignment for BATs and KASAN shadow
memory is allocated outside the linear memory space.

	---[ Data Block Address Translation ]---
	0: 0xc0000000-0xcfffffff 0x00000000       256M Kernel rw
	1: 0xd0000000-0xdfffffff 0x10000000       256M Kernel rw
	2: 0xe0000000-0xefffffff 0x20000000       256M Kernel rw
	3: 0xf8000000-0xfbffffff 0x7c000000        64M Kernel rw
	4: 0xfc000000-0xfdffffff 0x7a000000        32M Kernel rw

Fixes: 7974c47326 ("powerpc/32s: Implement dedicated kasan_init_region()")
Cc: stable@vger.kernel.org
Reported-by: Maxime Bizon <mbizon@freebox.fr>
Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu>
Tested-by: Maxime Bizon <mbizon@freebox.fr>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/7a50ef902494d1325227d47d33dada01e52e5518.1641818726.git.christophe.leroy@csgroup.eu
2022-01-16 20:51:05 +11:00
..
alpha TTY/Serial driver updates for 5.17-rc1 2022-01-12 11:21:52 -08:00
arc Linux 5.16-rc5 2021-12-13 10:48:46 +01:00
arm LED updates for 5.17. Nothing major is happening here. 2022-01-12 16:59:22 -08:00
arm64 sound updates for 5.17-rc1 2022-01-14 14:55:38 +01:00
csky Peter Zijlstra says: 2022-01-12 16:26:58 -08:00
h8300
hexagon Linux 5.16-rc5 2021-12-13 10:48:46 +01:00
ia64 Linux 5.16-rc5 2021-12-13 10:48:46 +01:00
m68k Peter Zijlstra says: 2022-01-11 17:24:45 -08:00
microblaze microblaze: Snapshot thread flags 2021-12-01 00:06:44 +01:00
mips - added support for more BCM47XX based devices 2022-01-14 15:08:36 +01:00
nds32 Peter Zijlstra says: 2022-01-12 16:26:58 -08:00
nios2
openrisc openrisc: Snapshot thread flags 2021-12-01 00:06:44 +01:00
parisc parisc: Default to 16 CPUs on 32-bit kernel 2022-01-11 11:57:38 +01:00
powerpc powerpc/32s: Fix kasan_init_region() for KASAN 2022-01-16 20:51:05 +11:00
riscv Peter Zijlstra says: 2022-01-12 16:26:58 -08:00
s390 Rework of the MSI interrupt infrastructure: 2022-01-13 09:05:29 -08:00
sh driver core changes for 5.17-rc1 2022-01-12 11:11:34 -08:00
sparc Rework of the MSI interrupt infrastructure: 2022-01-13 09:05:29 -08:00
um Peter Zijlstra says: 2022-01-11 17:24:45 -08:00
x86 Rework of the MSI interrupt infrastructure: 2022-01-13 09:05:29 -08:00
xtensa Linux 5.16-rc5 2021-12-13 10:48:46 +01:00
.gitignore
Kconfig - Add support for handling hw errors in SGX pages: poisoning, recovering 2022-01-10 09:44:09 -08:00