Re: [PATCH] mmc: via-sdmmc: add a check against NULL pointer dereference

From: Ulf Hansson
Date: Tue Jun 08 2021 - 09:18:36 EST


On Thu, 3 Jun 2021 at 15:33, Zheyu Ma <zheyuma97@xxxxxxxxx> wrote:
>
> Before referencing 'host->data', the driver needs to check whether it is
> null pointer, otherwise it will cause a null pointer reference.
>
> This log reveals it:
>
> [ 29.355199] BUG: kernel NULL pointer dereference, address:
> 0000000000000014
> [ 29.357323] #PF: supervisor write access in kernel mode
> [ 29.357706] #PF: error_code(0x0002) - not-present page
> [ 29.358088] PGD 0 P4D 0
> [ 29.358280] Oops: 0002 [#1] PREEMPT SMP PTI
> [ 29.358595] CPU: 2 PID: 0 Comm: swapper/2 Not tainted 5.12.4-
> g70e7f0549188-dirty #102
> [ 29.359164] Hardware name: QEMU Standard PC (Q35 + ICH9, 2009),
> BIOS rel-1.12.0-59-gc9ba5276e321-prebuilt.qemu.org 04/01/2014
> [ 29.359978] RIP: 0010:via_sdc_isr+0x21f/0x410
> [ 29.360314] Code: ff ff e8 84 aa d0 fd 66 45 89 7e 28 66 41 f7 c4 00
> 10 75 56 e8 72 aa d0 fd 66 41 f7 c4 00 c0 74 10 e8 65 aa d0 fd 48 8b 43
> 18 <c7> 40 14 ac ff ff ff e8 55 aa d0 fd 48 89 df e8 ad fb ff ff e9 77
> [ 29.361661] RSP: 0018:ffffc90000118e98 EFLAGS: 00010046
> [ 29.362042] RAX: 0000000000000000 RBX: ffff888107d77880
> RCX: 0000000000000000
> [ 29.362564] RDX: 0000000000000000 RSI: ffffffff835d20bb
> RDI: 00000000ffffffff
> [ 29.363085] RBP: ffffc90000118ed8 R08: 0000000000000001
> R09: 0000000000000001
> [ 29.363604] R10: 0000000000000000 R11: 0000000000000001
> R12: 0000000000008600
> [ 29.364128] R13: ffff888107d779c8 R14: ffffc90009c00200
> R15: 0000000000008000
> [ 29.364651] FS: 0000000000000000(0000) GS:ffff88817bc80000(0000)
> knlGS:0000000000000000
> [ 29.365235] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> [ 29.365655] CR2: 0000000000000014 CR3: 0000000005a2e000
> CR4: 00000000000006e0
> [ 29.366170] DR0: 0000000000000000 DR1: 0000000000000000
> DR2: 0000000000000000
> [ 29.366683] DR3: 0000000000000000 DR6: 00000000fffe0ff0
> DR7: 0000000000000400
> [ 29.367197] Call Trace:
> [ 29.367381] <IRQ>
> [ 29.367537] __handle_irq_event_percpu+0x53/0x3e0
> [ 29.367916] handle_irq_event_percpu+0x35/0x90
> [ 29.368247] handle_irq_event+0x39/0x60
> [ 29.368632] handle_fasteoi_irq+0xc2/0x1d0
> [ 29.368950] __common_interrupt+0x7f/0x150
> [ 29.369254] common_interrupt+0xb4/0xd0
> [ 29.369547] </IRQ>
> [ 29.369708] asm_common_interrupt+0x1e/0x40
> [ 29.370016] RIP: 0010:native_safe_halt+0x17/0x20
> [ 29.370360] Code: 07 0f 00 2d db 80 43 00 f4 5d c3 0f 1f 84 00 00 00
> 00 00 8b 05 c2 37 e5 01 55 48 89 e5 85 c0 7e 07 0f 00 2d bb 80 43 00 fb
> f4 <5d> c3 cc cc cc cc cc cc cc 55 48 89 e5 e8 67 53 ff ff 8b 0d f9 91
> [ 29.371696] RSP: 0018:ffffc9000008fe90 EFLAGS: 00000246
> [ 29.372079] RAX: 0000000000000000 RBX: 0000000000000002
> RCX: 0000000000000000
> [ 29.372595] RDX: 0000000000000000 RSI: ffffffff854f67a4
> RDI: ffffffff85403406
> [ 29.373122] RBP: ffffc9000008fe90 R08: 0000000000000001
> R09: 0000000000000001
> [ 29.373646] R10: 0000000000000000 R11: 0000000000000001
> R12: ffffffff86009188
> [ 29.374160] R13: 0000000000000000 R14: 0000000000000000
> R15: ffff888100258000
> [ 29.374690] default_idle+0x9/0x10
> [ 29.374944] arch_cpu_idle+0xa/0x10
> [ 29.375198] default_idle_call+0x6e/0x250
> [ 29.375491] do_idle+0x1f0/0x2d0
> [ 29.375740] cpu_startup_entry+0x18/0x20
> [ 29.376034] start_secondary+0x11f/0x160
> [ 29.376328] secondary_startup_64_no_verify+0xb0/0xbb
> [ 29.376705] Modules linked in:
> [ 29.376939] Dumping ftrace buffer:
> [ 29.377187] (ftrace buffer empty)
> [ 29.377460] CR2: 0000000000000014
> [ 29.377712] ---[ end trace 51a473dffb618c47 ]---
> [ 29.378056] RIP: 0010:via_sdc_isr+0x21f/0x410
> [ 29.378380] Code: ff ff e8 84 aa d0 fd 66 45 89 7e 28 66 41 f7 c4 00
> 10 75 56 e8 72 aa d0 fd 66 41 f7 c4 00 c0 74 10 e8 65 aa d0 fd 48 8b 43
> 18 <c7> 40 14 ac ff ff ff e8 55 aa d0 fd 48 89 df e8 ad fb ff ff e9 77
> [ 29.379714] RSP: 0018:ffffc90000118e98 EFLAGS: 00010046
> [ 29.380098] RAX: 0000000000000000 RBX: ffff888107d77880
> RCX: 0000000000000000
> [ 29.380614] RDX: 0000000000000000 RSI: ffffffff835d20bb
> RDI: 00000000ffffffff
> [ 29.381134] RBP: ffffc90000118ed8 R08: 0000000000000001
> R09: 0000000000000001
> [ 29.381653] R10: 0000000000000000 R11: 0000000000000001
> R12: 0000000000008600
> [ 29.382176] R13: ffff888107d779c8 R14: ffffc90009c00200
> R15: 0000000000008000
> [ 29.382697] FS: 0000000000000000(0000) GS:ffff88817bc80000(0000)
> knlGS:0000000000000000
> [ 29.383277] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> [ 29.383697] CR2: 0000000000000014 CR3: 0000000005a2e000
> CR4: 00000000000006e0
> [ 29.384223] DR0: 0000000000000000 DR1: 0000000000000000
> DR2: 0000000000000000
> [ 29.384736] DR3: 0000000000000000 DR6: 00000000fffe0ff0
> DR7: 0000000000000400
> [ 29.385260] Kernel panic - not syncing: Fatal exception in interrupt
> [ 29.385882] Dumping ftrace buffer:
> [ 29.386135] (ftrace buffer empty)
> [ 29.386401] Kernel Offset: disabled
> [ 29.386656] Rebooting in 1 seconds..
>
> Signed-off-by: Zheyu Ma <zheyuma97@xxxxxxxxx>

Applied for next, thanks!

Kind regards
Uffe


> ---
> drivers/mmc/host/via-sdmmc.c | 3 +++
> 1 file changed, 3 insertions(+)
>
> diff --git a/drivers/mmc/host/via-sdmmc.c b/drivers/mmc/host/via-sdmmc.c
> index a1d098560099..c32df5530b94 100644
> --- a/drivers/mmc/host/via-sdmmc.c
> +++ b/drivers/mmc/host/via-sdmmc.c
> @@ -857,6 +857,9 @@ static void via_sdc_data_isr(struct via_crdr_mmc_host *host, u16 intmask)
> {
> BUG_ON(intmask == 0);
>
> + if (!host->data)
> + return;
> +
> if (intmask & VIA_CRDR_SDSTS_DT)
> host->data->error = -ETIMEDOUT;
> else if (intmask & (VIA_CRDR_SDSTS_RC | VIA_CRDR_SDSTS_WC))
> --
> 2.17.6
>