mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
cpu/cc26xx_cc13xx: define uart_conf_t
Replaces older macro-based configuration Signed-off-by: Anton Gerasimov <tossel@gmail.com>
This commit is contained in:
parent
6790e9e6ca
commit
9fad1e3b6d
@ -75,13 +75,28 @@ static const timer_conf_t timer_config[] = {
|
|||||||
* to 1 and defining pins for UART_CTS_PIN and UART_RTS_PIN.
|
* to 1 and defining pins for UART_CTS_PIN and UART_RTS_PIN.
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define UART_NUMOF (1)
|
/**
|
||||||
#define UART0_RX_PIN (12)
|
* @name UART configuration
|
||||||
#define UART0_TX_PIN (13)
|
*
|
||||||
|
* We can enable hardware flow control, by setting flow_control
|
||||||
|
* to 1 and defining pins for cts_pin and rts_pin.
|
||||||
|
*
|
||||||
|
* Add a second UART configuration if using external pins.
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
/* Not implemented in launchpad, define if using external transceiver */
|
static const uart_conf_t uart_config[] = {
|
||||||
#define UART1_RX_PIN (0)
|
{
|
||||||
#define UART1_TX_PIN (0)
|
.regs = UART0,
|
||||||
|
.tx_pin = 13,
|
||||||
|
.rx_pin = 12,
|
||||||
|
.rts_pin = 0, /* ignored when flow_control is 0 */
|
||||||
|
.cts_pin = 0, /* ignored when flow_control is 0 */
|
||||||
|
.flow_control = 0,
|
||||||
|
.intn = UART0_IRQN
|
||||||
|
}
|
||||||
|
};
|
||||||
|
#define UART_NUMOF ARRAY_SIZE(uart_config)
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -71,13 +71,23 @@ static const timer_conf_t timer_config[] = {
|
|||||||
* The used CC26x0 CPU only supports a single UART device, so all we need to
|
* The used CC26x0 CPU only supports a single UART device, so all we need to
|
||||||
* configure are the RX and TX pins.
|
* configure are the RX and TX pins.
|
||||||
*
|
*
|
||||||
* Optionally we can enable hardware flow control, by setting UART_HW_FLOW_CTRL
|
* Optionally we can enable hardware flow control, by setting flow_control
|
||||||
* to 1 and defining pins for UART_CTS_PIN and UART_RTS_PIN.
|
* to 1 and defining pins for cts_pin and rts_pin.
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define UART_NUMOF (1)
|
|
||||||
#define UART0_RX_PIN (2)
|
static const uart_conf_t uart_config[] = {
|
||||||
#define UART0_TX_PIN (3)
|
{
|
||||||
|
.regs = UART0,
|
||||||
|
.tx_pin = 3,
|
||||||
|
.rx_pin = 2,
|
||||||
|
.rts_pin = 0, /* ignored when flow_control is 0 */
|
||||||
|
.cts_pin = 0, /* ignored when flow_control is 0 */
|
||||||
|
.flow_control = 0,
|
||||||
|
.intn = UART0_IRQN
|
||||||
|
}
|
||||||
|
};
|
||||||
|
#define UART_NUMOF ARRAY_SIZE(uart_config)
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -69,13 +69,23 @@ static const timer_conf_t timer_config[] = {
|
|||||||
* The used CC26x0 CPU only supports a single UART device, so all we need to
|
* The used CC26x0 CPU only supports a single UART device, so all we need to
|
||||||
* configure are the RX and TX pins.
|
* configure are the RX and TX pins.
|
||||||
*
|
*
|
||||||
* Optionally we can enable hardware flow control, by setting UART_HW_FLOW_CTRL
|
* Optionally we can enable hardware flow control, by setting flow_control
|
||||||
* to 1 and defining pins for UART_CTS_PIN and UART_RTS_PIN.
|
* to 1 and defining pins for cts_pin and rts_pin.
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
#define UART_NUMOF (1)
|
|
||||||
#define UART0_RX_PIN (28)
|
static const uart_conf_t uart_config[] = {
|
||||||
#define UART0_TX_PIN (29)
|
{
|
||||||
|
.regs = UART0,
|
||||||
|
.tx_pin = 29,
|
||||||
|
.rx_pin = 28,
|
||||||
|
.rts_pin = 0, /* ignored when flow_control is 0 */
|
||||||
|
.cts_pin = 0, /* ignored when flow_control is 0 */
|
||||||
|
.flow_control = 0,
|
||||||
|
.intn = UART0_IRQN
|
||||||
|
}
|
||||||
|
};
|
||||||
|
#define UART_NUMOF ARRAY_SIZE(uart_config)
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -111,6 +111,21 @@ typedef enum {
|
|||||||
} uart_stop_bits_t;
|
} uart_stop_bits_t;
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief UART device configuration
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
typedef struct {
|
||||||
|
uart_regs_t *regs;
|
||||||
|
int tx_pin;
|
||||||
|
int rx_pin;
|
||||||
|
int rts_pin;
|
||||||
|
int cts_pin;
|
||||||
|
int flow_control;
|
||||||
|
int intn;
|
||||||
|
} uart_conf_t;
|
||||||
|
/** @} */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Configuration of low-level general purpose timers
|
* @brief Configuration of low-level general purpose timers
|
||||||
*
|
*
|
||||||
|
@ -47,31 +47,15 @@ static uart_isr_ctx_t ctx[UART_NUMOF];
|
|||||||
|
|
||||||
int uart_init(uart_t uart, uint32_t baudrate, uart_rx_cb_t rx_cb, void *arg)
|
int uart_init(uart_t uart, uint32_t baudrate, uart_rx_cb_t rx_cb, void *arg)
|
||||||
{
|
{
|
||||||
/* make sure the uart device is valid */
|
assert(uart < UART_NUMOF);
|
||||||
if (uart > UART_NUMOF) {
|
|
||||||
return UART_NODEV;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined(CPU_VARIANT_X2)
|
|
||||||
uart_regs_t *uart_reg = (uart == 1) ? UART1 : UART0;
|
|
||||||
int tx_pin = (uart == 1) ? UART1_TX_PIN : UART0_TX_PIN;
|
|
||||||
int rx_pin = (uart == 1) ? UART1_RX_PIN : UART0_RX_PIN;
|
|
||||||
int irqn = (uart == 1) ? UART1_IRQN : UART0_IRQN;
|
|
||||||
# if UART_HW_FLOW_CONTROL
|
|
||||||
int rts_pin = (uart == 1) ? UART1_RTS_PIN : UART0_RTS_PIN;
|
|
||||||
int cts_pin = (uart == 1) ? UART1_CTS_PIN : UART0_CTS_PIN;
|
|
||||||
# endif // UART_HW_FLOW_CONTROL
|
|
||||||
#elif defined(CPU_VARIANT_X0)
|
|
||||||
uart_regs_t *uart_reg = UART0;
|
|
||||||
int tx_pin = UART0_TX_PIN;
|
|
||||||
int rx_pin = UART0_RX_PIN;
|
|
||||||
int irqn = UART0_IRQN;
|
|
||||||
# if UART_HW_FLOW_CONTROL
|
|
||||||
int rts_pin = UART0_RTS_PIN;
|
|
||||||
int cts_pin = UART0_CTS_PIN;
|
|
||||||
# endif // UART_HW_FLOW_CONTROL
|
|
||||||
#endif // CPU_VARIANT_X2
|
|
||||||
|
|
||||||
|
uart_regs_t *uart_reg = uart_config[uart].regs;
|
||||||
|
int tx_pin = uart_config[uart].tx_pin;
|
||||||
|
int rx_pin = uart_config[uart].rx_pin;
|
||||||
|
int intn = uart_config[uart].intn;
|
||||||
|
int flow = uart_config[uart].flow_control;
|
||||||
|
int rts_pin = uart_config[uart].rts_pin;
|
||||||
|
int cts_pin = uart_config[uart].cts_pin;
|
||||||
|
|
||||||
/* enable clocks: serial power domain and UART */
|
/* enable clocks: serial power domain and UART */
|
||||||
PRCM->PDCTL0SERIAL = 1;
|
PRCM->PDCTL0SERIAL = 1;
|
||||||
@ -88,10 +72,10 @@ int uart_init(uart_t uart, uint32_t baudrate, uart_rx_cb_t rx_cb, void *arg)
|
|||||||
/* configure pins */
|
/* configure pins */
|
||||||
IOC->CFG[tx_pin] = IOCFG_PORTID_UART0_TX;
|
IOC->CFG[tx_pin] = IOCFG_PORTID_UART0_TX;
|
||||||
IOC->CFG[rx_pin] = (IOCFG_PORTID_UART0_RX | IOCFG_INPUT_ENABLE);
|
IOC->CFG[rx_pin] = (IOCFG_PORTID_UART0_RX | IOCFG_INPUT_ENABLE);
|
||||||
#if UART_HW_FLOW_CONTROL
|
if (flow == 1) {
|
||||||
IOC->CFG[rts_pin] = IOCFG_PORTID_UART0_RTS;
|
IOC->CFG[rts_pin] = IOCFG_PORTID_UART0_RTS;
|
||||||
IOC->CFG[cts_pin] = (IOCFG_PORTID_UART0_CTS | IOCFG_INPUT_ENABLE);
|
IOC->CFG[cts_pin] = (IOCFG_PORTID_UART0_CTS | IOCFG_INPUT_ENABLE);
|
||||||
#endif
|
}
|
||||||
|
|
||||||
/* calculate baud-rate */
|
/* calculate baud-rate */
|
||||||
uint32_t tmp = (CLOCK_CORECLOCK * 4);
|
uint32_t tmp = (CLOCK_CORECLOCK * 4);
|
||||||
@ -105,7 +89,7 @@ int uart_init(uart_t uart, uint32_t baudrate, uart_rx_cb_t rx_cb, void *arg)
|
|||||||
|
|
||||||
/* enable the RX interrupt */
|
/* enable the RX interrupt */
|
||||||
uart_reg->IMSC = UART_IMSC_RXIM;
|
uart_reg->IMSC = UART_IMSC_RXIM;
|
||||||
NVIC_EnableIRQ(irqn);
|
NVIC_EnableIRQ(intn);
|
||||||
|
|
||||||
/* start the UART */
|
/* start the UART */
|
||||||
uart_reg->CTL = ENABLE_MASK;
|
uart_reg->CTL = ENABLE_MASK;
|
||||||
@ -132,14 +116,11 @@ int uart_mode(uart_t uart, uart_data_bits_t data_bits, uart_parity_t parity,
|
|||||||
assert(stop_bits == UART_STOP_BITS_1 ||
|
assert(stop_bits == UART_STOP_BITS_1 ||
|
||||||
stop_bits == UART_STOP_BITS_2);
|
stop_bits == UART_STOP_BITS_2);
|
||||||
|
|
||||||
/* make sure the uart device is valid */
|
assert(uart < UART_NUMOF);
|
||||||
if (uart >= UART_NUMOF) {
|
|
||||||
return UART_NODEV;
|
|
||||||
}
|
|
||||||
|
|
||||||
uart_regs_t *uart_reg = (uart == 1) ? UART1 : UART0;
|
uart_regs_t *uart_reg = uart_config[uart].regs;
|
||||||
|
|
||||||
/* cc26x0 does not support mark or space parity */
|
/* cc26xx/cc13xx does not support mark or space parity */
|
||||||
if (parity == UART_PARITY_MARK || parity == UART_PARITY_SPACE) {
|
if (parity == UART_PARITY_MARK || parity == UART_PARITY_SPACE) {
|
||||||
return UART_NOMODE;
|
return UART_NOMODE;
|
||||||
}
|
}
|
||||||
@ -160,7 +141,9 @@ int uart_mode(uart_t uart, uart_data_bits_t data_bits, uart_parity_t parity,
|
|||||||
|
|
||||||
void uart_write(uart_t uart, const uint8_t *data, size_t len)
|
void uart_write(uart_t uart, const uint8_t *data, size_t len)
|
||||||
{
|
{
|
||||||
uart_regs_t *uart_reg = (uart == 1) ? UART1 : UART0;
|
assert(uart < UART_NUMOF);
|
||||||
|
|
||||||
|
uart_regs_t *uart_reg = uart_config[uart].regs;
|
||||||
|
|
||||||
for (size_t i = 0; i < len; i++) {
|
for (size_t i = 0; i < len; i++) {
|
||||||
while (uart_reg->FR & UART_FR_TXFF) {}
|
while (uart_reg->FR & UART_FR_TXFF) {}
|
||||||
@ -170,7 +153,9 @@ void uart_write(uart_t uart, const uint8_t *data, size_t len)
|
|||||||
|
|
||||||
void uart_poweron(uart_t uart)
|
void uart_poweron(uart_t uart)
|
||||||
{
|
{
|
||||||
uart_regs_t *uart_reg = (uart == 1) ? UART1 : UART0;
|
assert(uart < UART_NUMOF);
|
||||||
|
|
||||||
|
uart_regs_t *uart_reg = uart_config[uart].regs;
|
||||||
|
|
||||||
PRCM->UARTCLKGR |= 0x1;
|
PRCM->UARTCLKGR |= 0x1;
|
||||||
PRCM->CLKLOADCTL = CLKLOADCTL_LOAD;
|
PRCM->CLKLOADCTL = CLKLOADCTL_LOAD;
|
||||||
@ -181,7 +166,9 @@ void uart_poweron(uart_t uart)
|
|||||||
|
|
||||||
void uart_poweroff(uart_t uart)
|
void uart_poweroff(uart_t uart)
|
||||||
{
|
{
|
||||||
uart_regs_t *uart_reg = (uart == 1) ? UART1 : UART0;
|
assert(uart < UART_NUMOF);
|
||||||
|
|
||||||
|
uart_regs_t *uart_reg = uart_config[uart].regs;
|
||||||
|
|
||||||
uart_reg->CTL = 0;
|
uart_reg->CTL = 0;
|
||||||
|
|
||||||
@ -193,7 +180,10 @@ void uart_poweroff(uart_t uart)
|
|||||||
|
|
||||||
static void isr_uart(uart_t uart)
|
static void isr_uart(uart_t uart)
|
||||||
{
|
{
|
||||||
uart_regs_t *uart_reg = (uart == 1) ? UART1 : UART0;
|
assert(uart < UART_NUMOF);
|
||||||
|
|
||||||
|
uart_regs_t *uart_reg = uart_config[uart].regs;
|
||||||
|
|
||||||
/* remember pending interrupts */
|
/* remember pending interrupts */
|
||||||
uint32_t mis = uart_reg->MIS;
|
uint32_t mis = uart_reg->MIS;
|
||||||
/* clear them */
|
/* clear them */
|
||||||
|
Loading…
Reference in New Issue
Block a user