Vulnerability Details CVE-2024-47696
In the Linux kernel, the following vulnerability has been resolved:
RDMA/iwcm: Fix WARNING:at_kernel/workqueue.c:#check_flush_dependency
In the commit aee2424246f9 ("RDMA/iwcm: Fix a use-after-free related to
destroying CM IDs"), the function flush_workqueue is invoked to flush the
work queue iwcm_wq.
But at that time, the work queue iwcm_wq was created via the function
alloc_ordered_workqueue without the flag WQ_MEM_RECLAIM.
Because the current process is trying to flush the whole iwcm_wq, if
iwcm_wq doesn't have the flag WQ_MEM_RECLAIM, verify that the current
process is not reclaiming memory or running on a workqueue which doesn't
have the flag WQ_MEM_RECLAIM as that can break forward-progress guarantee
leading to a deadlock.
The call trace is as below:
[ 125.350876][ T1430] Call Trace:
[ 125.356281][ T1430] <TASK>
[ 125.361285][ T1430] ? __warn (kernel/panic.c:693)
[ 125.367640][ T1430] ? check_flush_dependency (kernel/workqueue.c:3706 (discriminator 9))
[ 125.375689][ T1430] ? report_bug (lib/bug.c:180 lib/bug.c:219)
[ 125.382505][ T1430] ? handle_bug (arch/x86/kernel/traps.c:239)
[ 125.388987][ T1430] ? exc_invalid_op (arch/x86/kernel/traps.c:260 (discriminator 1))
[ 125.395831][ T1430] ? asm_exc_invalid_op (arch/x86/include/asm/idtentry.h:621)
[ 125.403125][ T1430] ? check_flush_dependency (kernel/workqueue.c:3706 (discriminator 9))
[ 125.410984][ T1430] ? check_flush_dependency (kernel/workqueue.c:3706 (discriminator 9))
[ 125.418764][ T1430] __flush_workqueue (kernel/workqueue.c:3970)
[ 125.426021][ T1430] ? __pfx___might_resched (kernel/sched/core.c:10151)
[ 125.433431][ T1430] ? destroy_cm_id (drivers/infiniband/core/iwcm.c:375) iw_cm
[ 125.441209][ T1430] ? __pfx___flush_workqueue (kernel/workqueue.c:3910)
[ 125.473900][ T1430] ? _raw_spin_lock_irqsave (arch/x86/include/asm/atomic.h:107 include/linux/atomic/atomic-arch-fallback.h:2170 include/linux/atomic/atomic-instrumented.h:1302 include/asm-generic/qspinlock.h:111 include/linux/spinlock.h:187 include/linux/spinlock_api_smp.h:111 kernel/locking/spinlock.c:162)
[ 125.473909][ T1430] ? __pfx__raw_spin_lock_irqsave (kernel/locking/spinlock.c:161)
[ 125.482537][ T1430] _destroy_id (drivers/infiniband/core/cma.c:2044) rdma_cm
[ 125.495072][ T1430] nvme_rdma_free_queue (drivers/nvme/host/rdma.c:656 drivers/nvme/host/rdma.c:650) nvme_rdma
[ 125.505827][ T1430] nvme_rdma_reset_ctrl_work (drivers/nvme/host/rdma.c:2180) nvme_rdma
[ 125.505831][ T1430] process_one_work (kernel/workqueue.c:3231)
[ 125.515122][ T1430] worker_thread (kernel/workqueue.c:3306 kernel/workqueue.c:3393)
[ 125.515127][ T1430] ? __pfx_worker_thread (kernel/workqueue.c:3339)
[ 125.531837][ T1430] kthread (kernel/kthread.c:389)
[ 125.539864][ T1430] ? __pfx_kthread (kernel/kthread.c:342)
[ 125.550628][ T1430] ret_from_fork (arch/x86/kernel/process.c:147)
[ 125.558840][ T1430] ? __pfx_kthread (kernel/kthread.c:342)
[ 125.558844][ T1430] ret_from_fork_asm (arch/x86/entry/entry_64.S:257)
[ 125.566487][ T1430] </TASK>
[ 125.566488][ T1430] ---[ end trace 0000000000000000 ]---
Exploit prediction scoring system (EPSS) score
EPSS Score 0.0
EPSS Ranking 1.3%
CVSS Severity
CVSS v3 Score 7.8
Products affected by CVE-2024-47696
-
cpe:2.3:o:linux:linux_kernel:4.19.320
-
cpe:2.3:o:linux:linux_kernel:4.19.321
-
cpe:2.3:o:linux:linux_kernel:4.19.322
-
cpe:2.3:o:linux:linux_kernel:4.19.323
-
cpe:2.3:o:linux:linux_kernel:4.19.324
-
cpe:2.3:o:linux:linux_kernel:4.19.325
-
cpe:2.3:o:linux:linux_kernel:4.20
-
cpe:2.3:o:linux:linux_kernel:4.20.1
-
cpe:2.3:o:linux:linux_kernel:4.20.10
-
cpe:2.3:o:linux:linux_kernel:4.20.11
-
cpe:2.3:o:linux:linux_kernel:4.20.12
-
cpe:2.3:o:linux:linux_kernel:4.20.13
-
cpe:2.3:o:linux:linux_kernel:4.20.14
-
cpe:2.3:o:linux:linux_kernel:4.20.15
-
cpe:2.3:o:linux:linux_kernel:4.20.16
-
cpe:2.3:o:linux:linux_kernel:4.20.17
-
cpe:2.3:o:linux:linux_kernel:4.20.2
-
cpe:2.3:o:linux:linux_kernel:4.20.3
-
cpe:2.3:o:linux:linux_kernel:4.20.4
-
cpe:2.3:o:linux:linux_kernel:4.20.5
-
cpe:2.3:o:linux:linux_kernel:4.20.6
-
cpe:2.3:o:linux:linux_kernel:4.20.7
-
cpe:2.3:o:linux:linux_kernel:4.20.8
-
cpe:2.3:o:linux:linux_kernel:4.20.9
-
cpe:2.3:o:linux:linux_kernel:5.0
-
cpe:2.3:o:linux:linux_kernel:5.0.1
-
cpe:2.3:o:linux:linux_kernel:5.0.10
-
cpe:2.3:o:linux:linux_kernel:5.0.11
-
cpe:2.3:o:linux:linux_kernel:5.0.12
-
cpe:2.3:o:linux:linux_kernel:5.0.13
-
cpe:2.3:o:linux:linux_kernel:5.0.14
-
cpe:2.3:o:linux:linux_kernel:5.0.15
-
cpe:2.3:o:linux:linux_kernel:5.0.16
-
cpe:2.3:o:linux:linux_kernel:5.0.17
-
cpe:2.3:o:linux:linux_kernel:5.0.18
-
cpe:2.3:o:linux:linux_kernel:5.0.19
-
cpe:2.3:o:linux:linux_kernel:5.0.2
-
cpe:2.3:o:linux:linux_kernel:5.0.20
-
cpe:2.3:o:linux:linux_kernel:5.0.21
-
cpe:2.3:o:linux:linux_kernel:5.0.3
-
cpe:2.3:o:linux:linux_kernel:5.0.4
-
cpe:2.3:o:linux:linux_kernel:5.0.5
-
cpe:2.3:o:linux:linux_kernel:5.0.6
-
cpe:2.3:o:linux:linux_kernel:5.0.7
-
cpe:2.3:o:linux:linux_kernel:5.0.8
-
cpe:2.3:o:linux:linux_kernel:5.0.9
-
cpe:2.3:o:linux:linux_kernel:5.1
-
cpe:2.3:o:linux:linux_kernel:5.1.1
-
cpe:2.3:o:linux:linux_kernel:5.1.10
-
cpe:2.3:o:linux:linux_kernel:5.1.11
-
cpe:2.3:o:linux:linux_kernel:5.1.12
-
cpe:2.3:o:linux:linux_kernel:5.1.13
-
cpe:2.3:o:linux:linux_kernel:5.1.14
-
cpe:2.3:o:linux:linux_kernel:5.1.15
-
cpe:2.3:o:linux:linux_kernel:5.1.16
-
cpe:2.3:o:linux:linux_kernel:5.1.17
-
cpe:2.3:o:linux:linux_kernel:5.1.18
-
cpe:2.3:o:linux:linux_kernel:5.1.19
-
cpe:2.3:o:linux:linux_kernel:5.1.2
-
cpe:2.3:o:linux:linux_kernel:5.1.20
-
cpe:2.3:o:linux:linux_kernel:5.1.21
-
cpe:2.3:o:linux:linux_kernel:5.1.3
-
cpe:2.3:o:linux:linux_kernel:5.1.4
-
cpe:2.3:o:linux:linux_kernel:5.1.5
-
cpe:2.3:o:linux:linux_kernel:5.1.6
-
cpe:2.3:o:linux:linux_kernel:5.1.7
-
cpe:2.3:o:linux:linux_kernel:5.1.8
-
cpe:2.3:o:linux:linux_kernel:5.1.9
-
cpe:2.3:o:linux:linux_kernel:5.10.224
-
cpe:2.3:o:linux:linux_kernel:5.10.225
-
cpe:2.3:o:linux:linux_kernel:5.10.226
-
cpe:2.3:o:linux:linux_kernel:5.15.165
-
cpe:2.3:o:linux:linux_kernel:5.15.166
-
cpe:2.3:o:linux:linux_kernel:5.15.167
-
cpe:2.3:o:linux:linux_kernel:5.2
-
cpe:2.3:o:linux:linux_kernel:5.2.1
-
cpe:2.3:o:linux:linux_kernel:5.2.10
-
cpe:2.3:o:linux:linux_kernel:5.2.11
-
cpe:2.3:o:linux:linux_kernel:5.2.12
-
cpe:2.3:o:linux:linux_kernel:5.2.13
-
cpe:2.3:o:linux:linux_kernel:5.2.14
-
cpe:2.3:o:linux:linux_kernel:5.2.15
-
cpe:2.3:o:linux:linux_kernel:5.2.16
-
cpe:2.3:o:linux:linux_kernel:5.2.17
-
cpe:2.3:o:linux:linux_kernel:5.2.18
-
cpe:2.3:o:linux:linux_kernel:5.2.19
-
cpe:2.3:o:linux:linux_kernel:5.2.2
-
cpe:2.3:o:linux:linux_kernel:5.2.20
-
cpe:2.3:o:linux:linux_kernel:5.2.21
-
cpe:2.3:o:linux:linux_kernel:5.2.3
-
cpe:2.3:o:linux:linux_kernel:5.2.4
-
cpe:2.3:o:linux:linux_kernel:5.2.5
-
cpe:2.3:o:linux:linux_kernel:5.2.6
-
cpe:2.3:o:linux:linux_kernel:5.2.7
-
cpe:2.3:o:linux:linux_kernel:5.2.8
-
cpe:2.3:o:linux:linux_kernel:5.2.9
-
cpe:2.3:o:linux:linux_kernel:5.3
-
cpe:2.3:o:linux:linux_kernel:5.3.1
-
cpe:2.3:o:linux:linux_kernel:5.3.10
-
cpe:2.3:o:linux:linux_kernel:5.3.11
-
cpe:2.3:o:linux:linux_kernel:5.3.12
-
cpe:2.3:o:linux:linux_kernel:5.3.13
-
cpe:2.3:o:linux:linux_kernel:5.3.14
-
cpe:2.3:o:linux:linux_kernel:5.3.15
-
cpe:2.3:o:linux:linux_kernel:5.3.16
-
cpe:2.3:o:linux:linux_kernel:5.3.17
-
cpe:2.3:o:linux:linux_kernel:5.3.18
-
cpe:2.3:o:linux:linux_kernel:5.3.2
-
cpe:2.3:o:linux:linux_kernel:5.3.3
-
cpe:2.3:o:linux:linux_kernel:5.3.4
-
cpe:2.3:o:linux:linux_kernel:5.3.5
-
cpe:2.3:o:linux:linux_kernel:5.3.6
-
cpe:2.3:o:linux:linux_kernel:5.3.7
-
cpe:2.3:o:linux:linux_kernel:5.3.8
-
cpe:2.3:o:linux:linux_kernel:5.3.9
-
cpe:2.3:o:linux:linux_kernel:5.4.282
-
cpe:2.3:o:linux:linux_kernel:5.4.283
-
cpe:2.3:o:linux:linux_kernel:5.4.284
-
cpe:2.3:o:linux:linux_kernel:5.4.285
-
cpe:2.3:o:linux:linux_kernel:5.4.286
-
cpe:2.3:o:linux:linux_kernel:5.4.287
-
cpe:2.3:o:linux:linux_kernel:5.4.288
-
cpe:2.3:o:linux:linux_kernel:5.4.289
-
cpe:2.3:o:linux:linux_kernel:5.4.290
-
cpe:2.3:o:linux:linux_kernel:5.4.291
-
cpe:2.3:o:linux:linux_kernel:5.4.292
-
cpe:2.3:o:linux:linux_kernel:5.4.293
-
cpe:2.3:o:linux:linux_kernel:5.4.294
-
cpe:2.3:o:linux:linux_kernel:5.4.295
-
cpe:2.3:o:linux:linux_kernel:5.4.296
-
cpe:2.3:o:linux:linux_kernel:5.4.297
-
cpe:2.3:o:linux:linux_kernel:5.4.298
-
cpe:2.3:o:linux:linux_kernel:5.4.299
-
cpe:2.3:o:linux:linux_kernel:5.4.300
-
cpe:2.3:o:linux:linux_kernel:5.4.301
-
cpe:2.3:o:linux:linux_kernel:5.4.302
-
cpe:2.3:o:linux:linux_kernel:5.5
-
cpe:2.3:o:linux:linux_kernel:5.5.0
-
cpe:2.3:o:linux:linux_kernel:5.5.1
-
cpe:2.3:o:linux:linux_kernel:5.5.10
-
cpe:2.3:o:linux:linux_kernel:5.5.11
-
cpe:2.3:o:linux:linux_kernel:5.5.12
-
cpe:2.3:o:linux:linux_kernel:5.5.13
-
cpe:2.3:o:linux:linux_kernel:5.5.14
-
cpe:2.3:o:linux:linux_kernel:5.5.15
-
cpe:2.3:o:linux:linux_kernel:5.5.16
-
cpe:2.3:o:linux:linux_kernel:5.5.17
-
cpe:2.3:o:linux:linux_kernel:5.5.18
-
cpe:2.3:o:linux:linux_kernel:5.5.19
-
cpe:2.3:o:linux:linux_kernel:5.5.2
-
cpe:2.3:o:linux:linux_kernel:5.5.3
-
cpe:2.3:o:linux:linux_kernel:5.5.4
-
cpe:2.3:o:linux:linux_kernel:5.5.5
-
cpe:2.3:o:linux:linux_kernel:5.5.6
-
cpe:2.3:o:linux:linux_kernel:5.5.7
-
cpe:2.3:o:linux:linux_kernel:5.5.8
-
cpe:2.3:o:linux:linux_kernel:5.5.9
-
cpe:2.3:o:linux:linux_kernel:5.6
-
cpe:2.3:o:linux:linux_kernel:5.6.1
-
cpe:2.3:o:linux:linux_kernel:5.6.10
-
cpe:2.3:o:linux:linux_kernel:5.6.11
-
cpe:2.3:o:linux:linux_kernel:5.6.12
-
cpe:2.3:o:linux:linux_kernel:5.6.13
-
cpe:2.3:o:linux:linux_kernel:5.6.14
-
cpe:2.3:o:linux:linux_kernel:5.6.15
-
cpe:2.3:o:linux:linux_kernel:5.6.16
-
cpe:2.3:o:linux:linux_kernel:5.6.17
-
cpe:2.3:o:linux:linux_kernel:5.6.18
-
cpe:2.3:o:linux:linux_kernel:5.6.19
-
cpe:2.3:o:linux:linux_kernel:5.6.2
-
cpe:2.3:o:linux:linux_kernel:5.6.3
-
cpe:2.3:o:linux:linux_kernel:5.6.4
-
cpe:2.3:o:linux:linux_kernel:5.6.5
-
cpe:2.3:o:linux:linux_kernel:5.6.6
-
cpe:2.3:o:linux:linux_kernel:5.6.7
-
cpe:2.3:o:linux:linux_kernel:5.6.7-1
-
cpe:2.3:o:linux:linux_kernel:5.6.8
-
cpe:2.3:o:linux:linux_kernel:5.6.9
-
cpe:2.3:o:linux:linux_kernel:5.7
-
cpe:2.3:o:linux:linux_kernel:5.7.0
-
cpe:2.3:o:linux:linux_kernel:5.7.1
-
cpe:2.3:o:linux:linux_kernel:5.7.10
-
cpe:2.3:o:linux:linux_kernel:5.7.11
-
cpe:2.3:o:linux:linux_kernel:5.7.12
-
cpe:2.3:o:linux:linux_kernel:5.7.13
-
cpe:2.3:o:linux:linux_kernel:5.7.14
-
cpe:2.3:o:linux:linux_kernel:5.7.15
-
cpe:2.3:o:linux:linux_kernel:5.7.16
-
cpe:2.3:o:linux:linux_kernel:5.7.17
-
cpe:2.3:o:linux:linux_kernel:5.7.18
-
cpe:2.3:o:linux:linux_kernel:5.7.19
-
cpe:2.3:o:linux:linux_kernel:5.7.2
-
cpe:2.3:o:linux:linux_kernel:5.7.3
-
cpe:2.3:o:linux:linux_kernel:5.7.4
-
cpe:2.3:o:linux:linux_kernel:5.7.5
-
cpe:2.3:o:linux:linux_kernel:5.7.6
-
cpe:2.3:o:linux:linux_kernel:5.7.7
-
cpe:2.3:o:linux:linux_kernel:5.7.8
-
cpe:2.3:o:linux:linux_kernel:5.7.9
-
cpe:2.3:o:linux:linux_kernel:5.8
-
cpe:2.3:o:linux:linux_kernel:5.8.0
-
cpe:2.3:o:linux:linux_kernel:5.8.1
-
cpe:2.3:o:linux:linux_kernel:5.8.10
-
cpe:2.3:o:linux:linux_kernel:5.8.11
-
cpe:2.3:o:linux:linux_kernel:5.8.12
-
cpe:2.3:o:linux:linux_kernel:5.8.13
-
cpe:2.3:o:linux:linux_kernel:5.8.14
-
cpe:2.3:o:linux:linux_kernel:5.8.15
-
cpe:2.3:o:linux:linux_kernel:5.8.16
-
cpe:2.3:o:linux:linux_kernel:5.8.17
-
cpe:2.3:o:linux:linux_kernel:5.8.18
-
cpe:2.3:o:linux:linux_kernel:5.8.2
-
cpe:2.3:o:linux:linux_kernel:5.8.3
-
cpe:2.3:o:linux:linux_kernel:5.8.4
-
cpe:2.3:o:linux:linux_kernel:5.8.5
-
cpe:2.3:o:linux:linux_kernel:5.8.6
-
cpe:2.3:o:linux:linux_kernel:5.8.7
-
cpe:2.3:o:linux:linux_kernel:5.8.8
-
cpe:2.3:o:linux:linux_kernel:5.8.9
-
cpe:2.3:o:linux:linux_kernel:5.9
-
cpe:2.3:o:linux:linux_kernel:5.9.0
-
cpe:2.3:o:linux:linux_kernel:5.9.1
-
cpe:2.3:o:linux:linux_kernel:5.9.10
-
cpe:2.3:o:linux:linux_kernel:5.9.11
-
cpe:2.3:o:linux:linux_kernel:5.9.12
-
cpe:2.3:o:linux:linux_kernel:5.9.13
-
cpe:2.3:o:linux:linux_kernel:5.9.14
-
cpe:2.3:o:linux:linux_kernel:5.9.15
-
cpe:2.3:o:linux:linux_kernel:5.9.16
-
cpe:2.3:o:linux:linux_kernel:5.9.2
-
cpe:2.3:o:linux:linux_kernel:5.9.3
-
cpe:2.3:o:linux:linux_kernel:5.9.4
-
cpe:2.3:o:linux:linux_kernel:5.9.5
-
cpe:2.3:o:linux:linux_kernel:5.9.6
-
cpe:2.3:o:linux:linux_kernel:5.9.7
-
cpe:2.3:o:linux:linux_kernel:5.9.8
-
cpe:2.3:o:linux:linux_kernel:5.9.9
-
cpe:2.3:o:linux:linux_kernel:6.1.103
-
cpe:2.3:o:linux:linux_kernel:6.1.104
-
cpe:2.3:o:linux:linux_kernel:6.1.105
-
cpe:2.3:o:linux:linux_kernel:6.1.106
-
cpe:2.3:o:linux:linux_kernel:6.1.107
-
cpe:2.3:o:linux:linux_kernel:6.1.108
-
cpe:2.3:o:linux:linux_kernel:6.1.109
-
cpe:2.3:o:linux:linux_kernel:6.1.110
-
cpe:2.3:o:linux:linux_kernel:6.1.111
-
cpe:2.3:o:linux:linux_kernel:6.1.112
-
cpe:2.3:o:linux:linux_kernel:6.10.10
-
cpe:2.3:o:linux:linux_kernel:6.10.11
-
cpe:2.3:o:linux:linux_kernel:6.10.12
-
cpe:2.3:o:linux:linux_kernel:6.10.3
-
cpe:2.3:o:linux:linux_kernel:6.10.4
-
cpe:2.3:o:linux:linux_kernel:6.10.5
-
cpe:2.3:o:linux:linux_kernel:6.10.6
-
cpe:2.3:o:linux:linux_kernel:6.10.7
-
cpe:2.3:o:linux:linux_kernel:6.10.8
-
cpe:2.3:o:linux:linux_kernel:6.10.9
-
cpe:2.3:o:linux:linux_kernel:6.11
-
cpe:2.3:o:linux:linux_kernel:6.11.1
-
cpe:2.3:o:linux:linux_kernel:6.6.44
-
cpe:2.3:o:linux:linux_kernel:6.6.45
-
cpe:2.3:o:linux:linux_kernel:6.6.46
-
cpe:2.3:o:linux:linux_kernel:6.6.47
-
cpe:2.3:o:linux:linux_kernel:6.6.48
-
cpe:2.3:o:linux:linux_kernel:6.6.49
-
cpe:2.3:o:linux:linux_kernel:6.6.50
-
cpe:2.3:o:linux:linux_kernel:6.6.51
-
cpe:2.3:o:linux:linux_kernel:6.6.52
-
cpe:2.3:o:linux:linux_kernel:6.6.53