arm64/acpi: NULL dereference reports from UBSAN at boot

From: Will Deacon
Date: Thu May 21 2020 - 06:10:00 EST


Hi folks,

I just tried booting the arm64 for-kernelci branch under QEMU (version
4.2.50 (v4.2.0-779-g4354edb6dcc7)) with UBSAN enabled, and I see a couple
of NULL pointer dereferences reported at boot. I think they're both GIC
related (log below). I don't see a panic with UBSAN disabled, so something's
fishy here.

Please can you take a look when you get a chance? I haven't had time to see
if this is a regression or not, but I don't think it's particularly serious
as I have all sorts of horrible stuff enabled in my .config, since I'm
trying to chase down another bug:

https://git.kernel.org/pub/scm/linux/kernel/git/mark/linux.git/plain/arch/arm64/configs/fuzzing.config?h=fuzzing/arm64-kernelci-20200519&id=c149cf6a51aa4f72d53fc681c6661094e93ef660

(on top of defconfig)

CONFIG_FAIL_PAGE_ALLOC may be to blame.

Cheers,

Will

--->8

[ 0.000000][ T0] ================================================================================
[ 0.000000][ T0] UBSAN: null-ptr-deref in drivers/acpi/acpica/tbfadt.c:459:37
[ 0.000000][ T0] member access within null pointer of type 'struct acpi_table_fadt'
[ 0.000000][ T0] CPU: 0 PID: 0 Comm: swapper Not tainted 5.7.0-rc6-00124-g96bc42ff0a82 #1
[ 0.000000][ T0] Call trace:
[ 0.000000][ T0] dump_backtrace+0x0/0x384
[ 0.000000][ T0] show_stack+0x28/0x38
[ 0.000000][ T0] dump_stack+0xec/0x174
[ 0.000000][ T0] handle_null_ptr_deref+0x134/0x174
[ 0.000000][ T0] __ubsan_handle_type_mismatch_v1+0x84/0xa4
[ 0.000000][ T0] acpi_tb_create_local_fadt+0x1d4/0x1418
[ 0.000000][ T0] acpi_tb_parse_fadt+0x108/0x4b8
[ 0.000000][ T0] acpi_tb_parse_root_table+0x380/0x578
[ 0.000000][ T0] acpi_initialize_tables+0x140/0x194
[ 0.000000][ T0] acpi_table_init+0x90/0xcc
[ 0.000000][ T0] acpi_boot_table_init+0xfc/0x1c8
[ 0.000000][ T0] setup_arch+0x2b4/0x3ec
[ 0.000000][ T0] start_kernel+0x98/0x6f4
[ 0.000000][ T0] ================================================================================

[ 0.000000][ T0] ================================================================================
[ 0.000000][ T0] UBSAN: null-ptr-deref in arch/arm64/kernel/smp.c:596:6
[ 0.000000][ T0] member access within null pointer of type 'struct acpi_madt_generic_interrupt'
[ 0.000000][ T0] CPU: 0 PID: 0 Comm: swapper Not tainted 5.7.0-rc6-00124-g96bc42ff0a82 #1
[ 0.000000][ T0] Call trace:
[ 0.000000][ T0] dump_backtrace+0x0/0x384
[ 0.000000][ T0] show_stack+0x28/0x38
[ 0.000000][ T0] dump_stack+0xec/0x174
[ 0.000000][ T0] handle_null_ptr_deref+0x134/0x174
[ 0.000000][ T0] __ubsan_handle_type_mismatch_v1+0x84/0xa4
[ 0.000000][ T0] acpi_parse_gic_cpu_interface+0x60/0xe8
[ 0.000000][ T0] acpi_parse_entries_array+0x288/0x498
[ 0.000000][ T0] acpi_table_parse_entries_array+0x178/0x1b4
[ 0.000000][ T0] acpi_table_parse_madt+0xa4/0x110
[ 0.000000][ T0] acpi_parse_and_init_cpus+0x38/0x100
[ 0.000000][ T0] smp_init_cpus+0x74/0x258
[ 0.000000][ T0] setup_arch+0x350/0x3ec
[ 0.000000][ T0] start_kernel+0x98/0x6f4
[ 0.000000][ T0] ================================================================================