1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

Merge pull request #7310 from smlng/cpu/cc2538/periph_uart

cpu, cc2538: adapt periph uart to GPIO API
This commit is contained in:
Peter Kietzmann 2017-12-14 18:14:07 +01:00 committed by GitHub
commit ec2d7c61d3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 33 additions and 101 deletions

View File

@ -76,10 +76,10 @@ static const timer_conf_t timer_config[] = {
#define UART_0_IRQ UART0_IRQn #define UART_0_IRQ UART0_IRQn
#define UART_0_ISR isr_uart0 #define UART_0_ISR isr_uart0
/* UART 0 pin configuration */ /* UART 0 pin configuration */
#define UART_0_TX_PIN GPIO_PA1 #define UART_0_TX_PIN GPIO_PIN(0, 1) /**< GPIO_PA1 */
#define UART_0_RX_PIN GPIO_PA0 #define UART_0_RX_PIN GPIO_PIN(0, 0) /**< GPIO_PA0 */
#define UART_0_RTS_PIN GPIO_PD3 #define UART_0_RTS_PIN GPIO_PIN(3, 3) /**< GPIO_PD3 */
#define UART_0_CTS_PIN GPIO_PB0 #define UART_0_CTS_PIN GPIO_PIN(1, 0) /**< GPIO_PB0 */
/* UART 1 device configuration */ /* UART 1 device configuration */
#define UART_1_DEV UART1 #define UART_1_DEV UART1

View File

@ -73,6 +73,24 @@ static const timer_conf_t timer_config[] = {
#define RADIO_IRQ_PRIO 1 #define RADIO_IRQ_PRIO 1
/** @} */ /** @} */
/**
* @name UART configuration
* @{
*/
#define UART_NUMOF (1U)
#define UART_0_EN 1
#define UART_IRQ_PRIO 1
/* UART 0 device configuration */
#define UART_0_DEV UART0
#define UART_0_IRQ UART0_IRQn
#define UART_0_ISR isr_uart0
/* UART 0 pin configuration */
#define UART_0_TX_PIN GPIO_PIN(0, 1) /**< GPIO_PA1 */
#define UART_0_RX_PIN GPIO_PIN(0, 0) /**< GPIO_PA0 */
/** @} */
#ifdef __cplusplus #ifdef __cplusplus
} /* end extern "C" */ } /* end extern "C" */
#endif #endif

View File

