aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_gfx.c
diff options
context:
space:
mode:
authorJoe Damato <[email protected]>2025-06-03 16:34:01 +0000
committerTony Nguyen <[email protected]>2025-06-10 16:10:47 +0000
commitb4a8085ceefb7bbb12c2b71c55e71fc946c6929f (patch)
tree6143689e15948c24c6b92d29a6f92da5c1929790 /drivers/gpu/drm/amd/amdgpu/amdgpu_gfx.c
parentice/ptp: fix crosstimestamp reporting (diff)
downloadkernel-b4a8085ceefb7bbb12c2b71c55e71fc946c6929f.tar.gz
kernel-b4a8085ceefb7bbb12c2b71c55e71fc946c6929f.zip
e1000: Move cancel_work_sync to avoid deadlock
Previously, e1000_down called cancel_work_sync for the e1000 reset task (via e1000_down_and_stop), which takes RTNL. As reported by users and syzbot, a deadlock is possible in the following scenario: CPU 0: - RTNL is held - e1000_close - e1000_down - cancel_work_sync (cancel / wait for e1000_reset_task()) CPU 1: - process_one_work - e1000_reset_task - take RTNL To remedy this, avoid calling cancel_work_sync from e1000_down (e1000_reset_task does nothing if the device is down anyway). Instead, call cancel_work_sync for e1000_reset_task when the device is being removed. Fixes: e400c7444d84 ("e1000: Hold RTNL when e1000_down can be called") Reported-by: [email protected] Closes: https://lore.kernel.org/netdev/[email protected]/ Reported-by: John <[email protected]> Closes: https://lore.kernel.org/netdev/CAP=Rh=OEsn4y_2LvkO3UtDWurKcGPnZ_NPSXK=FbgygNXL37Sw@mail.gmail.com/ Signed-off-by: Joe Damato <[email protected]> Acked-by: Stanislav Fomichev <[email protected]> Acked-by: Jacob Keller <[email protected]> Signed-off-by: Tony Nguyen <[email protected]>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_gfx.c')
0 files changed, 0 insertions, 0 deletions