aboutsummaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_irq.c
diff options
context:
space:
mode:
authorSara Sharon <[email protected]>2017-11-20 13:25:05 +0200
committerLuca Coelho <[email protected]>2017-11-25 17:12:56 +0200
commit0232d2cd7aa8e1b810fe84fb4059a0bd1eabe2ba (patch)
treee38e636bae4448e2a14b637e9be8fb7b1b40ab19 /drivers/gpu/drm/amd/amdgpu/amdgpu_irq.c
parentf3402d6d8eb084f6c2563dee1a09385b7c0ea2d5 (diff)
iwlwifi: fix access to prph when transport is stopped
When getting HW rfkill we get stop_device being called from two paths. One path is the IRQ calling stop device, and updating op mode and stack. As a result, cfg80211 is running rfkill sync work that shuts down all devices (second path). In the second path, we eventually get to iwl_mvm_stop_device which calls iwl_fw_dump_conf_clear->iwl_fw_dbg_stop_recording, that access periphery registers. The device may be stopped at this point from the first path, which will result with a failure to access those registers. Simply checking for the trans status is insufficient, since the race will still exist, only minimized. Instead, move the stop from iwl_fw_dump_conf_clear (which is getting called only from stop path) to the transport stop device function, where the access is always safe. This has the added value, of actually stopping dbgc before stopping device even when the stop is initiated from the transport. Fixes: 1efc3843a4ee ("iwlwifi: stop dbgc recording before stopping DMA") Signed-off-by: Sara Sharon <[email protected]> Signed-off-by: Luca Coelho <[email protected]>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_irq.c')
0 files changed, 0 insertions, 0 deletions