1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/cpu/cc26xx_cc13xx/include/cc26xx_cc13xx_uart.h

146 lines
3.9 KiB
C
Raw Normal View History

2016-01-23 14:38:51 +01:00
/*
* Copyright (C) 2016 Leon George
*
* 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
* directory for more details.
*/
/**
* @addtogroup cpu_cc26xx_cc13xx_definitions
2016-01-23 14:38:51 +01:00
* @{
*
* @file
* @brief CC26xx/CC13xx UART interface
2016-01-23 14:38:51 +01:00
*
*/
#ifndef CC26XX_CC13XX_UART_H
#define CC26XX_CC13XX_UART_H
2016-01-23 14:38:51 +01:00
#include "cc26xx_cc13xx.h"
2016-01-23 14:38:51 +01:00
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief UART component registers
2016-01-23 14:38:51 +01:00
*/
typedef struct {
reg32_t DR; /**< Data */
2016-01-23 14:38:51 +01:00
union {
reg32_t RSR; /**< Status */
reg32_t ECR; /**< Error clear */
2016-01-23 14:38:51 +01:00
};
reg32_t __reserved1[4]; /**< Reserved */
2016-01-23 14:38:51 +01:00
reg32_t FR; /**< flag */
reg32_t __reserved2[2]; /**< Reserved */
reg32_t IBRD; /**< Integer baud-rate divisor */
reg32_t FBRD; /**< Fractional baud-rate divisor */
reg32_t LCRH; /**< Line control */
reg32_t CTL; /**< Control */
reg32_t IFLS; /**< Interrupt fifo level select */
reg32_t IMSC; /**< Interrupt mask set/clear */
reg32_t RIS; /**< Raw interrupt status */
reg32_t MIS; /**< Masked interrupt status */
reg32_t ICR; /**< Interrupt clear */
reg32_t DMACTL; /**< MMA control */
2016-01-23 14:38:51 +01:00
} uart_regs_t;
/**
* @brief UART register values
* @{
*/
#define UART_DR_DATA_mask 0xFF
#define UART_DR_FE 0x100
#define UART_DR_PE 0x200
#define UART_DR_BE 0x400
#define UART_DR_OE 0x800
#define UART_ECR_FE 0x1
#define UART_ECR_PE 0x2
#define UART_ECR_BE 0x4
#define UART_ECR_OE 0x8
#define UART_FR_CTS 0x1
#define UART_FR_BUSY 0x4
#define UART_FR_RXFE 0x10
#define UART_FR_TXFF 0x20
#define UART_FR_RXFF 0x40
#define UART_FR_TXFE 0x80
#define UART_LCRH_PEN 0x2
#define UART_LCRH_EPS 0x4
2016-01-23 14:38:51 +01:00
#define UART_LCRH_STP2 0x8
#define UART_LCRH_FEN 0x10
#define UART_LCRH_WLEN_mask 0x60
#define UART_LCRH_WLEN_5 0x0
#define UART_LCRH_WLEN_6 0x20
#define UART_LCRH_WLEN_7 0x40
#define UART_LCRH_WLEN_8 0x60
#define UART_LCRH_SPS 0x80
#define UART_CTL_UARTEN 0x1
#define UART_CTL_LBE 0x80
#define UART_CTL_TXE 0x100
#define UART_CTL_RXE 0x200
#define UART_CTL_RTS 0x800
#define UART_CTL_RTSEN 0x4000
#define UART_CTL_CTSEN 0x8000
#define UART_MIS_CTSMMIS 0x1
#define UART_MIS_RXMIS 0x10
#define UART_MIS_TXMIS 0x20
#define UART_MIS_RTMIS 0x40
#define UART_MIS_FEMIS 0x80
#define UART_MIS_PEMIS 0x100
#define UART_MIS_BEMIS 0x200
#define UART_MIS_OEMIS 0x400
#define UART_IMSC_CTSMIM 0x2
#define UART_IMSC_RXIM 0x10
#define UART_IMSC_TXIM 0x20
#define UART_IMSC_RTIM 0x40
#define UART_IMSC_FEIM 0x80
#define UART_IMSC_PEIM 0x100
#define UART_IMSC_BEIM 0x200
#define UART_IMSC_OEIM 0x400
#define UART_IFLS_TXSEL_1_8 0x0
#define UART_IFLS_TXSEL_2_8 0x1
#define UART_IFLS_TXSEL_4_8 0x2
#define UART_IFLS_TXSEL_6_8 0x3
#define UART_IFLS_TXSEL_7_8 0x4
#define UART_IFLS_RXSEL_1_8 0x0
#define UART_IFLS_RXSEL_2_8 0x8
#define UART_IFLS_RXSEL_4_8 0x10
#define UART_IFLS_RXSEL_6_8 0x18
#define UART_IFLS_RXSEL_7_8 0x20
/** @} */
/**
* @ingroup cpu_specific_peripheral_memory_map
* @{
*/
#define UART0_BASE (PERIPH_BASE + 0x1000) /**< UART0 base address */
#define UART1_BASE (PERIPH_BASE + 0xB000) /**< UART1 base address */
/** @} */
/**
* @brief UART0 register bank
*/
#define UART0 ((uart_regs_t *) (UART0_BASE))
/**
* @brief UART1 register bank
*/
#define UART1 ((uart_regs_t *) (UART1_BASE))
2016-01-23 14:38:51 +01:00
#ifdef __cplusplus
} /* end extern "C" */
#endif
#endif /* CC26XX_CC13XX_UART_H */
2016-01-23 14:38:51 +01:00
/** @} */