diff options
author | Cosmin Cojocar <cosmin.cojocar@gmail.com> | 2010-12-05 10:15:10 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2010-12-10 18:17:19 -0500 |
commit | 1b41dbc1296269797efbb2b0837732b74de4731d (patch) | |
tree | 96281f7869f5b98f7cd9082d52d781ed86b85ebb /drivers/serial/omap-serial.c | |
parent | 5ac387d983149d4658aad17242d24eef85a43fa8 (diff) |
serial: omap-serial: Add support for kernel debugger
The kgdb invokes the poll_put_char and poll_get_char when communicating
with the host. This patch also changes the initialization order because the
kgdb will check at the very beginning, if there is a valid serial
driver.
Signed-off-by: Cosmin Cojocar <cosmin.cojocar@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/serial/omap-serial.c')
-rw-r--r-- | drivers/serial/omap-serial.c | 38 |
1 files changed, 32 insertions, 6 deletions
diff --git a/drivers/serial/omap-serial.c b/drivers/serial/omap-serial.c index 14365f72b66..54239f5a994 100644 --- a/drivers/serial/omap-serial.c +++ b/drivers/serial/omap-serial.c | |||
@@ -866,12 +866,6 @@ serial_omap_type(struct uart_port *port) | |||
866 | return up->name; | 866 | return up->name; |
867 | } | 867 | } |
868 | 868 | ||
869 | #ifdef CONFIG_SERIAL_OMAP_CONSOLE | ||
870 | |||
871 | static struct uart_omap_port *serial_omap_console_ports[4]; | ||
872 | |||
873 | static struct uart_driver serial_omap_reg; | ||
874 | |||
875 | #define BOTH_EMPTY (UART_LSR_TEMT | UART_LSR_THRE) | 869 | #define BOTH_EMPTY (UART_LSR_TEMT | UART_LSR_THRE) |
876 | 870 | ||
877 | static inline void wait_for_xmitr(struct uart_omap_port *up) | 871 | static inline void wait_for_xmitr(struct uart_omap_port *up) |
@@ -905,6 +899,34 @@ static inline void wait_for_xmitr(struct uart_omap_port *up) | |||
905 | } | 899 | } |
906 | } | 900 | } |
907 | 901 | ||
902 | #ifdef CONFIG_CONSOLE_POLL | ||
903 | |||
904 | static void serial_omap_poll_put_char(struct uart_port *port, unsigned char ch) | ||
905 | { | ||
906 | struct uart_omap_port *up = (struct uart_omap_port *)port; | ||
907 | wait_for_xmitr(up); | ||
908 | serial_out(up, UART_TX, ch); | ||
909 | } | ||
910 | |||
911 | static int serial_omap_poll_get_char(struct uart_port *port) | ||
912 | { | ||
913 | struct uart_omap_port *up = (struct uart_omap_port *)port; | ||
914 | unsigned int status = serial_in(up, UART_LSR); | ||
915 | |||
916 | if (!(status & UART_LSR_DR)) | ||
917 | return NO_POLL_CHAR; | ||
918 | |||
919 | return serial_in(up, UART_RX); | ||
920 | } | ||
921 | |||
922 | #endif /* CONFIG_CONSOLE_POLL */ | ||
923 | |||
924 | #ifdef CONFIG_SERIAL_OMAP_CONSOLE | ||
925 | |||
926 | static struct uart_omap_port *serial_omap_console_ports[4]; | ||
927 | |||
928 | static struct uart_driver serial_omap_reg; | ||
929 | |||
908 | static void serial_omap_console_putchar(struct uart_port *port, int ch) | 930 | static void serial_omap_console_putchar(struct uart_port *port, int ch) |
909 | { | 931 | { |
910 | struct uart_omap_port *up = (struct uart_omap_port *)port; | 932 | struct uart_omap_port *up = (struct uart_omap_port *)port; |
@@ -1022,6 +1044,10 @@ static struct uart_ops serial_omap_pops = { | |||
1022 | .request_port = serial_omap_request_port, | 1044 | .request_port = serial_omap_request_port, |
1023 | .config_port = serial_omap_config_port, | 1045 | .config_port = serial_omap_config_port, |
1024 | .verify_port = serial_omap_verify_port, | 1046 | .verify_port = serial_omap_verify_port, |
1047 | #ifdef CONFIG_CONSOLE_POLL | ||
1048 | .poll_put_char = serial_omap_poll_put_char, | ||
1049 | .poll_get_char = serial_omap_poll_get_char, | ||
1050 | #endif | ||
1025 | }; | 1051 | }; |
1026 | 1052 | ||
1027 | static struct uart_driver serial_omap_reg = { | 1053 | static struct uart_driver serial_omap_reg = { |