diff options
Diffstat (limited to 'drivers/serial')
| -rw-r--r-- | drivers/serial/arm_dcc.c | 45 | ||||
| -rw-r--r-- | drivers/serial/ns16550.c | 5 | ||||
| -rw-r--r-- | drivers/serial/serial.c | 2 | 
3 files changed, 27 insertions, 25 deletions
| diff --git a/drivers/serial/arm_dcc.c b/drivers/serial/arm_dcc.c index c217c88e5..5dfb02f47 100644 --- a/drivers/serial/arm_dcc.c +++ b/drivers/serial/arm_dcc.c @@ -27,7 +27,7 @@   */  #include <common.h> -#include <stdio_dev.h> +#include <serial.h>  #if defined(CONFIG_CPU_V6)  /* @@ -89,12 +89,12 @@  #define TIMEOUT_COUNT 0x4000000 -int arm_dcc_init(void) +static int arm_dcc_init(void)  {  	return 0;  } -int arm_dcc_getc(void) +static int arm_dcc_getc(void)  {  	int ch;  	register unsigned int reg; @@ -107,7 +107,7 @@ int arm_dcc_getc(void)  	return ch;  } -void arm_dcc_putc(char ch) +static void arm_dcc_putc(char ch)  {  	register unsigned int reg;  	unsigned int timeout_count = TIMEOUT_COUNT; @@ -123,13 +123,7 @@ void arm_dcc_putc(char ch)  		write_dcc(ch);  } -void arm_dcc_puts(const char *s) -{ -	while (*s) -		arm_dcc_putc(*s++); -} - -int arm_dcc_tstc(void) +static int arm_dcc_tstc(void)  {  	register unsigned int reg; @@ -138,22 +132,27 @@ int arm_dcc_tstc(void)  	return reg;  } -static struct stdio_dev arm_dcc_dev; - -int drv_arm_dcc_init(void) +static void arm_dcc_setbrg(void)  { -	strcpy(arm_dcc_dev.name, "dcc"); -	arm_dcc_dev.ext = 0;	/* No extensions */ -	arm_dcc_dev.flags = DEV_FLAGS_INPUT | DEV_FLAGS_OUTPUT; -	arm_dcc_dev.tstc = arm_dcc_tstc;	/* 'tstc' function */ -	arm_dcc_dev.getc = arm_dcc_getc;	/* 'getc' function */ -	arm_dcc_dev.putc = arm_dcc_putc;	/* 'putc' function */ -	arm_dcc_dev.puts = arm_dcc_puts;	/* 'puts' function */ +} + +static struct serial_device arm_dcc_drv = { +	.name	= "arm_dcc", +	.start	= arm_dcc_init, +	.stop	= NULL, +	.setbrg	= arm_dcc_setbrg, +	.putc	= arm_dcc_putc, +	.puts	= default_serial_puts, +	.getc	= arm_dcc_getc, +	.tstc	= arm_dcc_tstc, +}; -	return stdio_register(&arm_dcc_dev); +void arm_dcc_initialize(void) +{ +	serial_register(&arm_dcc_drv);  }  __weak struct serial_device *default_serial_console(void)  { -	return NULL; +	return &arm_dcc_drv;  } diff --git a/drivers/serial/ns16550.c b/drivers/serial/ns16550.c index d77c25fa9..181c81815 100644 --- a/drivers/serial/ns16550.c +++ b/drivers/serial/ns16550.c @@ -57,7 +57,8 @@ void NS16550_init(NS16550_t com_port, int baud_divisor)  	serial_out(CONFIG_SYS_NS16550_IER, &com_port->ier);  #if (defined(CONFIG_OMAP) && !defined(CONFIG_OMAP3_ZOOM2)) || \ -			defined(CONFIG_AM33XX) || defined(CONFIG_TI814X) +			defined(CONFIG_AM33XX) || defined(CONFIG_TI81XX) || \ +			defined(CONFIG_AM43XX)  	serial_out(0x7, &com_port->mdr1);	/* mode select reset TL16C750*/  #endif  	serial_out(UART_LCR_BKSE | UART_LCRVAL, &com_port->lcr); @@ -72,7 +73,7 @@ void NS16550_init(NS16550_t com_port, int baud_divisor)  	serial_out(UART_LCRVAL, &com_port->lcr);  #if (defined(CONFIG_OMAP) && !defined(CONFIG_OMAP3_ZOOM2)) || \  	defined(CONFIG_AM33XX) || defined(CONFIG_SOC_DA8XX) || \ -	defined(CONFIG_TI814X) +	defined(CONFIG_TI81XX) || defined(CONFIG_AM43XX)  	/* /16 is proper to hit 115200 with 48MHz */  	serial_out(0, &com_port->mdr1); diff --git a/drivers/serial/serial.c b/drivers/serial/serial.c index 67301355d..118fbc305 100644 --- a/drivers/serial/serial.c +++ b/drivers/serial/serial.c @@ -159,6 +159,7 @@ serial_initfunc(pl01x_serial_initialize);  serial_initfunc(s3c44b0_serial_initialize);  serial_initfunc(sa1100_serial_initialize);  serial_initfunc(sh_serial_initialize); +serial_initfunc(arm_dcc_initialize);  /**   * serial_register() - Register serial driver with serial driver core @@ -251,6 +252,7 @@ void serial_initialize(void)  	s3c44b0_serial_initialize();  	sa1100_serial_initialize();  	sh_serial_initialize(); +	arm_dcc_initialize();  	serial_assign(default_serial_console()->name);  } |