[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <Z39qZWlXtjNnrcMt@mev-dev.igk.intel.com>
Date: Thu, 9 Jan 2025 07:19:17 +0100
From: Michal Swiatkowski <michal.swiatkowski@...ux.intel.com>
To: Shradha Gupta <shradhagupta@...ux.microsoft.com>
Cc: linux-hyperv@...r.kernel.org, netdev@...r.kernel.org,
linux-kernel@...r.kernel.org,
"K. Y. Srinivasan" <kys@...rosoft.com>,
Haiyang Zhang <haiyangz@...rosoft.com>,
Wei Liu <wei.liu@...nel.org>, Dexuan Cui <decui@...rosoft.com>,
Andrew Lunn <andrew+netdev@...n.ch>,
"David S. Miller" <davem@...emloft.net>,
Eric Dumazet <edumazet@...gle.com>,
Jakub Kicinski <kuba@...nel.org>, Paolo Abeni <pabeni@...hat.com>,
Long Li <longli@...rosoft.com>,
Konstantin Taranov <kotaranov@...rosoft.com>,
Souradeep Chakrabarti <schakrabarti@...ux.microsoft.com>,
Yury Norov <yury.norov@...il.com>,
Kalesh AP <kalesh-anakkur.purayil@...adcom.com>,
Maxim Levitsky <mlevitsk@...hat.com>,
Peter Zijlstra <peterz@...radead.org>,
Shradha Gupta <shradhagupta@...rosoft.com>, stable@...r.kernel.org
Subject: Re: [PATCH net] net: mana: Cleanup "mana" debugfs dir after cleanup
of all children
On Wed, Jan 08, 2025 at 09:03:11PM -0800, Shradha Gupta wrote:
> In mana_driver_exit(), mana_debugfs_root gets cleanup before any of it's
> children (which happens later in the pci_unregister_driver()).
> Due to this, when mana driver is configured as a module and rmmod is
> invoked, following stack gets printed along with failure in rmmod command.
>
> [ 2399.317651] BUG: kernel NULL pointer dereference, address: 0000000000000098
> [ 2399.318657] #PF: supervisor write access in kernel mode
> [ 2399.319057] #PF: error_code(0x0002) - not-present page
> [ 2399.319528] PGD 10eb68067 P4D 0
> [ 2399.319914] Oops: Oops: 0002 [#1] SMP NOPTI
> [ 2399.320308] CPU: 72 UID: 0 PID: 5815 Comm: rmmod Not tainted 6.13.0-rc5+ #89
> [ 2399.320986] Hardware name: Microsoft Corporation Virtual Machine/Virtual Machine, BIOS Hyper-V UEFI Release v4.1 09/28/2024
> [ 2399.321892] RIP: 0010:down_write+0x1a/0x50
> [ 2399.322303] Code: 90 90 90 90 90 90 90 90 90 90 90 90 90 90 90 90 0f 1f 44 00 00 55 48 89 e5 41 54 49 89 fc e8 9d cd ff ff 31 c0 ba 01 00 00 00 <f0> 49 0f b1 14 24 75 17 65 48 8b 05 f6 84 dd 5f 49 89 44 24 08 4c
> [ 2399.323669] RSP: 0018:ff53859d6c663a70 EFLAGS: 00010246
> [ 2399.324061] RAX: 0000000000000000 RBX: ff1d4eb505060180 RCX: ffffff8100000000
> [ 2399.324620] RDX: 0000000000000001 RSI: 0000000000000064 RDI: 0000000000000098
> [ 2399.325167] RBP: ff53859d6c663a78 R08: 00000000000009c4 R09: ff1d4eb4fac90000
> [ 2399.325681] R10: 0000000000000000 R11: 0000000000000001 R12: 0000000000000098
> [ 2399.326185] R13: ff1d4e42e1a4a0c8 R14: ff1d4eb538ce0000 R15: 0000000000000098
> [ 2399.326755] FS: 00007fe729570000(0000) GS:ff1d4eb2b7200000(0000) knlGS:0000000000000000
> [ 2399.327269] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> [ 2399.327690] CR2: 0000000000000098 CR3: 00000001c0584005 CR4: 0000000000373ef0
> [ 2399.328166] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
> [ 2399.328623] DR3: 0000000000000000 DR6: 00000000fffe07f0 DR7: 0000000000000400
> [ 2399.329055] Call Trace:
> [ 2399.329243] <TASK>
> [ 2399.329379] ? show_regs+0x69/0x80
> [ 2399.329602] ? __die+0x25/0x70
> [ 2399.329856] ? page_fault_oops+0x271/0x550
> [ 2399.330088] ? psi_group_change+0x217/0x470
> [ 2399.330341] ? do_user_addr_fault+0x455/0x7b0
> [ 2399.330667] ? finish_task_switch.isra.0+0x91/0x2f0
> [ 2399.331004] ? exc_page_fault+0x73/0x160
> [ 2399.331275] ? asm_exc_page_fault+0x27/0x30
> [ 2399.343324] ? down_write+0x1a/0x50
> [ 2399.343631] simple_recursive_removal+0x4d/0x2c0
> [ 2399.343977] ? __pfx_remove_one+0x10/0x10
> [ 2399.344251] debugfs_remove+0x45/0x70
> [ 2399.344511] mana_destroy_rxq+0x44/0x400 [mana]
> [ 2399.344845] mana_destroy_vport+0x54/0x1c0 [mana]
> [ 2399.345229] mana_detach+0x2f1/0x4e0 [mana]
> [ 2399.345466] ? ida_free+0x150/0x160
> [ 2399.345718] ? __cond_resched+0x1a/0x50
> [ 2399.345987] mana_remove+0xf4/0x1a0 [mana]
> [ 2399.346243] mana_gd_remove+0x25/0x80 [mana]
> [ 2399.346605] pci_device_remove+0x41/0xb0
> [ 2399.346878] device_remove+0x46/0x70
> [ 2399.347150] device_release_driver_internal+0x1e3/0x250
> [ 2399.347831] ? klist_remove+0x81/0xe0
> [ 2399.348377] driver_detach+0x4b/0xa0
> [ 2399.348906] bus_remove_driver+0x83/0x100
> [ 2399.349435] driver_unregister+0x31/0x60
> [ 2399.349919] pci_unregister_driver+0x40/0x90
> [ 2399.350492] mana_driver_exit+0x1c/0xb50 [mana]
> [ 2399.351102] __do_sys_delete_module.constprop.0+0x184/0x320
> [ 2399.351664] ? __fput+0x1a9/0x2d0
> [ 2399.352200] __x64_sys_delete_module+0x12/0x20
> [ 2399.352760] x64_sys_call+0x1e66/0x2140
> [ 2399.353316] do_syscall_64+0x79/0x150
> [ 2399.353813] ? syscall_exit_to_user_mode+0x49/0x230
> [ 2399.354346] ? do_syscall_64+0x85/0x150
> [ 2399.354816] ? irqentry_exit+0x1d/0x30
> [ 2399.355287] ? exc_page_fault+0x7f/0x160
> [ 2399.355756] entry_SYSCALL_64_after_hwframe+0x76/0x7e
> [ 2399.356302] RIP: 0033:0x7fe728d26aeb
> [ 2399.356776] Code: 73 01 c3 48 8b 0d 45 33 0f 00 f7 d8 64 89 01 48 83 c8 ff c3 66 2e 0f 1f 84 00 00 00 00 00 90 f3 0f 1e fa b8 b0 00 00 00 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 8b 0d 15 33 0f 00 f7 d8 64 89 01 48
> [ 2399.358372] RSP: 002b:00007ffff954d6f8 EFLAGS: 00000206 ORIG_RAX: 00000000000000b0
> [ 2399.359066] RAX: ffffffffffffffda RBX: 00005609156cc760 RCX: 00007fe728d26aeb
> [ 2399.359779] RDX: 000000000000000a RSI: 0000000000000800 RDI: 00005609156cc7c8
> [ 2399.360535] RBP: 0000000000000000 R08: 0000000000000000 R09: 0000000000000000
> [ 2399.361261] R10: 00007fe728dbeac0 R11: 0000000000000206 R12: 00007ffff954d950
> [ 2399.361952] R13: 00005609156cc2a0 R14: 00007ffff954ee5f R15: 00005609156cc760
> [ 2399.362688] </TASK>
>
> Fixes: 6607c17c6c5e ("net: mana: Enable debugfs files for MANA device")
> Cc: stable@...r.kernel.org
> Signed-off-by: Shradha Gupta <shradhagupta@...ux.microsoft.com>
> ---
> drivers/net/ethernet/microsoft/mana/gdma_main.c | 4 ++--
> 1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/net/ethernet/microsoft/mana/gdma_main.c b/drivers/net/ethernet/microsoft/mana/gdma_main.c
> index 2dc0c6ad54be..be95336ce089 100644
> --- a/drivers/net/ethernet/microsoft/mana/gdma_main.c
> +++ b/drivers/net/ethernet/microsoft/mana/gdma_main.c
> @@ -1656,9 +1656,9 @@ static int __init mana_driver_init(void)
>
> static void __exit mana_driver_exit(void)
> {
> - debugfs_remove(mana_debugfs_root);
> -
> pci_unregister_driver(&mana_driver);
> +
> + debugfs_remove(mana_debugfs_root);
Reviewed-by: Michal Swiatkowski <michal.swiatkowski@...ux.intel.com>
Thanks
> }
>
> module_init(mana_driver_init);
> --
> 2.34.1
>
Powered by blists - more mailing lists