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 >