mirror of
https://github.com/torvalds/linux.git
synced 2026-05-28 17:13:52 +02:00
serial: 8250: fix return error code in serial8250_request_std_resource()
If port->mapbase = NULL in serial8250_request_std_resource() , it need return a error code instead of 0. If uart_set_info() fail to request new regions by serial8250_request_std_resource() but the return value of serial8250_request_std_resource() is 0, The system incorrectly considers that the resource application is successful and does not attempt to restore the old setting. A null pointer reference is triggered when the port resource is later invoked. Signed-off-by: Yi Yang <yiyang13@huawei.com> Cc: stable <stable@kernel.org> Link: https://lore.kernel.org/r/20220628083515.64138-1-yiyang13@huawei.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
5c5f44e362
commit
6e690d54cf
|
|
@ -2975,8 +2975,10 @@ static int serial8250_request_std_resource(struct uart_8250_port *up)
|
||||||
case UPIO_MEM32BE:
|
case UPIO_MEM32BE:
|
||||||
case UPIO_MEM16:
|
case UPIO_MEM16:
|
||||||
case UPIO_MEM:
|
case UPIO_MEM:
|
||||||
if (!port->mapbase)
|
if (!port->mapbase) {
|
||||||
|
ret = -EINVAL;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if (!request_mem_region(port->mapbase, size, "serial")) {
|
if (!request_mem_region(port->mapbase, size, "serial")) {
|
||||||
ret = -EBUSY;
|
ret = -EBUSY;
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user