TMS570: SCI serial driver is now included in the build and compiles without error

This commit is contained in:
Gregory Nutt 2015-12-24 13:37:42 -06:00
parent 90cfe8e23b
commit ea1fa2e938
5 changed files with 88 additions and 81 deletions

View File

@ -69,7 +69,7 @@
#define TMS570_REQ_N2HET_0 10 /* N2HET level 0 interrupt */ #define TMS570_REQ_N2HET_0 10 /* N2HET level 0 interrupt */
#define TMS570_REQ_HTU_0 11 /* HTU level 0 interrupt */ #define TMS570_REQ_HTU_0 11 /* HTU level 0 interrupt */
#define TMS570_REQ_MIBSPI1_0 12 /* MIBSPI1 level 0 interrupt */ #define TMS570_REQ_MIBSPI1_0 12 /* MIBSPI1 level 0 interrupt */
#define TMS570_REQ_SCI_0 13 /* SCI/LIN level 0 interrupt */ #define TMS570_REQ_SCI1_0 13 /* SCI1/LIN1 level 0 interrupt */
#define TMS570_REQ_MIBADCEV 14 /* MIBADC event group interrupt */ #define TMS570_REQ_MIBADCEV 14 /* MIBADC event group interrupt */
#define TMS570_REQ_MIBADSW1 15 /* MIBADC sw group 1 interrupt */ #define TMS570_REQ_MIBADSW1 15 /* MIBADC sw group 1 interrupt */
#define TMS570_REQ_DCAN1_0 16 /* DCAN1 level 0 interrupt */ #define TMS570_REQ_DCAN1_0 16 /* DCAN1 level 0 interrupt */
@ -81,7 +81,7 @@
#define TMS570_REQ_N2HET_1 24 /* N2HET level 1 interrupt */ #define TMS570_REQ_N2HET_1 24 /* N2HET level 1 interrupt */
#define TMS570_REQ_HTU_1 25 /* HTU level 1 interrupt */ #define TMS570_REQ_HTU_1 25 /* HTU level 1 interrupt */
#define TMS570_REQ_MIBSPI1_1 26 /* MIBSPI1 level 1 interrupt */ #define TMS570_REQ_MIBSPI1_1 26 /* MIBSPI1 level 1 interrupt */
#define TMS570_REQ_SCI_1 27 /* SCI/LIN level 1 interrupt */ #define TMS570_REQ_SCI1_1 27 /* SCI1/LIN1 level 1 interrupt */
#define TMS570_REQ_MIBADCSW2 28 /* MIBADC sw group 2 interrupt */ #define TMS570_REQ_MIBADCSW2 28 /* MIBADC sw group 2 interrupt */
#define TMS570_REQ_DCAN1_1 29 /* DCAN1 level 1 interrupt */ #define TMS570_REQ_DCAN1_1 29 /* DCAN1 level 1 interrupt */
#define TMS570_REQ_SPI2_1 30 /* SPI2 level 1 interrupt */ #define TMS570_REQ_SPI2_1 30 /* SPI2 level 1 interrupt */

View File

@ -99,7 +99,8 @@ CHIP_ASRCS =
# SAMA5-specific C source files # SAMA5-specific C source files
CHIP_CSRCS = tms570_boot.c tms570_clockconfig.c tms570_irq.c tms570_lowputc.c CHIP_CSRCS = tms570_boot.c tms570_clockconfig.c tms570_irq.c
CHIP_CSRCS += tms570_lowputc.c tms570_serial.c
# Configuration dependent C and assembly language files # Configuration dependent C and assembly language files

View File

@ -250,8 +250,10 @@
#define SCI_INT_PBE (1 << 30) /* Bit 30: Physical bus error interrupt */ #define SCI_INT_PBE (1 << 30) /* Bit 30: Physical bus error interrupt */
#define SCI_INT_BE (1 << 31) /* Bit 31: Bit error interrupt */ #define SCI_INT_BE (1 << 31) /* Bit 31: Bit error interrupt */
#define SCI_INT_ALLERRORS 0xff000000 #define SCI_INT_ALLERRORS 0xff000001
#define SCI_INT_ALL 0xff0023d3 #define SCI_INT_LINERRORS 0xff000000
#define SCI_INT_SCIERRORS 0x87000001
#define SCI_INT_ALLINTS 0xff0023d3
/* SCI Flags Register */ /* SCI Flags Register */

