kernel_samsung_a53x/drivers/scsi/qla2xxx
Quinn Tran e72bf6e916 scsi: qla2xxx: Fix use after free on unload
commit 07c903db0a2ff84b68efa1a74a4de353ea591eb0 upstream.

System crash is observed with stack trace warning of use after
free. There are 2 signals to tell dpc_thread to terminate (UNLOADING
flag and kthread_stop).

On setting the UNLOADING flag when dpc_thread happens to run at the time
and sees the flag, this causes dpc_thread to exit and clean up
itself. When kthread_stop is called for final cleanup, this causes use
after free.

Remove UNLOADING signal to terminate dpc_thread.  Use the kthread_stop
as the main signal to exit dpc_thread.

[596663.812935] kernel BUG at mm/slub.c:294!
[596663.812950] invalid opcode: 0000 [#1] SMP PTI
[596663.812957] CPU: 13 PID: 1475935 Comm: rmmod Kdump: loaded Tainted: G          IOE    --------- -  - 4.18.0-240.el8.x86_64 #1
[596663.812960] Hardware name: HP ProLiant DL380p Gen8, BIOS P70 08/20/2012
[596663.812974] RIP: 0010:__slab_free+0x17d/0x360

...
[596663.813008] Call Trace:
[596663.813022]  ? __dentry_kill+0x121/0x170
[596663.813030]  ? _cond_resched+0x15/0x30
[596663.813034]  ? _cond_resched+0x15/0x30
[596663.813039]  ? wait_for_completion+0x35/0x190
[596663.813048]  ? try_to_wake_up+0x63/0x540
[596663.813055]  free_task+0x5a/0x60
[596663.813061]  kthread_stop+0xf3/0x100
[596663.813103]  qla2x00_remove_one+0x284/0x440 [qla2xxx]

Cc: stable@vger.kernel.org
Signed-off-by: Quinn Tran <qutran@marvell.com>
Signed-off-by: Nilesh Javali <njavali@marvell.com>
Link: https://lore.kernel.org/r/20241115130313.46826-3-njavali@marvell.com
Reviewed-by: Himanshu Madhani <himanshu.madhani@oracle.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2024-12-17 13:24:28 +01:00
..
Kconfig
Makefile
qla_attr.c scsi: qla2xxx: Supported speed displayed incorrectly for VPorts 2024-12-17 13:24:28 +01:00
qla_bsg.c scsi: qla2xxx: Return ENOBUFS if sg_cnt is more than one for ELS cmds 2024-11-23 23:20:14 +01:00
qla_bsg.h
qla_dbg.c
qla_dbg.h
qla_def.h scsi: qla2xxx: Update manufacturer detail 2024-11-19 09:22:47 +01:00
qla_devtbl.h
qla_dfs.c
qla_dsd.h
qla_fw.h
qla_gbl.h
qla_gs.c scsi: qla2xxx: Fix optrom version displayed in FDMI 2024-11-23 23:20:13 +01:00
qla_init.c scsi: qla2xxx: Fix flash read failure 2024-11-23 23:20:15 +01:00
qla_inline.h
qla_iocb.c
qla_isr.c
qla_mbx.c
qla_mid.c scsi: qla2xxx: Fix NVMe and NPIV connect issue 2024-12-17 13:24:28 +01:00
qla_mr.c scsi: qla2xxx: Replace all non-returning strlcpy() with strscpy() 2024-11-19 12:27:06 +01:00
qla_mr.h
qla_nvme.c scsi: qla2xxx: validate nvme_local_port correctly 2024-11-23 23:20:15 +01:00
qla_nvme.h
qla_nx.c
qla_nx.h
qla_nx2.c
qla_nx2.h
qla_os.c scsi: qla2xxx: Fix use after free on unload 2024-12-17 13:24:28 +01:00
qla_settings.h
qla_sup.c scsi: qla2xxx: Fix flash read failure 2024-11-23 23:20:15 +01:00
qla_target.c
qla_target.h
qla_tmpl.c
qla_tmpl.h
qla_version.h
tcm_qla2xxx.c
tcm_qla2xxx.h