/* * File : interrupt.h * This file is part of RT-Thread RTOS * COPYRIGHT (C) 2006 - 2015, RT-Thread Development Team * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. * * Change Logs: * Date Author Notes * 2015-04-14 ArdaFu first version */ #ifndef __UART_H__ #define __UART_H__ #define R_VAL 0 #define R_SET 1 #define R_CLR 2 #define R_TOG 3 typedef struct { volatile rt_uint32_t CTRL0[4]; volatile rt_uint32_t CTRL1[4]; volatile rt_uint32_t CTRL2[4]; volatile rt_uint32_t LINECTRL[4]; volatile rt_uint32_t INTR[4]; volatile rt_uint32_t DATA[4]; volatile rt_uint32_t STAT[4]; volatile const rt_uint32_t DEBUG[4]; volatile rt_uint32_t ILPR[4]; volatile rt_uint32_t RS485CTRL[4]; volatile rt_uint32_t RS485ADRMATCH[4]; volatile rt_uint32_t RS485DLY[4]; volatile rt_uint32_t AUTOBAUD[4]; volatile rt_uint32_t CTRL3[4]; volatile rt_uint32_t ISO7816CTRL[4]; volatile rt_uint32_t ISO7816ERRCNT[4]; volatile rt_uint32_t ISO7816STATUS[4]; } HW_USART_TypeDef; #define USART0 ((HW_USART_TypeDef *)UART0_BASE) #define USART1 ((HW_USART_TypeDef *)UART1_BASE) #define USART2 ((HW_USART_TypeDef *)UART2_BASE) #define USART3 ((HW_USART_TypeDef *)UART3_BASE) #define USART4 ((HW_USART_TypeDef *)UART4_BASE) #define USART5 ((HW_USART_TypeDef *)UART5_BASE) #define USART6 ((HW_USART_TypeDef *)UART6_BASE) #define USART7 ((HW_USART_TypeDef *)UART7_BASE) #define USART8 ((HW_USART_TypeDef *)UART8_BASE) #define USART9 ((HW_USART_TypeDef *)UART9_BASE) #define ASM_UART_INTR_RXIS (1UL << 4) #define ASM_UART_INTR_TXIS (1UL << 5) #define ASM_UART_INTR_RTIS (1UL << 6) #define ASM_UART_INTR_RXIEN (1UL << 20) #define ASM_UART_INTR_TXIEN (1UL << 21) #define ASM_UART_INTR_RTIEN (1UL << 22) #define UART_BAUD_DIVINT_MASK 0x003FFFC0UL #define UART_BAUD_DIVFRAC_MASK 0x0000003FUL #define UART_FIFO_ENABLE 0x00000010UL #define MAIN_CLOCK_EXT12M 0 #define MAIN_CLOCK_SYSPLL 1 #define UART_INT_FIFO_LV_SEL_MASK 0x00770000UL #define RXTIMEOUT_ENABLE 0x01000000UL #define RXTIMEOUT_MASK 0x00FF0000UL #define ASM_UART_CTRL0_SFTRST (1UL << 31) #define ASM_UART_CTRL0_CLKGATE (1UL << 30) #define ASM_UART_CTRL0_RXTO_ENABLE (1UL << 24) #define ASM_UART_CTRL2_USARTEN (1UL << 0) #define ASM_UART_CTRL2_TXE (1UL << 8) #define ASM_UART_CTRL2_RXE (1UL << 9) #define ASM_UART_LINECTRL_PEN (1UL << 1) #define ASM_UART_LINECTRL_EPS (1UL << 2) #define ASM_UART_LINECTRL_STP2 (1UL << 3) #define ASM_UART_LINECTRL_FEN (1UL << 4) #define ASM_UART_LINECTRL_WLEN5 (0UL << 5) #define ASM_UART_LINECTRL_WLEN6 (1UL << 5) #define ASM_UART_LINECTRL_WLEN7 (2UL << 5) #define ASM_UART_LINECTRL_WLEN8 (3UL << 5) #define ASM_UART_LINECTRL_SPS (1UL << 7) #define ASM_UART_STAT_TXFF (1UL << 25) #define ASM_UART_STAT_RXFE (1UL << 24) extern void Hw_UartDisable(HW_USART_TypeDef* uartBase); extern void Hw_UartEnable(HW_USART_TypeDef* uartBase); extern void Hw_UartReset(HW_USART_TypeDef* uartBase); extern void Hw_UartConfig(HW_USART_TypeDef* uartBase, int baudRate, int dataBits, int stopBits, int parity); extern void Hw_UartInit(int index); #endif