* [PATCH] scsi: ipr: Fix WARNING in ipr_init()
@ 2022-11-13 6:45 Shang XiaoJing
2022-11-26 0:20 ` Martin K. Petersen
2022-12-01 3:45 ` Martin K. Petersen
0 siblings, 2 replies; 3+ messages in thread
From: Shang XiaoJing @ 2022-11-13 6:45 UTC (permalink / raw)
To: brking, jejb, martin.petersen, wayneb, James.Bottomley,
linux-scsi
Cc: shangxiaojing
ipr_init() will not call unregister_reboot_notifier() when
pci_register_driver() failed, which causes the WARNING. Call
unregister_reboot_notifier() when pci_register_driver() failed.
notifier callback ipr_halt [ipr] already registered
WARNING: CPU: 3 PID: 299 at kernel/notifier.c:29
notifier_chain_register+0x16d/0x230
Modules linked in: ipr(+) xhci_pci_renesas xhci_hcd ehci_hcd usbcore
led_class gpu_sched drm_buddy video wmi drm_ttm_helper ttm
drm_display_helper drm_kms_helper drm drm_panel_orientation_quirks
agpgart cfbft
CPU: 3 PID: 299 Comm: modprobe Tainted: G W
6.1.0-rc1-00190-g39508d23b672-dirty #332
Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS
rel-1.15.0-0-g2dd4b9b3f840-prebuilt.qemu.org 04/01/2014
RIP: 0010:notifier_chain_register+0x16d/0x230
Call Trace:
<TASK>
__blocking_notifier_chain_register+0x73/0xb0
ipr_init+0x30/0x1000 [ipr]
do_one_initcall+0xdb/0x480
do_init_module+0x1cf/0x680
load_module+0x6a50/0x70a0
__do_sys_finit_module+0x12f/0x1c0
do_syscall_64+0x3f/0x90
entry_SYSCALL_64_after_hwframe+0x63/0xcd
Fixes: f72919ec2bbb ("[SCSI] ipr: implement shutdown changes and remove obsolete write cache parameter")
Signed-off-by: Shang XiaoJing <shangxiaojing@huawei.com>
---
drivers/scsi/ipr.c | 10 +++++++++-
1 file changed, 9 insertions(+), 1 deletion(-)
diff --git a/drivers/scsi/ipr.c b/drivers/scsi/ipr.c
index 9d01a3e3c26a..2022ffb45041 100644
--- a/drivers/scsi/ipr.c
+++ b/drivers/scsi/ipr.c
@@ -10872,11 +10872,19 @@ static struct notifier_block ipr_notifier = {
**/
static int __init ipr_init(void)
{
+ int rc;
+
ipr_info("IBM Power RAID SCSI Device Driver version: %s %s\n",
IPR_DRIVER_VERSION, IPR_DRIVER_DATE);
register_reboot_notifier(&ipr_notifier);
- return pci_register_driver(&ipr_driver);
+ rc = pci_register_driver(&ipr_driver);
+ if (rc) {
+ unregister_reboot_notifier(&ipr_notifier);
+ return rc;
+ }
+
+ return 0;
}
/**
--
2.17.1
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH] scsi: ipr: Fix WARNING in ipr_init()
2022-11-13 6:45 [PATCH] scsi: ipr: Fix WARNING in ipr_init() Shang XiaoJing
@ 2022-11-26 0:20 ` Martin K. Petersen
2022-12-01 3:45 ` Martin K. Petersen
1 sibling, 0 replies; 3+ messages in thread
From: Martin K. Petersen @ 2022-11-26 0:20 UTC (permalink / raw)
To: Shang XiaoJing
Cc: brking, jejb, martin.petersen, wayneb, James.Bottomley,
linux-scsi
Shang,
> ipr_init() will not call unregister_reboot_notifier() when
> pci_register_driver() failed, which causes the WARNING. Call
> unregister_reboot_notifier() when pci_register_driver() failed.
Applied to 6.2/scsi-staging, thanks!
--
Martin K. Petersen Oracle Linux Engineering
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] scsi: ipr: Fix WARNING in ipr_init()
2022-11-13 6:45 [PATCH] scsi: ipr: Fix WARNING in ipr_init() Shang XiaoJing
2022-11-26 0:20 ` Martin K. Petersen
@ 2022-12-01 3:45 ` Martin K. Petersen
1 sibling, 0 replies; 3+ messages in thread
From: Martin K. Petersen @ 2022-12-01 3:45 UTC (permalink / raw)
To: jejb, wayneb, James.Bottomley, linux-scsi, brking, Shang XiaoJing
Cc: Martin K . Petersen
On Sun, 13 Nov 2022 14:45:13 +0800, Shang XiaoJing wrote:
> ipr_init() will not call unregister_reboot_notifier() when
> pci_register_driver() failed, which causes the WARNING. Call
> unregister_reboot_notifier() when pci_register_driver() failed.
>
> notifier callback ipr_halt [ipr] already registered
> WARNING: CPU: 3 PID: 299 at kernel/notifier.c:29
> notifier_chain_register+0x16d/0x230
> Modules linked in: ipr(+) xhci_pci_renesas xhci_hcd ehci_hcd usbcore
> led_class gpu_sched drm_buddy video wmi drm_ttm_helper ttm
> drm_display_helper drm_kms_helper drm drm_panel_orientation_quirks
> agpgart cfbft
> CPU: 3 PID: 299 Comm: modprobe Tainted: G W
> 6.1.0-rc1-00190-g39508d23b672-dirty #332
> Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS
> rel-1.15.0-0-g2dd4b9b3f840-prebuilt.qemu.org 04/01/2014
> RIP: 0010:notifier_chain_register+0x16d/0x230
> Call Trace:
> <TASK>
> __blocking_notifier_chain_register+0x73/0xb0
> ipr_init+0x30/0x1000 [ipr]
> do_one_initcall+0xdb/0x480
> do_init_module+0x1cf/0x680
> load_module+0x6a50/0x70a0
> __do_sys_finit_module+0x12f/0x1c0
> do_syscall_64+0x3f/0x90
> entry_SYSCALL_64_after_hwframe+0x63/0xcd
>
> [...]
Applied to 6.2/scsi-queue, thanks!
[1/1] scsi: ipr: Fix WARNING in ipr_init()
https://git.kernel.org/mkp/scsi/c/e6f108bffc37
--
Martin K. Petersen Oracle Linux Engineering
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2022-12-01 3:47 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-11-13 6:45 [PATCH] scsi: ipr: Fix WARNING in ipr_init() Shang XiaoJing
2022-11-26 0:20 ` Martin K. Petersen
2022-12-01 3:45 ` Martin K. Petersen
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox