summaryrefslogtreecommitdiff
path: root/drivers/bus/simple-pm-bus.c
diff options
context:
space:
mode:
authorManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>2023-01-23 10:29:45 +0300
committerManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>2023-01-27 10:01:41 +0300
commit1ddc7618294084fff8d673217a9479550990ee84 (patch)
treea1c166517bd8d83b03148acd64d76d7d0cbf551a /drivers/bus/simple-pm-bus.c
parent8a1c24bb908f9ecbc4be0fea014df67d43161551 (diff)
downloadlinux-1ddc7618294084fff8d673217a9479550990ee84.tar.xz
bus: mhi: ep: Change state_lock to mutex
state_lock, the spinlock type is meant to protect race against concurrent MHI state transitions. In mhi_ep_set_m0_state(), while the state_lock is being held, the channels are resumed in mhi_ep_resume_channels() if the previous state was M3. This causes sleeping in atomic bug, since mhi_ep_resume_channels() use mutex internally. Since the state_lock is supposed to be held throughout the state change, it is not ideal to drop the lock before calling mhi_ep_resume_channels(). So to fix this issue, let's change the type of state_lock to mutex. This would also allow holding the lock throughout all state transitions thereby avoiding any potential race. Cc: <stable@vger.kernel.org> # 5.19 Fixes: e4b7b5f0f30a ("bus: mhi: ep: Add support for suspending and resuming channels") Reported-by: Dan Carpenter <error27@gmail.com> Reviewed-by: Jeffrey Hugo <quic_jhugo@quicinc.com> Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Diffstat (limited to 'drivers/bus/simple-pm-bus.c')
0 files changed, 0 insertions, 0 deletions