mirror of
https://github.com/rd-stuffs/msm-4.14.git
synced 2025-02-20 11:45:48 +08:00
PCI hotplug: fix lock imbalance in pciehp
set_lock_status omits mutex_unlock in fail path. Add the omitted unlock. As a result a lockup caused by this can be triggered from userspace by writing 1 to /sys/bus/pci/slots/.../lock often enough. Signed-off-by: Jiri Slaby <jirislaby@gmail.com> Reviewed-by: Kenji Kaneshige <kaneshige.kenji@jp.fujitsu.com> Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
This commit is contained in:
parent
aa8c6c9374
commit
c2fdd36b55
@ -126,8 +126,10 @@ static int set_lock_status(struct hotplug_slot *hotplug_slot, u8 status)
|
|||||||
mutex_lock(&slot->ctrl->crit_sect);
|
mutex_lock(&slot->ctrl->crit_sect);
|
||||||
|
|
||||||
/* has it been >1 sec since our last toggle? */
|
/* has it been >1 sec since our last toggle? */
|
||||||
if ((get_seconds() - slot->last_emi_toggle) < 1)
|
if ((get_seconds() - slot->last_emi_toggle) < 1) {
|
||||||
|
mutex_unlock(&slot->ctrl->crit_sect);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
/* see what our current state is */
|
/* see what our current state is */
|
||||||
retval = get_lock_status(hotplug_slot, &value);
|
retval = get_lock_status(hotplug_slot, &value);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user