Commit d0a39608 authored by Steven Price's avatar Steven Price Committed by Greg Kroah-Hartman

serial: core: Don't drop port_mutex in serial_core_remove_one_port

Commit 84a9582f ("serial: core: Start managing serial controllers to
enable runtime PM") required the caller to hold port_mutex rather than
taking it locally. However the mutex_unlock() call wasn't removed
causing the mutex to be dropped unexpectly. Remove the call to
mutex_unlock() (and fix up the early return) to restore correct
behaviour.

Fixes: 84a9582f ("serial: core: Start managing serial controllers to enable runtime PM")
Signed-off-by: default avatarSteven Price <steven.price@arm.com>
Reviewed-by: default avatarTony Lindgren <tony@atomide.com>
Link: https://lore.kernel.org/r/20230601105548.29965-1-steven.price@arm.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 84a9582f
...@@ -3194,7 +3194,7 @@ static void serial_core_remove_one_port(struct uart_driver *drv, ...@@ -3194,7 +3194,7 @@ static void serial_core_remove_one_port(struct uart_driver *drv,
if (!uart_port) { if (!uart_port) {
mutex_unlock(&port->mutex); mutex_unlock(&port->mutex);
goto out; return;
} }
mutex_unlock(&port->mutex); mutex_unlock(&port->mutex);
...@@ -3234,8 +3234,6 @@ static void serial_core_remove_one_port(struct uart_driver *drv, ...@@ -3234,8 +3234,6 @@ static void serial_core_remove_one_port(struct uart_driver *drv,
wait_event(state->remove_wait, !atomic_read(&state->refcount)); wait_event(state->remove_wait, !atomic_read(&state->refcount));
state->uart_port = NULL; state->uart_port = NULL;
mutex_unlock(&port->mutex); mutex_unlock(&port->mutex);
out:
mutex_unlock(&port_mutex);
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment