uart.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. //*****************************************************************************
  2. //
  3. // uart.h - Defines and Macros for the UART.
  4. //
  5. // Copyright (c) 2005-2011 Texas Instruments Incorporated. All rights reserved.
  6. // Software License Agreement
  7. //
  8. // Texas Instruments (TI) is supplying this software for use solely and
  9. // exclusively on TI's microcontroller products. The software is owned by
  10. // TI and/or its suppliers, and is protected under applicable copyright
  11. // laws. You may not combine this software with "viral" open-source
  12. // software in order to form a larger program.
  13. //
  14. // THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS.
  15. // NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT
  16. // NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  17. // A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY
  18. // CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL
  19. // DAMAGES, FOR ANY REASON WHATSOEVER.
  20. //
  21. // This is part of revision 8264 of the Stellaris Peripheral Driver Library.
  22. //
  23. //*****************************************************************************
  24. #ifndef __UART_H__
  25. #define __UART_H__
  26. //*****************************************************************************
  27. //
  28. // If building with a C++ compiler, make all of the definitions in this header
  29. // have a C binding.
  30. //
  31. //*****************************************************************************
  32. #ifdef __cplusplus
  33. extern "C"
  34. {
  35. #endif
  36. //*****************************************************************************
  37. //
  38. // Values that can be passed to UARTIntEnable, UARTIntDisable, and UARTIntClear
  39. // as the ulIntFlags parameter, and returned from UARTIntStatus.
  40. //
  41. //*****************************************************************************
  42. #define UART_INT_9BIT 0x1000 // 9-bit address match interrupt
  43. #define UART_INT_OE 0x400 // Overrun Error Interrupt Mask
  44. #define UART_INT_BE 0x200 // Break Error Interrupt Mask
  45. #define UART_INT_PE 0x100 // Parity Error Interrupt Mask
  46. #define UART_INT_FE 0x080 // Framing Error Interrupt Mask
  47. #define UART_INT_RT 0x040 // Receive Timeout Interrupt Mask
  48. #define UART_INT_TX 0x020 // Transmit Interrupt Mask
  49. #define UART_INT_RX 0x010 // Receive Interrupt Mask
  50. #define UART_INT_DSR 0x008 // DSR Modem Interrupt Mask
  51. #define UART_INT_DCD 0x004 // DCD Modem Interrupt Mask
  52. #define UART_INT_CTS 0x002 // CTS Modem Interrupt Mask
  53. #define UART_INT_RI 0x001 // RI Modem Interrupt Mask
  54. //*****************************************************************************
  55. //
  56. // Values that can be passed to UARTConfigSetExpClk as the ulConfig parameter
  57. // and returned by UARTConfigGetExpClk in the pulConfig parameter.
  58. // Additionally, the UART_CONFIG_PAR_* subset can be passed to
  59. // UARTParityModeSet as the ulParity parameter, and are returned by
  60. // UARTParityModeGet.
  61. //
  62. //*****************************************************************************
  63. #define UART_CONFIG_WLEN_MASK 0x00000060 // Mask for extracting word length
  64. #define UART_CONFIG_WLEN_8 0x00000060 // 8 bit data
  65. #define UART_CONFIG_WLEN_7 0x00000040 // 7 bit data
  66. #define UART_CONFIG_WLEN_6 0x00000020 // 6 bit data
  67. #define UART_CONFIG_WLEN_5 0x00000000 // 5 bit data
  68. #define UART_CONFIG_STOP_MASK 0x00000008 // Mask for extracting stop bits
  69. #define UART_CONFIG_STOP_ONE 0x00000000 // One stop bit
  70. #define UART_CONFIG_STOP_TWO 0x00000008 // Two stop bits
  71. #define UART_CONFIG_PAR_MASK 0x00000086 // Mask for extracting parity
  72. #define UART_CONFIG_PAR_NONE 0x00000000 // No parity
  73. #define UART_CONFIG_PAR_EVEN 0x00000006 // Even parity
  74. #define UART_CONFIG_PAR_ODD 0x00000002 // Odd parity
  75. #define UART_CONFIG_PAR_ONE 0x00000082 // Parity bit is one
  76. #define UART_CONFIG_PAR_ZERO 0x00000086 // Parity bit is zero
  77. //*****************************************************************************
  78. //
  79. // Values that can be passed to UARTFIFOLevelSet as the ulTxLevel parameter and
  80. // returned by UARTFIFOLevelGet in the pulTxLevel.
  81. //
  82. //*****************************************************************************
  83. #define UART_FIFO_TX1_8 0x00000000 // Transmit interrupt at 1/8 Full
  84. #define UART_FIFO_TX2_8 0x00000001 // Transmit interrupt at 1/4 Full
  85. #define UART_FIFO_TX4_8 0x00000002 // Transmit interrupt at 1/2 Full
  86. #define UART_FIFO_TX6_8 0x00000003 // Transmit interrupt at 3/4 Full
  87. #define UART_FIFO_TX7_8 0x00000004 // Transmit interrupt at 7/8 Full
  88. //*****************************************************************************
  89. //
  90. // Values that can be passed to UARTFIFOLevelSet as the ulRxLevel parameter and
  91. // returned by UARTFIFOLevelGet in the pulRxLevel.
  92. //
  93. //*****************************************************************************
  94. #define UART_FIFO_RX1_8 0x00000000 // Receive interrupt at 1/8 Full
  95. #define UART_FIFO_RX2_8 0x00000008 // Receive interrupt at 1/4 Full
  96. #define UART_FIFO_RX4_8 0x00000010 // Receive interrupt at 1/2 Full
  97. #define UART_FIFO_RX6_8 0x00000018 // Receive interrupt at 3/4 Full
  98. #define UART_FIFO_RX7_8 0x00000020 // Receive interrupt at 7/8 Full
  99. //*****************************************************************************
  100. //
  101. // Values that can be passed to UARTDMAEnable() and UARTDMADisable().
  102. //
  103. //*****************************************************************************
  104. #define UART_DMA_ERR_RXSTOP 0x00000004 // Stop DMA receive if UART error
  105. #define UART_DMA_TX 0x00000002 // Enable DMA for transmit
  106. #define UART_DMA_RX 0x00000001 // Enable DMA for receive
  107. //*****************************************************************************
  108. //
  109. // Values returned from UARTRxErrorGet().
  110. //
  111. //*****************************************************************************
  112. #define UART_RXERROR_OVERRUN 0x00000008
  113. #define UART_RXERROR_BREAK 0x00000004
  114. #define UART_RXERROR_PARITY 0x00000002
  115. #define UART_RXERROR_FRAMING 0x00000001
  116. //*****************************************************************************
  117. //
  118. // Values that can be passed to UARTHandshakeOutputsSet() or returned from
  119. // UARTHandshakeOutputGet().
  120. //
  121. //*****************************************************************************
  122. #define UART_OUTPUT_RTS 0x00000800
  123. #define UART_OUTPUT_DTR 0x00000400
  124. //*****************************************************************************
  125. //
  126. // Values that can be returned from UARTHandshakeInputsGet().
  127. //
  128. //*****************************************************************************
  129. #define UART_INPUT_RI 0x00000100
  130. #define UART_INPUT_DCD 0x00000004
  131. #define UART_INPUT_DSR 0x00000002
  132. #define UART_INPUT_CTS 0x00000001
  133. //*****************************************************************************
  134. //
  135. // Values that can be passed to UARTFlowControl() or returned from
  136. // UARTFlowControlGet().
  137. //
  138. //*****************************************************************************
  139. #define UART_FLOWCONTROL_TX 0x00008000
  140. #define UART_FLOWCONTROL_RX 0x00004000
  141. #define UART_FLOWCONTROL_NONE 0x00000000
  142. //*****************************************************************************
  143. //
  144. // Values that can be passed to UARTTxIntModeSet() or returned from
  145. // UARTTxIntModeGet().
  146. //
  147. //*****************************************************************************
  148. #define UART_TXINT_MODE_FIFO 0x00000000
  149. #define UART_TXINT_MODE_EOT 0x00000010
  150. //*****************************************************************************
  151. //
  152. // Values that can be passed to UARTClockSourceSet() or returned from
  153. // UARTClockSourceGet().
  154. //
  155. //*****************************************************************************
  156. #define UART_CLOCK_SYSTEM 0x00000000
  157. #define UART_CLOCK_PIOSC 0x00000001
  158. //*****************************************************************************
  159. //
  160. // API Function prototypes
  161. //
  162. //*****************************************************************************
  163. extern void UARTParityModeSet(unsigned long ulBase, unsigned long ulParity);
  164. extern unsigned long UARTParityModeGet(unsigned long ulBase);
  165. extern void UARTFIFOLevelSet(unsigned long ulBase, unsigned long ulTxLevel,
  166. unsigned long ulRxLevel);
  167. extern void UARTFIFOLevelGet(unsigned long ulBase, unsigned long *pulTxLevel,
  168. unsigned long *pulRxLevel);
  169. extern void UARTConfigSetExpClk(unsigned long ulBase, unsigned long ulUARTClk,
  170. unsigned long ulBaud, unsigned long ulConfig);
  171. extern void UARTConfigGetExpClk(unsigned long ulBase, unsigned long ulUARTClk,
  172. unsigned long *pulBaud,
  173. unsigned long *pulConfig);
  174. extern void UARTEnable(unsigned long ulBase);
  175. extern void UARTDisable(unsigned long ulBase);
  176. extern void UARTFIFOEnable(unsigned long ulBase);
  177. extern void UARTFIFODisable(unsigned long ulBase);
  178. extern void UARTEnableSIR(unsigned long ulBase, tBoolean bLowPower);
  179. extern void UARTDisableSIR(unsigned long ulBase);
  180. extern tBoolean UARTCharsAvail(unsigned long ulBase);
  181. extern tBoolean UARTSpaceAvail(unsigned long ulBase);
  182. extern long UARTCharGetNonBlocking(unsigned long ulBase);
  183. extern long UARTCharGet(unsigned long ulBase);
  184. extern tBoolean UARTCharPutNonBlocking(unsigned long ulBase,
  185. unsigned char ucData);
  186. extern void UARTCharPut(unsigned long ulBase, unsigned char ucData);
  187. extern void UARTBreakCtl(unsigned long ulBase, tBoolean bBreakState);
  188. extern tBoolean UARTBusy(unsigned long ulBase);
  189. extern void UARTIntRegister(unsigned long ulBase, void(*pfnHandler)(void));
  190. extern void UARTIntUnregister(unsigned long ulBase);
  191. extern void UARTIntEnable(unsigned long ulBase, unsigned long ulIntFlags);
  192. extern void UARTIntDisable(unsigned long ulBase, unsigned long ulIntFlags);
  193. extern unsigned long UARTIntStatus(unsigned long ulBase, tBoolean bMasked);
  194. extern void UARTIntClear(unsigned long ulBase, unsigned long ulIntFlags);
  195. extern void UARTDMAEnable(unsigned long ulBase, unsigned long ulDMAFlags);
  196. extern void UARTDMADisable(unsigned long ulBase, unsigned long ulDMAFlags);
  197. extern unsigned long UARTRxErrorGet(unsigned long ulBase);
  198. extern void UARTRxErrorClear(unsigned long ulBase);
  199. extern void UARTSmartCardEnable(unsigned long ulBase);
  200. extern void UARTSmartCardDisable(unsigned long ulBase);
  201. extern void UARTModemControlSet(unsigned long ulBase,
  202. unsigned long ulControl);
  203. extern void UARTModemControlClear(unsigned long ulBase,
  204. unsigned long ulControl);
  205. extern unsigned long UARTModemControlGet(unsigned long ulBase);
  206. extern unsigned long UARTModemStatusGet(unsigned long ulBase);
  207. extern void UARTFlowControlSet(unsigned long ulBase, unsigned long ulMode);
  208. extern unsigned long UARTFlowControlGet(unsigned long ulBase);
  209. extern void UARTTxIntModeSet(unsigned long ulBase, unsigned long ulMode);
  210. extern unsigned long UARTTxIntModeGet(unsigned long ulBase);
  211. extern void UARTClockSourceSet(unsigned long ulBase, unsigned long ulSource);
  212. extern unsigned long UARTClockSourceGet(unsigned long ulBase);
  213. extern void UART9BitEnable(unsigned long ulBase);
  214. extern void UART9BitDisable(unsigned long ulBase);
  215. extern void UART9BitAddrSet(unsigned long ulBase, unsigned char ucAddr,
  216. unsigned char ucMask);
  217. extern void UART9BitAddrSend(unsigned long ulBase, unsigned char ucAddr);
  218. //*****************************************************************************
  219. //
  220. // Several UART APIs have been renamed, with the original function name being
  221. // deprecated. These defines provide backward compatibility.
  222. //
  223. //*****************************************************************************
  224. #ifndef DEPRECATED
  225. #include "driverlib/sysctl.h"
  226. #define UARTConfigSet(a, b, c) \
  227. UARTConfigSetExpClk(a, SysCtlClockGet(), b, c)
  228. #define UARTConfigGet(a, b, c) \
  229. UARTConfigGetExpClk(a, SysCtlClockGet(), b, c)
  230. #define UARTCharNonBlockingGet(a) \
  231. UARTCharGetNonBlocking(a)
  232. #define UARTCharNonBlockingPut(a, b) \
  233. UARTCharPutNonBlocking(a, b)
  234. #endif
  235. //*****************************************************************************
  236. //
  237. // Mark the end of the C bindings section for C++ compilers.
  238. //
  239. //*****************************************************************************
  240. #ifdef __cplusplus
  241. }
  242. #endif
  243. #endif // __UART_H__