View File

@ -297,8 +297,8 @@ int tms570_sci_configure(uint32_t base, FAR const struct sci_config_s *config)
/* Disable all interrupts and map them all to INT0 */ /* Disable all interrupts and map them all to INT0 */
putreg32(SCI_INT_ALL, base + TMS570_SCI_CLEARINT_OFFSET); putreg32(SCI_INT_ALLINTS, base + TMS570_SCI_CLEARINT_OFFSET);
putreg32(SCI_INT_ALL, base + TMS570_SCI_CLEARINTLVL_OFFSET); putreg32(SCI_INT_ALLINTS, base + TMS570_SCI_CLEARINTLVL_OFFSET);
/* Global control 1: /* Global control 1:
* COMM=0 Idle line mode is used. * COMM=0 Idle line mode is used.

View File

@ -63,6 +63,7 @@
#include "up_internal.h" #include "up_internal.h"
#include "chip/tms570_sci.h" #include "chip/tms570_sci.h"
#include "tms570_lowputc.h"
/**************************************************************************** /****************************************************************************
* Pre-processor Definitions * Pre-processor Definitions
@ -131,20 +132,19 @@ struct tms570_dev_s
{ {
const uint32_t scibase; /* Base address of SCI registers */ const uint32_t scibase; /* Base address of SCI registers */
struct sci_config_s config; /* SCI configuration */ struct sci_config_s config; /* SCI configuration */
xcpt_t handler; /* Interrupt handler */ xcpt_t handler; /* Interrupt handler */
uint32_t sr; /* Saved status bits */ uint8_t irq; /* IRQ associated with this SCI */
uint8_t irq; /* IRQ associated with this SCI */
}; };
/**************************************************************************** /****************************************************************************
* Private Function Prototypes * Private Function Prototypes
****************************************************************************/ ****************************************************************************/
static int tms570_setup(struct sci_dev_s *dev); static int tms570_setup(struct uart_dev_s *dev);
static void tms570_shutdown(struct sci_dev_s *dev); static void tms570_shutdown(struct uart_dev_s *dev);
static int tms570_attach(struct sci_dev_s *dev); static int tms570_attach(struct uart_dev_s *dev);
static void tms570_detach(struct sci_dev_s *dev); static void tms570_detach(struct uart_dev_s *dev);
static int tms570_interrupt(struct sci_dev_s *dev); static int tms570_interrupt(struct uart_dev_s *dev);
#ifdef CONFIG_TMS570_SCI1 #ifdef CONFIG_TMS570_SCI1
static int tms570_sci1_interrupt(int irq, void *context); static int tms570_sci1_interrupt(int irq, void *context);
#endif #endif
@ -152,19 +152,19 @@ static int tms570_sci1_interrupt(int irq, void *context);
static int tms570_sci2_interrupt(int irq, void *context); static int tms570_sci2_interrupt(int irq, void *context);
#endif #endif
static int tms570_ioctl(struct file *filep, int cmd, unsigned long arg); static int tms570_ioctl(struct file *filep, int cmd, unsigned long arg);
static int tms570_receive(struct sci_dev_s *dev, uint32_t *status); static int tms570_receive(struct uart_dev_s *dev, uint32_t *status);
static void tms570_rxint(struct sci_dev_s *dev, bool enable); static void tms570_rxint(struct uart_dev_s *dev, bool enable);
static bool tms570_rxavailable(struct sci_dev_s *dev); static bool tms570_rxavailable(struct uart_dev_s *dev);
static void tms570_send(struct sci_dev_s *dev, int ch); static void tms570_send(struct uart_dev_s *dev, int ch);
static void tms570_txint(struct sci_dev_s *dev, bool enable); static void tms570_txint(struct uart_dev_s *dev, bool enable);
static bool tms570_txready(struct sci_dev_s *dev); static bool tms570_txready(struct uart_dev_s *dev);
static bool tms570_txempty(struct sci_dev_s *dev); static bool tms570_txempty(struct uart_dev_s *dev);
/**************************************************************************** /****************************************************************************
* Private Variables * Private Variables
****************************************************************************/ ****************************************************************************/
static const struct sci_ops_s g_sci_ops = static const struct uart_ops_s g_sci_ops =
{ {
.setup = tms570_setup, .setup = tms570_setup,
.shutdown = tms570_shutdown, .shutdown = tms570_shutdown,
@ -205,13 +205,13 @@ static struct tms570_dev_s g_sci1priv =
.baud = CONFIG_SCI1_BAUD, .baud = CONFIG_SCI1_BAUD,
.parity = CONFIG_SCI1_PARITY, .parity = CONFIG_SCI1_PARITY,
.bits = CONFIG_SCI1_BITS, .bits = CONFIG_SCI1_BITS,
.stopbit = CONFIG_SCI1_2STOP, .stopbits2 = CONFIG_SCI1_2STOP,
} },
.handler = tms570_sci1_interrupt, .handler = tms570_sci1_interrupt,
.irq = TMS570_IRQ_SCI1, .irq = TMS570_REQ_SCI1_0,
}; };
static sci_dev_t g_sci1port = static uart_dev_t g_sci1port =
{ {
.recv = .recv =
{ {
@ -239,13 +239,13 @@ static struct tms570_dev_s g_sci2priv =
.baud = CONFIG_SCI2_BAUD, .baud = CONFIG_SCI2_BAUD,
.parity = CONFIG_SCI2_PARITY, .parity = CONFIG_SCI2_PARITY,
.bits = CONFIG_SCI2_BITS, .bits = CONFIG_SCI2_BITS,
.stopbit = CONFIG_SCI2_2STOP, .stopbits2 = CONFIG_SCI2_2STOP,
} },
.handler = tms570_sci2_interrupt, .handler = tms570_sci2_interrupt,
.irq = TMS570_IRQ_SCI2, .irq = TMS570_REQ_SCI2_0,
}; };
static sci_dev_t g_sci2port = static uart_dev_t g_sci2port =
{ {
.recv = .recv =
{ {
@ -290,34 +290,34 @@ static inline void tms570_serialout(struct tms570_dev_s *priv, int offset,
****************************************************************************/ ****************************************************************************/
static inline void tms570_restoresciint(struct tms570_dev_s *priv, static inline void tms570_restoresciint(struct tms570_dev_s *priv,
uint32_t imr) uint32_t ints)
{ {
/* Restore the previous interrupt state (assuming all interrupts disabled) */ /* Restore the previous interrupt state (assuming all interrupts disabled) */
tms570_serialout(priv, TMS570_SCI_IER_OFFSET, imr); tms570_serialout(priv, TMS570_SCI_SETINT_OFFSET, ints);
} }
/**************************************************************************** /****************************************************************************
* Name: tms570_disableallints * Name: tms570_disableallints
****************************************************************************/ ****************************************************************************/
static void tms570_disableallints(struct tms570_dev_s *priv, uint32_t *imr) static void tms570_disableallints(struct tms570_dev_s *priv, uint32_t *ints)
{ {
irqstate_t flags; irqstate_t flags;
/* The following must be atomic */ /* The following must be atomic */
flags = irqsave(); flags = irqsave();
if (imr) if (ints)
{ {
/* Return the current interrupt mask */ /* Return the current enable bitsopop9 */
*imr = tms570_serialin(priv, TMS570_SCI_IMR_OFFSET); *ints = tms570_serialin(priv, TMS570_SCI_SETINT_OFFSET);
} }
/* Disable all interrupts */ /* Disable all interrupts */
tms570_serialout(priv, TMS570_SCI_IDR_OFFSET, SCI_INT_ALLINTS); tms570_serialout(priv, TMS570_SCI_CLEARINT_OFFSET, SCI_INT_ALLINTS);
irqrestore(flags); irqrestore(flags);
} }
@ -330,14 +330,14 @@ static void tms570_disableallints(struct tms570_dev_s *priv, uint32_t *imr)
* *
****************************************************************************/ ****************************************************************************/
static int tms570_setup(struct sci_dev_s *dev) static int tms570_setup(struct uart_dev_s *dev)
{ {
#ifndef CONFIG_SUPPRESS_SCI_CONFIG #ifndef CONFIG_SUPPRESS_SCI_CONFIG
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
/* Configure baud, number of bits, stop bits, and parity */ /* Configure baud, number of bits, stop bits, and parity */
return tms570_sci_configure(priv->base, &priv->config); return tms570_sci_configure(priv->scibase, &priv->config);
#else #else
return OK; return OK;
#endif #endif
@ -352,15 +352,13 @@ static int tms570_setup(struct sci_dev_s *dev)
* *
****************************************************************************/ ****************************************************************************/
static void tms570_shutdown(struct sci_dev_s *dev) static void tms570_shutdown(struct uart_dev_s *dev)
{ {
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
/* Reset and disable receiver and transmitter */ /* Reset and disable receiver and transmitter */
tms570_serialout(priv, TMS570_SCI_CR_OFFSET, tms570_serialout(priv, TMS570_SCI_GCR1_OFFSET, 0);
(SCI_CR_RSTRX | SCI_CR_RSTTX | SCI_CR_RXDIS |
SCI_CR_TXDIS));
/* Disable all interrupts */ /* Disable all interrupts */
@ -382,7 +380,7 @@ static void tms570_shutdown(struct sci_dev_s *dev)
* *
****************************************************************************/ ****************************************************************************/
static int tms570_attach(struct sci_dev_s *dev) static int tms570_attach(struct uart_dev_s *dev)
{ {
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
int ret; int ret;
@ -412,7 +410,7 @@ static int tms570_attach(struct sci_dev_s *dev)
* *
****************************************************************************/ ****************************************************************************/
static void tms570_detach(struct sci_dev_s *dev) static void tms570_detach(struct uart_dev_s *dev)
{ {
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
up_disable_irq(priv->irq); up_disable_irq(priv->irq);
@ -430,7 +428,7 @@ static void tms570_detach(struct sci_dev_s *dev)
* *
****************************************************************************/ ****************************************************************************/
static int tms570_interrupt(struct sci_dev_s *dev) static int tms570_interrupt(struct uart_dev_s *dev)
{ {
struct tms570_dev_s *priv; struct tms570_dev_s *priv;
uint32_t intvec; uint32_t intvec;
@ -453,7 +451,7 @@ static int tms570_interrupt(struct sci_dev_s *dev)
switch (intvec) switch (intvec)
{ {
case SCI_INTVECT_NONE: /* No interrupt */ case SCI_INTVECT_NONE: /* No interrupt */
return; return OK;
case SCI_INTVECT_WAKEUP: /* Wake-up interrupt */ case SCI_INTVECT_WAKEUP: /* Wake-up interrupt */
/* SCI sets the WAKEUP flag if bus activity on the RX line /* SCI sets the WAKEUP flag if bus activity on the RX line
@ -461,19 +459,24 @@ static int tms570_interrupt(struct sci_dev_s *dev)
* line activity causes an exit from power-down mode. If * line activity causes an exit from power-down mode. If
* enabled wakeup interrupt is triggered once WAKEUP flag is * enabled wakeup interrupt is triggered once WAKEUP flag is
* set. * set.
*
* REVISIT: This interrupt is ignored because for now the
* break detect interrupt is never enabled.
*/ */
#warning Missing Logic
break; break;
/* SCI Errors */ /* SCI Errors
*
* REVISIT: These error interrupta are ignored because for now the
* break detect interrupt is never enabled.
*/
case SCI_INTVECT_PE: /* Parity error interrupt */ case SCI_INTVECT_PE: /* Parity error interrupt */
case SCI_INTVECT_FE: /* Framing error interrupt */ case SCI_INTVECT_FE: /* Framing error interrupt */
case SCI_INTVECT_BRKDT: /* Break detect interrupt */
case SCI_INTVECT_OE: /* Overrun error interrupt */ case SCI_INTVECT_OE: /* Overrun error interrupt */
case SCI_INTVECT_BRKDT: /* Break detect interrupt */
case SCI_INTVECT_BE: /* Bit error interrupt */ case SCI_INTVECT_BE: /* Bit error interrupt */
#warning Missing Logic
break; break;
case SCI_INTVECT_RX: /* Receive interrupt */ case SCI_INTVECT_RX: /* Receive interrupt */
@ -544,7 +547,7 @@ static int tms570_ioctl(struct file *filep, int cmd, unsigned long arg)
{ {
#if defined(CONFIG_SERIAL_TERMIOS) || defined(CONFIG_SERIAL_TIOCSERGSTRUCT) #if defined(CONFIG_SERIAL_TERMIOS) || defined(CONFIG_SERIAL_TIOCSERGSTRUCT)
struct inode *inode = filep->f_inode; struct inode *inode = filep->f_inode;
struct sci_dev_s *dev = inode->i_private; struct uart_dev_s *dev = inode->i_private;
#endif #endif
int ret = OK; int ret = OK;
@ -624,7 +627,7 @@ static int tms570_ioctl(struct file *filep, int cmd, unsigned long arg)
struct termios *termiosp = (struct termios *)arg; struct termios *termiosp = (struct termios *)arg;
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
uint32_t baud; uint32_t baud;
uint32_t imr; uint32_t ints;
uint8_t parity; uint8_t parity;
uint8_t nbits; uint8_t nbits;
bool stop2; bool stop2;
@ -699,12 +702,12 @@ static int tms570_ioctl(struct file *filep, int cmd, unsigned long arg)
* implement TCSADRAIN / TCSAFLUSH * implement TCSADRAIN / TCSAFLUSH
*/ */
tms570_disableallints(priv, &imr); tms570_disableallints(priv, &ints);
ret = tms570_sci_configure(priv->scibase, &priv->config); ret = tms570_sci_configure(priv->scibase, &priv->config);
/* Restore the interrupt state */ /* Restore the interrupt state */
tms570_restoresciint(priv, imr); tms570_restoresciint(priv, ints);
} }
} }
break; break;
@ -728,18 +731,20 @@ static int tms570_ioctl(struct file *filep, int cmd, unsigned long arg)
* *
****************************************************************************/ ****************************************************************************/
static int tms570_receive(struct sci_dev_s *dev, uint32_t *status) static int tms570_receive(struct uart_dev_s *dev, uint32_t *status)
{ {
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
/* Return the error information in the saved status */ /* Return the error information in the saved status.
*
* REVISIT: RX error information is not currently retained.
*/
*status = priv->sr; *status = 0;
priv->sr = 0;
/* Then return the actual received byte */ /* Then return the actual received byte */
return (int)(tms570_serialin(priv, TMS570_SCI_RHR_OFFSET) & 0xff); return (int)(tms570_serialin(priv, TMS570_SCI_RD_OFFSET) & 0xff);
} }
/**************************************************************************** /****************************************************************************
@ -750,7 +755,7 @@ static int tms570_receive(struct sci_dev_s *dev, uint32_t *status)
* *
****************************************************************************/ ****************************************************************************/
static void tms570_rxint(struct sci_dev_s *dev, bool enable) static void tms570_rxint(struct uart_dev_s *dev, bool enable)
{ {
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
@ -761,12 +766,12 @@ static void tms570_rxint(struct sci_dev_s *dev, bool enable)
*/ */
#ifndef CONFIG_SUPPRESS_SERIAL_INTS #ifndef CONFIG_SUPPRESS_SERIAL_INTS
tms570_serialout(priv, TMS570_SCI_IER_OFFSET, SCI_INT_RXRDY); tms570_serialout(priv, TMS570_SCI_SETINT_OFFSET, SCI_INT_RX);
#endif #endif
} }
else else
{ {
tms570_serialout(priv, TMS570_SCI_IDR_OFFSET, SCI_INT_RXRDY); tms570_serialout(priv, TMS570_SCI_CLEARINT_OFFSET, SCI_INT_RX);
} }
} }
@ -778,10 +783,10 @@ static void tms570_rxint(struct sci_dev_s *dev, bool enable)
* *
****************************************************************************/ ****************************************************************************/
static bool tms570_rxavailable(struct sci_dev_s *dev) static bool tms570_rxavailable(struct uart_dev_s *dev)
{ {
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
return ((tms570_serialin(priv, TMS570_SCI_SR_OFFSET) & SCI_INT_RXRDY) != 0); return ((tms570_serialin(priv, TMS570_SCI_FLR_OFFSET) & SCI_FLR_RXRDY) != 0);
} }
/**************************************************************************** /****************************************************************************
@ -792,10 +797,10 @@ static bool tms570_rxavailable(struct sci_dev_s *dev)
*- *-
****************************************************************************/ ****************************************************************************/
static void tms570_send(struct sci_dev_s *dev, int ch) static void tms570_send(struct uart_dev_s *dev, int ch)
{ {
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
tms570_serialout(priv, TMS570_SCI_THR_OFFSET, (uint32_t)ch); tms570_serialout(priv, TMS570_SCI_TD_OFFSET, (uint32_t)ch);
} }
/**************************************************************************** /****************************************************************************
@ -806,7 +811,7 @@ static void tms570_send(struct sci_dev_s *dev, int ch)
* *
****************************************************************************/ ****************************************************************************/
static void tms570_txint(struct sci_dev_s *dev, bool enable) static void tms570_txint(struct uart_dev_s *dev, bool enable)
{ {
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
irqstate_t flags; irqstate_t flags;
@ -819,21 +824,20 @@ static void tms570_txint(struct sci_dev_s *dev, bool enable)
*/ */
#ifndef CONFIG_SUPPRESS_SERIAL_INTS #ifndef CONFIG_SUPPRESS_SERIAL_INTS
tms570_serialout(priv, TMS570_SCI_IER_OFFSET, SCI_INT_TXRDY); tms570_serialout(priv, TMS570_SCI_SETINT_OFFSET, SCI_INT_TX);
/* Fake a TX interrupt here by just calling sci_xmitchars() with /* Fake a TX interrupt here by just calling uart_xmitchars() with
* interrupts disabled (note this may recurse). * interrupts disabled (note this may recurse).
*/ */
sci_xmitchars(dev); uart_xmitchars(dev);
#endif #endif
} }
else else
{ {
/* Disable the TX interrupt */ /* Disable the TX interrupt */
tms570_serialout(priv, TMS570_SCI_IDR_OFFSET, SCI_INT_TXRDY); tms570_serialout(priv, TMS570_SCI_CLEARINT_OFFSET, SCI_INT_TX);
} }
irqrestore(flags); irqrestore(flags);
@ -847,10 +851,10 @@ static void tms570_txint(struct sci_dev_s *dev, bool enable)
* *
****************************************************************************/ ****************************************************************************/
static bool tms570_txready(struct sci_dev_s *dev) static bool tms570_txready(struct uart_dev_s *dev)
{ {
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
return ((tms570_serialin(priv, TMS570_SCI_SR_OFFSET) & SCI_INT_TXRDY) != 0); return ((tms570_serialin(priv, TMS570_SCI_FLR_OFFSET) & SCI_FLR_TXRDY) != 0);
} }
/**************************************************************************** /****************************************************************************
@ -861,10 +865,10 @@ static bool tms570_txready(struct sci_dev_s *dev)
* *
****************************************************************************/ ****************************************************************************/
static bool tms570_txempty(struct sci_dev_s *dev) static bool tms570_txempty(struct uart_dev_s *dev)
{ {
struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv; struct tms570_dev_s *priv = (struct tms570_dev_s *)dev->priv;
return ((tms570_serialin(priv, TMS570_SCI_SR_OFFSET) & SCI_INT_TXEMPTY) != 0); return ((tms570_serialin(priv, TMS570_SCI_FLR_OFFSET) & SCI_FLR_TXEMPTY) != 0);
} }
/**************************************************************************** /****************************************************************************
@ -896,14 +900,14 @@ void up_serialinit(void)
/* Register the console */ /* Register the console */
(void)sci_register("/dev/console", &CONSOLE_DEV); (void)uart_register("/dev/console", &CONSOLE_DEV);
#endif #endif
/* Register all SCIs */ /* Register all SCIs */
(void)sci_register("/dev/ttyS0", &TTYS0_DEV); (void)uart_register("/dev/ttyS0", &TTYS0_DEV);
#ifdef TTYS1_DEV #ifdef TTYS1_DEV
(void)sci_register("/dev/ttyS1", &TTYS1_DEV); (void)uart_register("/dev/ttyS1", &TTYS1_DEV);
#endif #endif
} }