bus: mhi: core: Remove double locking from mhi_driver_remove()
authorBhaumik Bhatt <bbhatt@codeaurora.org>
Thu, 15 Oct 2020 18:47:51 +0000 (11:47 -0700)
committerManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Wed, 18 Nov 2020 09:50:34 +0000 (15:20 +0530)
There is double acquisition of the pm_lock from mhi_driver_remove()
function. Remove the read_lock_bh/read_unlock_bh calls for pm_lock
taken during a call to mhi_device_put() as the lock is acquired
within the function already. This will help avoid a potential
kernel panic.

Fixes: 189ff97cca53 ("bus: mhi: core: Add support for data transfer")
Reported-by: Shuah Khan <skhan@linuxfoundation.org>
Signed-off-by: Bhaumik Bhatt <bbhatt@codeaurora.org>
Reviewed-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
drivers/bus/mhi/core/init.c

index 0ffdebde826576f3baa525868a2ec416c63dd88b..0a09f8215057da7b2eb9d23f8409ee76ce9582f5 100644 (file)
@@ -1276,10 +1276,8 @@ static int mhi_driver_remove(struct device *dev)
                mutex_unlock(&mhi_chan->mutex);
        }
 
-       read_lock_bh(&mhi_cntrl->pm_lock);
        while (mhi_dev->dev_wake)
                mhi_device_put(mhi_dev);
-       read_unlock_bh(&mhi_cntrl->pm_lock);
 
        return 0;
 }