|
@@ -1930,7 +1930,7 @@ static void serial8250_put_poll_char(struct uart_port *port,
|
|
|
|
|
|
#endif /* CONFIG_CONSOLE_POLL */
|
|
|
|
|
|
-static int serial8250_startup(struct uart_port *port)
|
|
|
+int serial8250_do_startup(struct uart_port *port)
|
|
|
{
|
|
|
struct uart_8250_port *up = up_to_u8250p(port);
|
|
|
unsigned long flags;
|
|
@@ -2181,8 +2181,16 @@ dont_test_tx_en:
|
|
|
|
|
|
return 0;
|
|
|
}
|
|
|
+EXPORT_SYMBOL_GPL(serial8250_do_startup);
|
|
|
|
|
|
-static void serial8250_shutdown(struct uart_port *port)
|
|
|
+static int serial8250_startup(struct uart_port *port)
|
|
|
+{
|
|
|
+ if (port->startup)
|
|
|
+ return port->startup(port);
|
|
|
+ return serial8250_do_startup(port);
|
|
|
+}
|
|
|
+
|
|
|
+void serial8250_do_shutdown(struct uart_port *port)
|
|
|
{
|
|
|
struct uart_8250_port *up = up_to_u8250p(port);
|
|
|
unsigned long flags;
|
|
@@ -2232,6 +2240,15 @@ static void serial8250_shutdown(struct uart_port *port)
|
|
|
if (port->irq)
|
|
|
serial_unlink_irq_chain(up);
|
|
|
}
|
|
|
+EXPORT_SYMBOL_GPL(serial8250_do_shutdown);
|
|
|
+
|
|
|
+static void serial8250_shutdown(struct uart_port *port)
|
|
|
+{
|
|
|
+ if (port->shutdown)
|
|
|
+ port->shutdown(port);
|
|
|
+ else
|
|
|
+ serial8250_do_shutdown(port);
|
|
|
+}
|
|
|
|
|
|
static unsigned int serial8250_get_divisor(struct uart_port *port, unsigned int baud)
|
|
|
{
|
|
@@ -3466,6 +3483,10 @@ int serial8250_register_8250_port(struct uart_8250_port *up)
|
|
|
/* Possibly override set_termios call */
|
|
|
if (up->port.set_termios)
|
|
|
uart->port.set_termios = up->port.set_termios;
|
|
|
+ if (up->port.startup)
|
|
|
+ uart->port.startup = up->port.startup;
|
|
|
+ if (up->port.shutdown)
|
|
|
+ uart->port.shutdown = up->port.shutdown;
|
|
|
if (up->port.pm)
|
|
|
uart->port.pm = up->port.pm;
|
|
|
if (up->port.handle_break)
|