diff options
| author | Michael Brown | 2015-07-31 12:19:19 +0200 |
|---|---|---|
| committer | Michael Brown | 2015-07-31 12:19:19 +0200 |
| commit | 2849932c4853ba36edafb5ae16c67e5976d95372 (patch) | |
| tree | 04b1e744924248d6e45c24655d756c2349d3b61c /src/arch | |
| parent | [comboot] Avoid dragging in serial console support unconditionally (diff) | |
| download | ipxe-2849932c4853ba36edafb5ae16c67e5976d95372.tar.gz ipxe-2849932c4853ba36edafb5ae16c67e5976d95372.tar.xz ipxe-2849932c4853ba36edafb5ae16c67e5976d95372.zip | |
[serial] Check for UART existence in uart_select()
Check for existence of the UART in uart_select(), not just in
uart_init(). This allows uart_select() to refuse to set a non-working
address in uart->base, which in turns means that the serial console
code will not attempt to use a non-existent UART.
Reported-by: Torgeir Wulfsberg <Torgeir.Wulfsberg@kongsberg.com>
Reported-by: Ján ONDREJ (SAL) <ondrejj@salstar.sk>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
Diffstat (limited to 'src/arch')
| -rw-r--r-- | src/arch/x86/core/x86_uart.c | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/src/arch/x86/core/x86_uart.c b/src/arch/x86/core/x86_uart.c index 7c3a01d66..e455775bf 100644 --- a/src/arch/x86/core/x86_uart.c +++ b/src/arch/x86/core/x86_uart.c @@ -48,15 +48,22 @@ static uint16_t uart_base[] = { * @ret rc Return status code */ int uart_select ( struct uart *uart, unsigned int port ) { - - /* Clear UART base */ - uart->base = NULL; + int rc; /* Set new UART base */ - if ( port < ( sizeof ( uart_base ) / sizeof ( uart_base[0] ) ) ) { - uart->base = ( ( void * ) ( intptr_t ) uart_base[port] ); - return 0; - } else { - return -ENODEV; + if ( port >= ( sizeof ( uart_base ) / sizeof ( uart_base[0] ) ) ) { + rc = -ENODEV; + goto err; } + uart->base = ( ( void * ) ( intptr_t ) uart_base[port] ); + + /* Check that UART exists */ + if ( ( rc = uart_exists ( uart ) ) != 0 ) + goto err; + + return 0; + + err: + uart->base = NULL; + return rc; } |
