CVE-2026-43468
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
08/05/2026
Last modified:
12/05/2026
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
net/mlx5: Fix deadlock between devlink lock and esw->wq<br />
<br />
esw->work_queue executes esw_functions_changed_event_handler -><br />
esw_vfs_changed_event_handler and acquires the devlink lock.<br />
<br />
.eswitch_mode_set (acquires devlink lock in devlink_nl_pre_doit) -><br />
mlx5_devlink_eswitch_mode_set -> mlx5_eswitch_disable_locked -><br />
mlx5_eswitch_event_handler_unregister -> flush_workqueue deadlocks<br />
when esw_vfs_changed_event_handler executes.<br />
<br />
Fix that by no longer flushing the work to avoid the deadlock, and using<br />
a generation counter to keep track of work relevance. This avoids an old<br />
handler manipulating an esw that has undergone one or more mode changes:<br />
- the counter is incremented in mlx5_eswitch_event_handler_unregister.<br />
- the counter is read and passed to the ephemeral mlx5_host_work struct.<br />
- the work handler takes the devlink lock and bails out if the current<br />
generation is different than the one it was scheduled to operate on.<br />
- mlx5_eswitch_cleanup does the final draining before destroying the wq.<br />
<br />
No longer flushing the workqueue has the side effect of maybe no longer<br />
cancelling pending vport_change_handler work items, but that&#39;s ok since<br />
those are disabled elsewhere:<br />
- mlx5_eswitch_disable_locked disables the vport eq notifier.<br />
- mlx5_esw_vport_disable disarms the HW EQ notification and marks<br />
vport->enabled under state_lock to false to prevent pending vport<br />
handler from doing anything.<br />
- mlx5_eswitch_cleanup destroys the workqueue and makes sure all events<br />
are disabled/finished.
Impact
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/0de867f6e34eae6907b367fd152c55e61cb98608
- https://git.kernel.org/stable/c/3c7313cb41b1b427078440364d2f042c276a1c0b
- https://git.kernel.org/stable/c/4a7838bebc38374f74baaf88bf2cf8d439a92923
- https://git.kernel.org/stable/c/90e7e5d14d0bd25ffd019a3aa39d9f1c05fedbe1
- https://git.kernel.org/stable/c/957d2a58f7f8ebcbdd0a85935e0d2675134b890d
- https://git.kernel.org/stable/c/aed763abf0e905b4b8d747d1ba9e172961572f57