@ -95,8 +95,8 @@ static const adc_conf_t adc_config[] = {
#define UART_0_IRQ UART0_IRQn #define UART_0_IRQ UART0_IRQn
#define UART_0_ISR isr_uart0 #define UART_0_ISR isr_uart0
/* UART 0 pin configuration */ /* UART 0 pin configuration */
#define UART_0_TX_PIN GPIO_PA1 #define UART_0_TX_PIN GPIO_PIN(0, 1) /**< GPIO_PA1 */
#define UART_0_RX_PIN GPIO_PA0 #define UART_0_RX_PIN GPIO_PIN(0, 0) /**< GPIO_PA0 */
/** @} */ /** @} */
/** /**

View File

@ -28,23 +28,6 @@
extern "C" { extern "C" {
#endif #endif
/**
* @name UART configuration
* @{
*/
#define UART_NUMOF (1U)
#define UART_0_EN 1
#define UART_IRQ_PRIO 1
/* UART 0 device configuration */
#define UART_0_DEV UART0
#define UART_0_IRQ UART0_IRQn
#define UART_0_ISR isr_uart0
/* UART 0 pin configuration */
#define UART_0_TX_PIN GPIO_PA1
#define UART_0_RX_PIN GPIO_PA0
/** @} */
/** /**
* @name I2C configuration * @name I2C configuration
* @{ * @{

View File

@ -28,24 +28,6 @@
extern "C" { extern "C" {
#endif #endif
/**
* @name UART configuration
* @{
*/
#define UART_NUMOF (1U)
#define UART_0_EN 1
#define UART_IRQ_PRIO 1
/* UART 0 device configuration */
#define UART_0_DEV UART0
#define UART_0_IRQ UART0_IRQn
#define UART_0_ISR isr_uart0
/* UART 0 pin configuration */
#define UART_0_TX_PIN GPIO_PA1
#define UART_0_RX_PIN GPIO_PA0
/** @} */
/** /**
* @name I2C configuration * @name I2C configuration
* @{ * @{

View File

@ -31,24 +31,6 @@
extern "C" { extern "C" {
#endif #endif
/**
* @name UART configuration
* @{
*/
#define UART_NUMOF (1U)
#define UART_0_EN 1
#define UART_IRQ_PRIO 1
/* UART 0 device configuration */
#define UART_0_DEV UART0
#define UART_0_IRQ UART0_IRQn
#define UART_0_ISR isr_uart0
/* UART 0 pin configuration */
#define UART_0_TX_PIN GPIO_PA1
#define UART_0_RX_PIN GPIO_PA0
/** @} */
/** /**
* @name I2C configuration * @name I2C configuration
* @{ * @{

View File

@ -1,5 +1,6 @@
/* /*
* Copyright (C) 2014 Loci Controls Inc. * Copyright (C) 2014 Loci Controls Inc.
* 2017 HAW Hamburg
* *
* This file is subject to the terms and conditions of the GNU Lesser * This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level * General Public License v2.1. See the file LICENSE in the top level
@ -15,7 +16,7 @@
* @brief Low-level UART driver implementation * @brief Low-level UART driver implementation
* *
* @author Ian Martin <ian@locicontrols.com> * @author Ian Martin <ian@locicontrols.com>
* * @author Sebastian Meiling <s@mlng.net>
* @} * @}
*/ */
@ -192,45 +193,15 @@ static int init_base(uart_t uart, uint32_t baudrate)
#if UART_0_EN #if UART_0_EN
case UART_0: case UART_0:
u = UART_0_DEV; u = UART_0_DEV;
gpio_init_af(UART_0_RX_PIN, UART0_RXD, GPIO_IN);
/* gpio_init_af(UART_0_TX_PIN, UART0_TXD, GPIO_OUT);
* Select the UARTx RX pin by writing to the IOC_UARTRXD_UARTn register
*/
IOC_UARTRXD_UART0 = UART_0_RX_PIN;
/*
* Pad Control for the TX pin:
* - Set function to UARTn TX
* - Output Enable
*/
IOC_PXX_SEL[UART_0_TX_PIN] = UART0_TXD;
IOC_PXX_OVER[UART_0_TX_PIN] = IOC_OVERRIDE_OE;
/* Set RX and TX pins to peripheral mode */
gpio_hardware_control(UART_0_TX_PIN);
gpio_hardware_control(UART_0_RX_PIN);
break; break;
#endif #endif
#if UART_1_EN #if UART_1_EN
case UART_1: case UART_1:
u = UART_1_DEV; u = UART_1_DEV;
gpio_init_af(UART_1_RX_PIN, UART1_RXD, GPIO_IN);
/* gpio_init_af(UART_1_TX_PIN, UART1_TXD, GPIO_OUT);
* Select the UARTx RX pin by writing to the IOC_UARTRXD_UARTn register
*/
IOC_UARTRXD_UART1 = UART_1_RX_PIN;
/*
* Pad Control for the TX pin:
* - Set function to UARTn TX
* - Output Enable
*/
IOC_PXX_SEL[UART_1_TX_PIN] = UART1_TXD;
IOC_PXX_OVER[UART_1_TX_PIN] = IOC_OVERRIDE_OE;
/* Set RX and TX pins to peripheral mode */
gpio_hardware_control(UART_1_TX_PIN);
gpio_hardware_control(UART_1_RX_PIN);
break; break;
#endif #endif
@ -255,16 +226,12 @@ static int init_base(uart_t uart, uint32_t baudrate)
/* On the CC2538, hardware flow control is supported only on UART1 */ /* On the CC2538, hardware flow control is supported only on UART1 */
if (u == UART1) { if (u == UART1) {
#ifdef UART_1_RTS_PIN #ifdef UART_1_RTS_PIN
IOC_PXX_SEL[UART_1_RTS_PIN] = UART1_RTS; gpio_init_af(UART_1_RTS_PIN, UART1_RTS, GPIO_OUT);
gpio_hardware_control(UART_1_RTS_PIN);
IOC_PXX_OVER[UART_1_RTS_PIN] = IOC_OVERRIDE_OE;
u->cc2538_uart_ctl.CTLbits.RTSEN = 1; u->cc2538_uart_ctl.CTLbits.RTSEN = 1;
#endif #endif
#ifdef UART_1_CTS_PIN #ifdef UART_1_CTS_PIN
IOC_UARTCTS_UART1 = UART_1_CTS_PIN; gpio_init_af(UART_1_CTS_PIN, UART1_CTS, GPIO_IN);
gpio_hardware_control(UART_1_CTS_PIN);
IOC_PXX_OVER[UART_1_CTS_PIN] = IOC_OVERRIDE_DIS;
u->cc2538_uart_ctl.CTLbits.CTSEN = 1; u->cc2538_uart_ctl.CTLbits.CTSEN = 1;
#endif #endif
} }
@ -334,7 +301,7 @@ void uart_write(uart_t uart, const uint8_t *data, size_t len)
/* Block if the TX FIFO is full */ /* Block if the TX FIFO is full */
for (size_t i = 0; i < len; i++) { for (size_t i = 0; i < len; i++) {
while (u->cc2538_uart_fr.FRbits.TXFF); while (u->cc2538_uart_fr.FRbits.TXFF) {}
u->DR = data[i]; u->DR = data[i];
} }
} }