msp430x13x.h
上传用户:xhjmsc
上传日期:2019-09-13
资源大小:389k
文件大小:42k
源码类别:

传真(Fax)编程

开发平台:

C/C++

  1. /********************************************************************
  2. *
  3. * Standard register and bit definitions for the Texas Instruments
  4. * MSP430 microcontroller.
  5. *
  6. * This file supports assembler and C/EC++ development for
  7. * MSP430x13x devices.
  8. *
  9. * Version 2.0
  10. *
  11. ********************************************************************/
  12. #ifndef __msp430x13x
  13. #define __msp430x13x
  14. #if (((__TID__ >> 8) & 0x7F) != 0x2b)     /* 0x2b = 43 dec */
  15. #error MSP430X13X.H file for use with ICC430/A430 only
  16. #endif
  17. #ifdef __IAR_SYSTEMS_ICC__
  18. #include <in430.h>
  19. #pragma language=extended
  20. #define DEFC(name, address) __no_init volatile unsigned char name @ address;
  21. #define DEFW(name, address) __no_init volatile unsigned short name @ address;
  22. #endif  /* __IAR_SYSTEMS_ICC__  */
  23. #ifdef __IAR_SYSTEMS_ASM__
  24. #define DEFC(name, address) sfrb name = address;
  25. #define DEFW(name, address) sfrw name = address;
  26. #endif /* __IAR_SYSTEMS_ASM__*/
  27. #ifdef __cplusplus
  28. #define READ_ONLY
  29. #else
  30. #define READ_ONLY const
  31. #endif
  32. /************************************************************
  33. * STANDARD BITS
  34. ************************************************************/
  35. #define BIT0                (0x0001)
  36. #define BIT1                (0x0002)
  37. #define BIT2                (0x0004)
  38. #define BIT3                (0x0008)
  39. #define BIT4                (0x0010)
  40. #define BIT5                (0x0020)
  41. #define BIT6                (0x0040)
  42. #define BIT7                (0x0080)
  43. #define BIT8                (0x0100)
  44. #define BIT9                (0x0200)
  45. #define BITA                (0x0400)
  46. #define BITB                (0x0800)
  47. #define BITC                (0x1000)
  48. #define BITD                (0x2000)
  49. #define BITE                (0x4000)
  50. #define BITF                (0x8000)
  51. /************************************************************
  52. * STATUS REGISTER BITS
  53. ************************************************************/
  54. #define C                   (0x0001)
  55. #define Z                   (0x0002)
  56. #define N                   (0x0004)
  57. #define V                   (0x0100)
  58. #define GIE                 (0x0008)
  59. #define CPUOFF              (0x0010)
  60. #define OSCOFF              (0x0020)
  61. #define SCG0                (0x0040)
  62. #define SCG1                (0x0080)
  63. /* Low Power Modes coded with Bits 4-7 in SR */
  64. #ifndef __IAR_SYSTEMS_ICC /* Begin #defines for assembler */
  65. #define LPM0                (CPUOFF)
  66. #define LPM1                (SCG0+CPUOFF)
  67. #define LPM2                (SCG1+CPUOFF)
  68. #define LPM3                (SCG1+SCG0+CPUOFF)
  69. #define LPM4                (SCG1+SCG0+OSCOFF+CPUOFF)
  70. /* End #defines for assembler */
  71. #else /* Begin #defines for C */
  72. #define LPM0_bits           (CPUOFF)
  73. #define LPM1_bits           (SCG0+CPUOFF)
  74. #define LPM2_bits           (SCG1+CPUOFF)
  75. #define LPM3_bits           (SCG1+SCG0+CPUOFF)
  76. #define LPM4_bits           (SCG1+SCG0+OSCOFF+CPUOFF)
  77. #define LPM0      _BIS_SR(LPM0_bits)     /* Enter Low Power Mode 0 */
  78. #define LPM0_EXIT _BIC_SR_IRQ(LPM0_bits) /* Exit Low Power Mode 0 */
  79. #define LPM1      _BIS_SR(LPM1_bits)     /* Enter Low Power Mode 1 */
  80. #define LPM1_EXIT _BIC_SR_IRQ(LPM1_bits) /* Exit Low Power Mode 1 */
  81. #define LPM2      _BIS_SR(LPM2_bits)     /* Enter Low Power Mode 2 */
  82. #define LPM2_EXIT _BIC_SR_IRQ(LPM2_bits) /* Exit Low Power Mode 2 */
  83. #define LPM3      _BIS_SR(LPM3_bits)     /* Enter Low Power Mode 3 */
  84. #define LPM3_EXIT _BIC_SR_IRQ(LPM3_bits) /* Exit Low Power Mode 3 */
  85. #define LPM4      _BIS_SR(LPM4_bits)     /* Enter Low Power Mode 4 */
  86. #define LPM4_EXIT _BIC_SR_IRQ(LPM4_bits) /* Exit Low Power Mode 4 */
  87. #endif /* End #defines for C */
  88. /************************************************************
  89. * PERIPHERAL FILE MAP
  90. ************************************************************/
  91. /************************************************************
  92. * SPECIAL FUNCTION REGISTER ADDRESSES + CONTROL BITS
  93. ************************************************************/
  94. #define IE1_                (0x0000)  /* Interrupt Enable 1 */
  95. DEFC(IE1                  , IE1_)
  96. #define U0IE_               (IE1_)    /* UART0 Interrupt Enable Register */
  97. DEFC(   U0IE              , U0IE_)
  98. #define WDTIE               (0x01)
  99. #define OFIE                (0x02)
  100. #define NMIIE               (0x10)
  101. #define ACCVIE              (0x20)
  102. #define URXIE0              (0x40)
  103. #define UTXIE0              (0x80)
  104. #define IFG1_               (0x0002)  /* Interrupt Flag 1 */
  105. DEFC(IFG1                 , IFG1_)
  106. #define U0IFG_              (IFG1_)   /* UART0 Interrupt Flag Register */
  107. DEFC(   U0IFG             , U0IFG_)
  108. #define WDTIFG              (0x01)
  109. #define OFIFG               (0x02)
  110. #define NMIIFG              (0x10)
  111. #define URXIFG0             (0x40)
  112. #define UTXIFG0             (0x80)
  113. #define ME1_                (0x0004)  /* Module Enable 1 */
  114. DEFC(    ME1              , ME1_)
  115. #define U0ME_               (ME1_)    /* UART0 Module Enable Register */
  116. DEFC(   U0ME              , U0ME_)
  117. #define URXE0               (0x40)
  118. #define USPIE0              (0x40)
  119. #define UTXE0               (0x80)
  120. /************************************************************
  121. * WATCHDOG TIMER
  122. ************************************************************/
  123. #define WDTCTL_             (0x0120)  /* Watchdog Timer Control */
  124. DEFW(    WDTCTL            , WDTCTL_)
  125. /* The bit names have been prefixed with "WDT" */
  126. #define WDTIS0              (0x0001)
  127. #define WDTIS1              (0x0002)
  128. #define WDTSSEL             (0x0004)
  129. #define WDTCNTCL            (0x0008)
  130. #define WDTTMSEL            (0x0010)
  131. #define WDTNMI              (0x0020)
  132. #define WDTNMIES            (0x0040)
  133. #define WDTHOLD             (0x0080)
  134. #define WDTPW               (0x5A00)
  135. /* WDT-interval times [1ms] coded with Bits 0-2 */
  136. /* WDT is clocked by fMCLK (assumed 1MHz) */
  137. #define WDT_MDLY_32         (WDTPW+WDTTMSEL+WDTCNTCL)                         /* 32ms interval (default) */
  138. #define WDT_MDLY_8          (WDTPW+WDTTMSEL+WDTCNTCL+WDTIS0)                  /* 8ms     " */
  139. #define WDT_MDLY_0_5        (WDTPW+WDTTMSEL+WDTCNTCL+WDTIS1)                  /* 0.5ms   " */
  140. #define WDT_MDLY_0_064      (WDTPW+WDTTMSEL+WDTCNTCL+WDTIS1+WDTIS0)           /* 0.064ms " */
  141. /* WDT is clocked by fACLK (assumed 32KHz) */
  142. #define WDT_ADLY_1000       (WDTPW+WDTTMSEL+WDTCNTCL+WDTSSEL)                 /* 1000ms  " */
  143. #define WDT_ADLY_250        (WDTPW+WDTTMSEL+WDTCNTCL+WDTSSEL+WDTIS0)          /* 250ms   " */
  144. #define WDT_ADLY_16         (WDTPW+WDTTMSEL+WDTCNTCL+WDTSSEL+WDTIS1)          /* 16ms    " */
  145. #define WDT_ADLY_1_9        (WDTPW+WDTTMSEL+WDTCNTCL+WDTSSEL+WDTIS1+WDTIS0)   /* 1.9ms   " */
  146. /* Watchdog mode -> reset after expired time */
  147. /* WDT is clocked by fMCLK (assumed 1MHz) */
  148. #define WDT_MRST_32         (WDTPW+WDTCNTCL)                                  /* 32ms interval (default) */
  149. #define WDT_MRST_8          (WDTPW+WDTCNTCL+WDTIS0)                           /* 8ms     " */
  150. #define WDT_MRST_0_5        (WDTPW+WDTCNTCL+WDTIS1)                           /* 0.5ms   " */
  151. #define WDT_MRST_0_064      (WDTPW+WDTCNTCL+WDTIS1+WDTIS0)                    /* 0.064ms " */
  152. /* WDT is clocked by fACLK (assumed 32KHz) */
  153. #define WDT_ARST_1000       (WDTPW+WDTCNTCL+WDTSSEL)                          /* 1000ms  " */
  154. #define WDT_ARST_250        (WDTPW+WDTCNTCL+WDTSSEL+WDTIS0)                   /* 250ms   " */
  155. #define WDT_ARST_16         (WDTPW+WDTCNTCL+WDTSSEL+WDTIS1)                   /* 16ms    " */
  156. #define WDT_ARST_1_9        (WDTPW+WDTCNTCL+WDTSSEL+WDTIS1+WDTIS0)            /* 1.9ms   " */
  157. /* INTERRUPT CONTROL */
  158. /* These two bits are defined in the Special Function Registers */
  159. /* #define WDTIE               0x01 */
  160. /* #define WDTIFG              0x01 */
  161. /************************************************************
  162. * DIGITAL I/O Port1/2
  163. ************************************************************/
  164. #define P1IN_               (0x0020)  /* Port 1 Input */
  165. READ_ONLY DEFC( P1IN           , P1IN_)
  166. #define P1OUT_              (0x0021)  /* Port 1 Output */
  167. DEFC(    P1OUT             , P1OUT_)
  168. #define P1DIR_              (0x0022)  /* Port 1 Direction */
  169. DEFC(    P1DIR             , P1DIR_)
  170. #define P1IFG_              (0x0023)  /* Port 1 Interrupt Flag */
  171. DEFC(    P1IFG             , P1IFG_)
  172. #define P1IES_              (0x0024)  /* Port 1 Interrupt Edge Select */
  173. DEFC(    P1IES             , P1IES_)
  174. #define P1IE_               (0x0025)  /* Port 1 Interrupt Enable */
  175. DEFC(    P1IE              , P1IE_)
  176. #define P1SEL_              (0x0026)  /* Port 1 Selection */
  177. DEFC(    P1SEL             , P1SEL_)
  178. #define P2IN_               (0x0028)  /* Port 2 Input */
  179. READ_ONLY DEFC( P2IN           , P2IN_)
  180. #define P2OUT_              (0x0029)  /* Port 2 Output */
  181. DEFC(    P2OUT             , P2OUT_)
  182. #define P2DIR_              (0x002A)  /* Port 2 Direction */
  183. DEFC(    P2DIR             , P2DIR_)
  184. #define P2IFG_              (0x002B)  /* Port 2 Interrupt Flag */
  185. DEFC(    P2IFG             , P2IFG_)
  186. #define P2IES_              (0x002C)  /* Port 2 Interrupt Edge Select */
  187. DEFC(    P2IES             , P2IES_)
  188. #define P2IE_               (0x002D)  /* Port 2 Interrupt Enable */
  189. DEFC(    P2IE              , P2IE_)
  190. #define P2SEL_              (0x002E)  /* Port 2 Selection */
  191. DEFC(    P2SEL             , P2SEL_)
  192. /************************************************************
  193. * DIGITAL I/O Port3/4
  194. ************************************************************/
  195. #define P3IN_               (0x0018)  /* Port 3 Input */
  196. READ_ONLY DEFC( P3IN           , P3IN_)
  197. #define P3OUT_              (0x0019)  /* Port 3 Output */
  198. DEFC(    P3OUT             , P3OUT_)
  199. #define P3DIR_              (0x001A)  /* Port 3 Direction */
  200. DEFC(    P3DIR             , P3DIR_)
  201. #define P3SEL_              (0x001B)  /* Port 3 Selection */
  202. DEFC(    P3SEL             , P3SEL_)
  203. #define P4IN_               (0x001C)  /* Port 4 Input */
  204. READ_ONLY DEFC( P4IN           , P4IN_)
  205. #define P4OUT_              (0x001D)  /* Port 4 Output */
  206. DEFC(    P4OUT             , P4OUT_)
  207. #define P4DIR_              (0x001E)  /* Port 4 Direction */
  208. DEFC(    P4DIR             , P4DIR_)
  209. #define P4SEL_              (0x001F)  /* Port 4 Selection */
  210. DEFC(    P4SEL             , P4SEL_)
  211. /************************************************************
  212. * DIGITAL I/O Port5/6
  213. ************************************************************/
  214. #define P5IN_               (0x0030)  /* Port 5 Input */
  215. READ_ONLY DEFC( P5IN           , P5IN_)
  216. #define P5OUT_              (0x0031)  /* Port 5 Output */
  217. DEFC(    P5OUT             , P5OUT_)
  218. #define P5DIR_              (0x0032)  /* Port 5 Direction */
  219. DEFC(    P5DIR             , P5DIR_)
  220. #define P5SEL_              (0x0033)  /* Port 5 Selection */
  221. DEFC(    P5SEL             , P5SEL_)
  222. #define P6IN_               (0x0034)  /* Port 6 Input */
  223. READ_ONLY DEFC( P6IN           , P6IN_)
  224. #define P6OUT_              (0x0035)  /* Port 6 Output */
  225. DEFC(    P6OUT             , P6OUT_)
  226. #define P6DIR_              (0x0036)  /* Port 6 Direction */
  227. DEFC(    P6DIR             , P6DIR_)
  228. #define P6SEL_              (0x0037)  /* Port 6 Selection */
  229. DEFC(    P6SEL             , P6SEL_)
  230. /************************************************************
  231. * USART
  232. ************************************************************/
  233. #define PENA                (0x80)        /* UCTL */
  234. #define PEV                 (0x40)
  235. #define SPB                 (0x20)        /* to distinguish from stackpointer SP */
  236. #define CHAR                (0x10)
  237. #define LISTEN              (0x08)
  238. #define SYNC                (0x04)
  239. #define MM                  (0x02)
  240. #define SWRST               (0x01)
  241. #define CKPH                (0x80)        /* UTCTL */
  242. #define CKPL                (0x40)
  243. #define SSEL1               (0x20)
  244. #define SSEL0               (0x10)
  245. #define URXSE               (0x08)
  246. #define TXWAKE              (0x04)
  247. #define STC                 (0x02)
  248. #define TXEPT               (0x01)
  249. #define FE                  (0x80)        /* URCTL */
  250. #define PE                  (0x40)
  251. #define OE                  (0x20)
  252. #define BRK                 (0x10)
  253. #define URXEIE              (0x08)
  254. #define URXWIE              (0x04)
  255. #define RXWAKE              (0x02)
  256. #define RXERR               (0x01)
  257. /************************************************************
  258. * USART 0
  259. ************************************************************/
  260. #define U0CTL_              (0x0070)  /* USART 0 Control */
  261. DEFC(    U0CTL             , U0CTL_)
  262. #define U0TCTL_             (0x0071)  /* USART 0 Transmit Control */
  263. DEFC(    U0TCTL            , U0TCTL_)
  264. #define U0RCTL_             (0x0072)  /* USART 0 Receive Control */
  265. DEFC(    U0RCTL            , U0RCTL_)
  266. #define U0MCTL_             (0x0073)  /* USART 0 Modulation Control */
  267. DEFC(    U0MCTL            , U0MCTL_)
  268. #define U0BR0_              (0x0074)  /* USART 0 Baud Rate 0 */
  269. DEFC(    U0BR0             , U0BR0_)
  270. #define U0BR1_              (0x0075)  /* USART 0 Baud Rate 1 */
  271. DEFC(    U0BR1             , U0BR1_)
  272. #define U0RXBUF_            (0x0076)  /* USART 0 Receive Buffer */
  273. READ_ONLY DEFC( U0RXBUF        , U0RXBUF_)
  274. #define U0TXBUF_            (0x0077)  /* USART 0 Transmit Buffer */
  275. DEFC(    U0TXBUF           , U0TXBUF_)
  276. /* Alternate register names */
  277. #define UCTL0_              U0CTL_    /* USART 0 Control */
  278. DEFC(    UCTL0             , UCTL0_)
  279. #define UTCTL0_             U0TCTL_   /* USART 0 Transmit Control */
  280. DEFC(    UTCTL0            , UTCTL0_)
  281. #define URCTL0_             U0RCTL_   /* USART 0 Receive Control */
  282. DEFC(    URCTL0            , URCTL0_)
  283. #define UMCTL0_             U0MCTL_   /* USART 0 Modulation Control */
  284. DEFC(    UMCTL0            , UMCTL0_)
  285. #define UBR00_              U0BR0_    /* USART 0 Baud Rate 0 */
  286. DEFC(    UBR00             , UBR00_)
  287. #define UBR10_              U0BR1_    /* USART 0 Baud Rate 1 */
  288. DEFC(    UBR10             , UBR10_)
  289. #define RXBUF0_             U0RXBUF_  /* USART 0 Receive Buffer */
  290. READ_ONLY DEFC( RXBUF0         , RXBUF0_)
  291. #define TXBUF0_             U0TXBUF_  /* USART 0 Transmit Buffer */
  292. DEFC(    TXBUF0            , TXBUF0_)
  293. #define UCTL_0_             U0CTL_    /* USART 0 Control */
  294. DEFC(    UCTL_0            , UCTL_0_)
  295. #define UTCTL_0_            U0TCTL_   /* USART 0 Transmit Control */
  296. DEFC(    UTCTL_0           , UTCTL_0_)
  297. #define URCTL_0_            U0RCTL_   /* USART 0 Receive Control */
  298. DEFC(    URCTL_0           , URCTL_0_)
  299. #define UMCTL_0_            U0MCTL_   /* USART 0 Modulation Control */
  300. DEFC(    UMCTL_0           , UMCTL_0_)
  301. #define UBR0_0_             U0BR0_    /* USART 0 Baud Rate 0 */
  302. DEFC(    UBR0_0            , UBR0_0_)
  303. #define UBR1_0_             U0BR1_    /* USART 0 Baud Rate 1 */
  304. DEFC(    UBR1_0            , UBR1_0_)
  305. #define RXBUF_0_            U0RXBUF_  /* USART 0 Receive Buffer */
  306. READ_ONLY DEFC( RXBUF_0        , RXBUF_0_)
  307. #define TXBUF_0_            U0TXBUF_  /* USART 0 Transmit Buffer */
  308. DEFC(    TXBUF_0           , TXBUF_0_)
  309. /************************************************************
  310. * Timer A
  311. ************************************************************/
  312. #define TAIV_               (0x012E)  /* Timer A Interrupt Vector Word */
  313. READ_ONLY DEFW( TAIV           , TAIV_)
  314. #define TACTL_              (0x0160)  /* Timer A Control */
  315. DEFW(    TACTL             , TACTL_)
  316. #define TACCTL0_            (0x0162)  /* Timer A Capture/Compare Control 0 */
  317. DEFW(    TACCTL0           , TACCTL0_)
  318. #define TACCTL1_            (0x0164)  /* Timer A Capture/Compare Control 1 */
  319. DEFW(    TACCTL1           , TACCTL1_)
  320. #define TACCTL2_            (0x0166)  /* Timer A Capture/Compare Control 2 */
  321. DEFW(    TACCTL2           , TACCTL2_)
  322. #define TAR_                (0x0170)  /* Timer A */
  323. DEFW(    TAR               , TAR_)
  324. #define TACCR0_             (0x0172)  /* Timer A Capture/Compare 0 */
  325. DEFW(    TACCR0            , TACCR0_)
  326. #define TACCR1_             (0x0174)  /* Timer A Capture/Compare 1 */
  327. DEFW(    TACCR1            , TACCR1_)
  328. #define TACCR2_             (0x0176)  /* Timer A Capture/Compare 2 */
  329. DEFW(    TACCR2            , TACCR2_)
  330. /* Alternate register names */
  331. #define CCTL0_              TACCTL0_   /* Timer A Capture/Compare Control 0 */
  332. DEFW(    CCTL0 , CCTL0_)
  333. #define CCTL1_              TACCTL1_   /* Timer A Capture/Compare Control 1 */
  334. DEFW(    CCTL1 , CCTL1_)
  335. #define CCTL2_              TACCTL2_   /* Timer A Capture/Compare Control 2 */
  336. DEFW(    CCTL2 , CCTL2_)
  337. #define CCR0_               TACCR0_   /* Timer A Capture/Compare 0 */
  338. DEFW(    CCR0 , CCR0_)
  339. #define CCR1_               TACCR1_   /* Timer A Capture/Compare 1 */
  340. DEFW(    CCR1 , CCR1_)
  341. #define CCR2_               TACCR2_   /* Timer A Capture/Compare 2 */
  342. DEFW(    CCR2 , CCR2_)
  343. #define TASSEL2             (0x0400)  /* unused */        /* to distinguish from USART SSELx */
  344. #define TASSEL1             (0x0200)  /* Timer A clock source select 0 */
  345. #define TASSEL0             (0x0100)  /* Timer A clock source select 1 */
  346. #define ID1                 (0x0080)  /* Timer A clock input devider 1 */
  347. #define ID0                 (0x0040)  /* Timer A clock input devider 0 */
  348. #define MC1                 (0x0020)  /* Timer A mode control 1 */
  349. #define MC0                 (0x0010)  /* Timer A mode control 0 */
  350. #define TACLR               (0x0004)  /* Timer A counter clear */
  351. #define TAIE                (0x0002)  /* Timer A counter interrupt enable */
  352. #define TAIFG               (0x0001)  /* Timer A counter interrupt flag */
  353. #define MC_0                (0*0x10)  /* Timer A mode control: 0 - Stop */
  354. #define MC_1                (1*0x10)  /* Timer A mode control: 1 - Up to CCR0 */
  355. #define MC_2                (2*0x10)  /* Timer A mode control: 2 - Continous up */
  356. #define MC_3                (3*0x10)  /* Timer A mode control: 3 - Up/Down */
  357. #define ID_0                (0*0x40)  /* Timer A input divider: 0 - /1 */
  358. #define ID_1                (1*0x40)  /* Timer A input divider: 1 - /2 */
  359. #define ID_2                (2*0x40)  /* Timer A input divider: 2 - /4 */
  360. #define ID_3                (3*0x40)  /* Timer A input divider: 3 - /8 */
  361. #define TASSEL_0            (0*0x100) /* Timer A clock source select: 0 - TACLK */
  362. #define TASSEL_1            (1*0x100) /* Timer A clock source select: 1 - ACLK  */
  363. #define TASSEL_2            (2*0x100) /* Timer A clock source select: 2 - SMCLK */
  364. #define TASSEL_3            (3*0x100) /* Timer A clock source select: 3 - INCLK */
  365. #define CM1                 (0x8000)  /* Capture mode 1 */
  366. #define CM0                 (0x4000)  /* Capture mode 0 */
  367. #define CCIS1               (0x2000)  /* Capture input select 1 */
  368. #define CCIS0               (0x1000)  /* Capture input select 0 */
  369. #define SCS                 (0x0800)  /* Capture sychronize */
  370. #define SCCI                (0x0400)  /* Latched capture signal (read) */
  371. #define CAP                 (0x0100)  /* Capture mode: 1 /Compare mode : 0 */
  372. #define OUTMOD2             (0x0080)  /* Output mode 2 */
  373. #define OUTMOD1             (0x0040)  /* Output mode 1 */
  374. #define OUTMOD0             (0x0020)  /* Output mode 0 */
  375. #define CCIE                (0x0010)  /* Capture/compare interrupt enable */
  376. #define CCI                 (0x0008)  /* Capture input signal (read) */
  377. #define OUT                 (0x0004)  /* PWM Output signal if output mode 0 */
  378. #define COV                 (0x0002)  /* Capture/compare overflow flag */
  379. #define CCIFG               (0x0001)  /* Capture/compare interrupt flag */
  380. #define OUTMOD_0            (0*0x20)  /* PWM output mode: 0 - output only */
  381. #define OUTMOD_1            (1*0x20)  /* PWM output mode: 1 - set */
  382. #define OUTMOD_2            (2*0x20)  /* PWM output mode: 2 - PWM toggle/reset */
  383. #define OUTMOD_3            (3*0x20)  /* PWM output mode: 3 - PWM set/reset */
  384. #define OUTMOD_4            (4*0x20)  /* PWM output mode: 4 - toggle */
  385. #define OUTMOD_5            (5*0x20)  /* PWM output mode: 5 - Reset */
  386. #define OUTMOD_6            (6*0x20)  /* PWM output mode: 6 - PWM toggle/set */
  387. #define OUTMOD_7            (7*0x20)  /* PWM output mode: 7 - PWM reset/set */
  388. #define CCIS_0              (0*0x1000) /* Capture input select: 0 - CCIxA */
  389. #define CCIS_1              (1*0x1000) /* Capture input select: 1 - CCIxB */
  390. #define CCIS_2              (2*0x1000) /* Capture input select: 2 - GND */
  391. #define CCIS_3              (3*0x1000) /* Capture input select: 3 - Vcc */
  392. #define CM_0                (0*0x4000) /* Capture mode: 0 - disabled */
  393. #define CM_1                (1*0x4000) /* Capture mode: 1 - pos. edge */
  394. #define CM_2                (2*0x4000) /* Capture mode: 1 - neg. edge */
  395. #define CM_3                (3*0x4000) /* Capture mode: 1 - both edges */
  396. /************************************************************
  397. * Timer B
  398. ************************************************************/
  399. #define TBIV_               (0x011E)  /* Timer B Interrupt Vector Word */
  400. READ_ONLY DEFW( TBIV           , TBIV_)
  401. #define TBCTL_              (0x0180)  /* Timer B Control */
  402. DEFW(    TBCTL             , TBCTL_)
  403. #define TBCCTL0_            (0x0182)  /* Timer B Capture/Compare Control 0 */
  404. DEFW(    TBCCTL0           , TBCCTL0_)
  405. #define TBCCTL1_            (0x0184)  /* Timer B Capture/Compare Control 1 */
  406. DEFW(    TBCCTL1           , TBCCTL1_)
  407. #define TBCCTL2_            (0x0186)  /* Timer B Capture/Compare Control 2 */
  408. DEFW(    TBCCTL2           , TBCCTL2_)
  409. #define TBR_                (0x0190)  /* Timer B */
  410. DEFW(    TBR               , TBR_)
  411. #define TBCCR0_             (0x0192)  /* Timer B Capture/Compare 0 */
  412. DEFW(    TBCCR0            , TBCCR0_)
  413. #define TBCCR1_             (0x0194)  /* Timer B Capture/Compare 1 */
  414. DEFW(    TBCCR1            , TBCCR1_)
  415. #define TBCCR2_             (0x0196)  /* Timer B Capture/Compare 2 */
  416. DEFW(    TBCCR2            , TBCCR2_)
  417. #define SHR1                (0x4000)  /* Timer B Compare latch load group 1 */
  418. #define SHR0                (0x2000)  /* Timer B Compare latch load group 0 */
  419. #define TBCLGRP1            (0x4000)  /* Timer B Compare latch load group 1 */
  420. #define TBCLGRP0            (0x2000)  /* Timer B Compare latch load group 0 */
  421. #define CNTL1               (0x1000)  /* Counter lenght 1 */
  422. #define CNTL0               (0x0800)  /* Counter lenght 0 */
  423. #define TBSSEL2             (0x0400)  /* unused */
  424. #define TBSSEL1             (0x0200)  /* Clock source 1 */
  425. #define TBSSEL0             (0x0100)  /* Clock source 0 */
  426. #define TBCLR               (0x0004)  /* Timer B counter clear */
  427. #define TBIE                (0x0002)  /* Timer B interrupt enable */
  428. #define TBIFG               (0x0001)  /* Timer B interrupt flag */
  429. #define TBSSEL_0            (0*0x0100)  /* Clock Source: TBCLK */
  430. #define TBSSEL_1            (1*0x0100)  /* Clock Source: ACLK  */
  431. #define TBSSEL_2            (2*0x0100)  /* Clock Source: SMCLK */
  432. #define TBSSEL_3            (3*0x0100)  /* Clock Source: INCLK */
  433. #define CNTL_0              (0*0x0800)  /* Counter lenght: 16 bit */
  434. #define CNTL_1              (1*0x0800)  /* Counter lenght: 12 bit */
  435. #define CNTL_2              (2*0x0800)  /* Counter lenght: 10 bit */
  436. #define CNTL_3              (3*0x0800)  /* Counter lenght:  8 bit */
  437. #define SHR_0               (0*0x2000)  /* Timer B Group: 0 - individually */
  438. #define SHR_1               (1*0x2000)  /* Timer B Group: 1 - 3 groups (1-2, 3-4, 5-6) */
  439. #define SHR_2               (2*0x2000)  /* Timer B Group: 2 - 2 groups (1-3, 4-6)*/
  440. #define SHR_3               (3*0x2000)  /* Timer B Group: 3 - 1 group (all) */
  441. #define TBCLGRP_0           (0*0x2000)  /* Timer B Group: 0 - individually */
  442. #define TBCLGRP_1           (1*0x2000)  /* Timer B Group: 1 - 3 groups (1-2, 3-4, 5-6) */
  443. #define TBCLGRP_2           (2*0x2000)  /* Timer B Group: 2 - 2 groups (1-3, 4-6)*/
  444. #define TBCLGRP_3           (3*0x2000)  /* Timer B Group: 3 - 1 group (all) */
  445. /* Additional Timer B Control Register bits are defined in Timer A */
  446. #define SLSHR1              (0x0400)  /* Compare latch load source 1 */
  447. #define SLSHR0              (0x0200)  /* Compare latch load source 0 */
  448. #define CLLD1               (0x0400)  /* Compare latch load source 1 */
  449. #define CLLD0               (0x0200)  /* Compare latch load source 0 */
  450. #define SLSHR_0             (0*0x0200)  /* Compare latch load sourec : 0 - immediate */
  451. #define SLSHR_1             (1*0x0200)  /* Compare latch load sourec : 1 - TBR counts to 0 */
  452. #define SLSHR_2             (2*0x0200)  /* Compare latch load sourec : 2 - up/down */
  453. #define SLSHR_3             (3*0x0200)  /* Compare latch load sourec : 3 - TBR counts to TBCTL0 */
  454. #define CLLD_0              (0*0x0200)  /* Compare latch load sourec : 0 - immediate */
  455. #define CLLD_1              (1*0x0200)  /* Compare latch load sourec : 1 - TBR counts to 0 */
  456. #define CLLD_2              (2*0x0200)  /* Compare latch load sourec : 2 - up/down */
  457. #define CLLD_3              (3*0x0200)  /* Compare latch load sourec : 3 - TBR counts to TBCTL0 */
  458. /************************************************************
  459. * Basic Clock Module
  460. ************************************************************/
  461. #define DCOCTL_             (0x0056)  /* DCO Clock Frequency Control */
  462. DEFC(    DCOCTL            , DCOCTL_)
  463. #define BCSCTL1_            (0x0057)  /* Basic Clock System Control 1 */
  464. DEFC(    BCSCTL1           , BCSCTL1_)
  465. #define BCSCTL2_            (0x0058)  /* Basic Clock System Control 2 */
  466. DEFC(    BCSCTL2           , BCSCTL2_)
  467. #define MOD0                (0x01)   /* Modulation Bit 0 */
  468. #define MOD1                (0x02)   /* Modulation Bit 1 */
  469. #define MOD2                (0x04)   /* Modulation Bit 2 */
  470. #define MOD3                (0x08)   /* Modulation Bit 3 */
  471. #define MOD4                (0x10)   /* Modulation Bit 4 */
  472. #define DCO0                (0x20)   /* DCO Select Bit 0 */
  473. #define DCO1                (0x40)   /* DCO Select Bit 1 */
  474. #define DCO2                (0x80)   /* DCO Select Bit 2 */
  475. #define RSEL0               (0x01)   /* Resistor Select Bit 0 */
  476. #define RSEL1               (0x02)   /* Resistor Select Bit 1 */
  477. #define RSEL2               (0x04)   /* Resistor Select Bit 2 */
  478. #define XT5V                (0x08)   /* XT5V should always be reset */
  479. #define DIVA0               (0x10)   /* ACLK Divider 0 */
  480. #define DIVA1               (0x20)   /* ACLK Divider 1 */
  481. #define XTS                 (0x40)   /* LFXTCLK 0:Low Freq. / 1: High Freq. */
  482. #define XT2OFF              (0x80)   /* Enable XT2CLK */
  483. #define DIVA_0              (0x00)   /* ACLK Divider 0: /1 */
  484. #define DIVA_1              (0x10)   /* ACLK Divider 1: /2 */
  485. #define DIVA_2              (0x20)   /* ACLK Divider 2: /4 */
  486. #define DIVA_3              (0x30)   /* ACLK Divider 3: /8 */
  487. #define DCOR                (0x01)   /* Enable External Resistor : 1 */
  488. #define DIVS0               (0x02)   /* SMCLK Divider 0 */
  489. #define DIVS1               (0x04)   /* SMCLK Divider 1 */
  490. #define SELS                (0x08)   /* SMCLK Source Select 0:DCOCLK / 1:XT2CLK/LFXTCLK */
  491. #define DIVM0               (0x10)   /* MCLK Divider 0 */
  492. #define DIVM1               (0x20)   /* MCLK Divider 1 */
  493. #define SELM0               (0x40)   /* MCLK Source Select 0 */
  494. #define SELM1               (0x80)   /* MCLK Source Select 1 */
  495. #define DIVS_0              (0x00)   /* SMCLK Divider 0: /1 */
  496. #define DIVS_1              (0x02)   /* SMCLK Divider 1: /2 */
  497. #define DIVS_2              (0x04)   /* SMCLK Divider 2: /4 */
  498. #define DIVS_3              (0x06)   /* SMCLK Divider 3: /8 */
  499. #define DIVM_0              (0x00)   /* MCLK Divider 0: /1 */
  500. #define DIVM_1              (0x10)   /* MCLK Divider 1: /2 */
  501. #define DIVM_2              (0x20)   /* MCLK Divider 2: /4 */
  502. #define DIVM_3              (0x30)   /* MCLK Divider 3: /8 */
  503. #define SELM_0              (0x00)   /* MCLK Source Select 0: DCOCLK */
  504. #define SELM_1              (0x40)   /* MCLK Source Select 1: DCOCLK */
  505. #define SELM_2              (0x80)   /* MCLK Source Select 2: XT2CLK/LFXTCLK */
  506. #define SELM_3              (0xC0)   /* MCLK Source Select 3: LFXTCLK */
  507. /*************************************************************
  508. * Flash Memory
  509. *************************************************************/
  510. #define FCTL1_              (0x0128)  /* FLASH Control 1 */
  511. DEFW(    FCTL1             , FCTL1_)
  512. #define FCTL2_              (0x012A)  /* FLASH Control 2 */
  513. DEFW(    FCTL2             , FCTL2_)
  514. #define FCTL3_              (0x012C)  /* FLASH Control 3 */
  515. DEFW(    FCTL3             , FCTL3_)
  516. #define FRKEY               (0x9600)  /* Flash key returned by read */
  517. #define FWKEY               (0xA500)  /* Flash key for write */
  518. #define FXKEY               (0x3300)  /* for use with XOR instruction */
  519. #define ERASE               (0x0002)  /* Enable bit for Flash segment erase */
  520. #define MERAS               (0x0004)  /* Enable bit for Flash mass erase */
  521. #define WRT                 (0x0040)  /* Enable bit for Flash write */
  522. #define BLKWRT              (0x0080)  /* Enable bit for Flash segment write */
  523. #define SEGWRT              (0x0080)  /* old definition */ /* Enable bit for Flash segment write */
  524. #define FN0                 (0x0001)  /* Devide Flash clock by 1 to 64 using FN0 to FN5 according to: */
  525. #define FN1                 (0x0002)  /*  32*FN5 + 16*FN4 + 8*FN3 + 4*FN2 + 2*FN1 + FN0 + 1 */
  526. #define FN2                 (0x0004)
  527. #define FN3                 (0x0008)
  528. #define FN4                 (0x0010)
  529. #define FN5                 (0x0020)
  530. #define FSSEL0              (0x0040)  /* Flash clock select 0 */        /* to distinguish from USART SSELx */
  531. #define FSSEL1              (0x0080)  /* Flash clock select 1 */
  532. #define FSSEL_0             (0x0000)  /* Flash clock select: 0 - ACLK */
  533. #define FSSEL_1             (0x0040)  /* Flash clock select: 1 - MCLK */
  534. #define FSSEL_2             (0x0080)  /* Flash clock select: 2 - SMCLK */
  535. #define FSSEL_3             (0x00C0)  /* Flash clock select: 3 - SMCLK */
  536. #define BUSY                (0x0001)  /* Flash busy: 1 */
  537. #define KEYV                (0x0002)  /* Flash Key violation flag */
  538. #define ACCVIFG             (0x0004)  /* Flash Access violation flag */
  539. #define WAIT                (0x0008)  /* Wait flag for segment write */
  540. #define LOCK                (0x0010)  /* Lock bit: 1 - Flash is locked (read only) */
  541. #define EMEX                (0x0020)  /* Flash Emergency Exit */
  542. /************************************************************
  543. * Comparator A
  544. ************************************************************/
  545. #define CACTL1_             (0x0059)  /* Comparator A Control 1 */
  546. DEFC(    CACTL1            , CACTL1_)
  547. #define CACTL2_             (0x005A)  /* Comparator A Control 2 */
  548. DEFC(    CACTL2            , CACTL2_)
  549. #define CAPD_               (0x005B)  /* Comparator A Port Disable */
  550. DEFC(    CAPD              , CAPD_)
  551. #define CAIFG               (0x01)    /* Comp. A Interrupt Flag */
  552. #define CAIE                (0x02)    /* Comp. A Interrupt Enable */
  553. #define CAIES               (0x04)    /* Comp. A Int. Edge Select: 0:rising / 1:falling */
  554. #define CAON                (0x08)    /* Comp. A enable */
  555. #define CAREF0              (0x10)    /* Comp. A Internal Reference Select 0 */
  556. #define CAREF1              (0x20)    /* Comp. A Internal Reference Select 1 */
  557. #define CARSEL              (0x40)    /* Comp. A Internal Reference Enable */
  558. #define CAEX                (0x80)    /* Comp. A Exchange Inputs */
  559. #define CAREF_0             (0x00)    /* Comp. A Int. Ref. Select 0 : Off */
  560. #define CAREF_1             (0x10)    /* Comp. A Int. Ref. Select 1 : 0.25*Vcc */
  561. #define CAREF_2             (0x20)    /* Comp. A Int. Ref. Select 2 : 0.5*Vcc */
  562. #define CAREF_3             (0x30)    /* Comp. A Int. Ref. Select 3 : Vt*/
  563. #define CAOUT               (0x01)    /* Comp. A Output */
  564. #define CAF                 (0x02)    /* Comp. A Enable Output Filter */
  565. #define P2CA0               (0x04)    /* Comp. A Connect External Signal to CA0 : 1 */
  566. #define P2CA1               (0x08)    /* Comp. A Connect External Signal to CA1 : 1 */
  567. #define CACTL24             (0x10)
  568. #define CACTL25             (0x20)
  569. #define CACTL26             (0x40)
  570. #define CACTL27             (0x80)
  571. #define CAPD0               (0x01)    /* Comp. A Disable Input Buffer of Port Register .0 */
  572. #define CAPD1               (0x02)    /* Comp. A Disable Input Buffer of Port Register .1 */
  573. #define CAPD2               (0x04)    /* Comp. A Disable Input Buffer of Port Register .2 */
  574. #define CAPD3               (0x08)    /* Comp. A Disable Input Buffer of Port Register .3 */
  575. #define CAPD4               (0x10)    /* Comp. A Disable Input Buffer of Port Register .4 */
  576. #define CAPD5               (0x20)    /* Comp. A Disable Input Buffer of Port Register .5 */
  577. #define CAPD6               (0x40)    /* Comp. A Disable Input Buffer of Port Register .6 */
  578. #define CAPD7               (0x80)    /* Comp. A Disable Input Buffer of Port Register .7 */
  579. /************************************************************
  580. * ADC12
  581. ************************************************************/
  582. #define ADC12CTL0_          (0x01A0)  /* ADC12 Control 0 */
  583. DEFW(    ADC12CTL0         , ADC12CTL0_)
  584. #define ADC12CTL1_          (0x01A2)  /* ADC12 Control 1 */
  585. DEFW(    ADC12CTL1         , ADC12CTL1_)
  586. #define ADC12IFG_           (0x01A4)  /* ADC12 Interrupt Flag */
  587. DEFW(    ADC12IFG          , ADC12IFG_)
  588. #define ADC12IE_            (0x01A6)  /* ADC12 Interrupt Enable */
  589. DEFW(    ADC12IE           , ADC12IE_)
  590. #define ADC12IV_            (0x01A8)  /* ADC12 Interrupt Vector Word */
  591. DEFW(    ADC12IV           , ADC12IV_)
  592. #define ADC12MEM_           (0x0140)  /* ADC12 Conversion Memory */
  593. #ifndef __IAR_SYSTEMS_ICC
  594. #define ADC12MEM            (ADC12MEM_) /* ADC12 Conversion Memory (for assembler) */
  595. #else
  596. #define ADC12MEM            ((int*) ADC12MEM_) /* ADC12 Conversion Memory (for C) */
  597. #endif
  598. #define ADC12MEM0_          (ADC12MEM_) /* ADC12 Conversion Memory 0 */
  599. DEFW(    ADC12MEM0         , ADC12MEM0_)
  600. #define ADC12MEM1_          (0x0142)  /* ADC12 Conversion Memory 1 */
  601. DEFW(    ADC12MEM1         , ADC12MEM1_)
  602. #define ADC12MEM2_          (0x0144)  /* ADC12 Conversion Memory 2 */
  603. DEFW(    ADC12MEM2         , ADC12MEM2_)
  604. #define ADC12MEM3_          (0x0146)  /* ADC12 Conversion Memory 3 */
  605. DEFW(    ADC12MEM3         , ADC12MEM3_)
  606. #define ADC12MEM4_          (0x0148)  /* ADC12 Conversion Memory 4 */
  607. DEFW(    ADC12MEM4         , ADC12MEM4_)
  608. #define ADC12MEM5_          (0x014A)  /* ADC12 Conversion Memory 5 */
  609. DEFW(    ADC12MEM5         , ADC12MEM5_)
  610. #define ADC12MEM6_          (0x014C)  /* ADC12 Conversion Memory 6 */
  611. DEFW(    ADC12MEM6         , ADC12MEM6_)
  612. #define ADC12MEM7_          (0x014E)  /* ADC12 Conversion Memory 7 */
  613. DEFW(    ADC12MEM7         , ADC12MEM7_)
  614. #define ADC12MEM8_          (0x0150)  /* ADC12 Conversion Memory 8 */
  615. DEFW(    ADC12MEM8         , ADC12MEM8_)
  616. #define ADC12MEM9_          (0x0152)  /* ADC12 Conversion Memory 9 */
  617. DEFW(    ADC12MEM9         , ADC12MEM9_)
  618. #define ADC12MEM10_         (0x0154)  /* ADC12 Conversion Memory 10 */
  619. DEFW(    ADC12MEM10        , ADC12MEM10_)
  620. #define ADC12MEM11_         (0x0156)  /* ADC12 Conversion Memory 11 */
  621. DEFW(    ADC12MEM11        , ADC12MEM11_)
  622. #define ADC12MEM12_         (0x0158)  /* ADC12 Conversion Memory 12 */
  623. DEFW(    ADC12MEM12        , ADC12MEM12_)
  624. #define ADC12MEM13_         (0x015A)  /* ADC12 Conversion Memory 13 */
  625. DEFW(    ADC12MEM13        , ADC12MEM13_)
  626. #define ADC12MEM14_         (0x015C)  /* ADC12 Conversion Memory 14 */
  627. DEFW(    ADC12MEM14        , ADC12MEM14_)
  628. #define ADC12MEM15_         (0x015E)  /* ADC12 Conversion Memory 15 */
  629. DEFW(    ADC12MEM15        , ADC12MEM15_)
  630. #define ADC12MCTL_          (0x0080)  /* ADC12 Memory Control */
  631. #ifndef __IAR_SYSTEMS_ICC
  632. #define ADC12MCTL           (ADC12MCTL_) /* ADC12 Memory Control (for assembler) */
  633. #else
  634. #define ADC12MCTL           ((char*) ADC12MCTL_) /* ADC12 Memory Control (for C) */
  635. #endif
  636. #define ADC12MCTL0_         (ADC12MCTL_) /* ADC12 Memory Control 0 */
  637. DEFC(    ADC12MCTL0        , ADC12MCTL0_)
  638. #define ADC12MCTL1_         (0x0081)  /* ADC12 Memory Control 1 */
  639. DEFC(    ADC12MCTL1        , ADC12MCTL1_)
  640. #define ADC12MCTL2_         (0x0082)  /* ADC12 Memory Control 2 */
  641. DEFC(    ADC12MCTL2        , ADC12MCTL2_)
  642. #define ADC12MCTL3_         (0x0083)  /* ADC12 Memory Control 3 */
  643. DEFC(    ADC12MCTL3        , ADC12MCTL3_)
  644. #define ADC12MCTL4_         (0x0084)  /* ADC12 Memory Control 4 */
  645. DEFC(    ADC12MCTL4        , ADC12MCTL4_)
  646. #define ADC12MCTL5_         (0x0085)  /* ADC12 Memory Control 5 */
  647. DEFC(    ADC12MCTL5        , ADC12MCTL5_)
  648. #define ADC12MCTL6_         (0x0086)  /* ADC12 Memory Control 6 */
  649. DEFC(    ADC12MCTL6        , ADC12MCTL6_)
  650. #define ADC12MCTL7_         (0x0087)  /* ADC12 Memory Control 7 */
  651. DEFC(    ADC12MCTL7        , ADC12MCTL7_)
  652. #define ADC12MCTL8_         (0x0088)  /* ADC12 Memory Control 8 */
  653. DEFC(    ADC12MCTL8        , ADC12MCTL8_)
  654. #define ADC12MCTL9_         (0x0089)  /* ADC12 Memory Control 9 */
  655. DEFC(    ADC12MCTL9        , ADC12MCTL9_)
  656. #define ADC12MCTL10_        (0x008A)  /* ADC12 Memory Control 10 */
  657. DEFC(    ADC12MCTL10       , ADC12MCTL10_)
  658. #define ADC12MCTL11_        (0x008B)  /* ADC12 Memory Control 11 */
  659. DEFC(    ADC12MCTL11       , ADC12MCTL11_)
  660. #define ADC12MCTL12_        (0x008C)  /* ADC12 Memory Control 12 */
  661. DEFC(    ADC12MCTL12       , ADC12MCTL12_)
  662. #define ADC12MCTL13_        (0x008D)  /* ADC12 Memory Control 13 */
  663. DEFC(    ADC12MCTL13       , ADC12MCTL13_)
  664. #define ADC12MCTL14_        (0x008E)  /* ADC12 Memory Control 14 */
  665. DEFC(    ADC12MCTL14       , ADC12MCTL14_)
  666. #define ADC12MCTL15_        (0x008F)  /* ADC12 Memory Control 15 */
  667. DEFC(    ADC12MCTL15       , ADC12MCTL15_)
  668. #define ADC12SC             (0x001) /* ADC12CTL0 */
  669. #define ENC                 (0x002)
  670. #define ADC12TOVIE          (0x004)
  671. #define ADC12OVIE           (0x008)
  672. #define ADC12ON             (0x010)
  673. #define REFON               (0x020)
  674. #define REF2_5V             (0x040)
  675. #define MSH                 (0x080)
  676. #define MSC                 (0x080)
  677. #define SHT0_0               (0*0x100)
  678. #define SHT0_1               (1*0x100)
  679. #define SHT0_2               (2*0x100)
  680. #define SHT0_3               (3*0x100)
  681. #define SHT0_4               (4*0x100)
  682. #define SHT0_5               (5*0x100)
  683. #define SHT0_6               (6*0x100)
  684. #define SHT0_7               (7*0x100)
  685. #define SHT0_8               (8*0x100)
  686. #define SHT0_9               (9*0x100)
  687. #define SHT0_10             (10*0x100)
  688. #define SHT0_11             (11*0x100)
  689. #define SHT0_12             (12*0x100)
  690. #define SHT0_13             (13*0x100)
  691. #define SHT0_14             (14*0x100)
  692. #define SHT0_15             (15*0x100)
  693. #define SHT1_0               (0*0x1000)
  694. #define SHT1_1               (1*0x1000)
  695. #define SHT1_2               (2*0x1000)
  696. #define SHT1_3               (3*0x1000)
  697. #define SHT1_4               (4*0x1000)
  698. #define SHT1_5               (5*0x1000)
  699. #define SHT1_6               (6*0x1000)
  700. #define SHT1_7               (7*0x1000)
  701. #define SHT1_8               (8*0x1000)
  702. #define SHT1_9               (9*0x1000)
  703. #define SHT1_10             (10*0x1000)
  704. #define SHT1_11             (11*0x1000)
  705. #define SHT1_12             (12*0x1000)
  706. #define SHT1_13             (13*0x1000)
  707. #define SHT1_14             (14*0x1000)
  708. #define SHT1_15             (15*0x1000)
  709. #define ADC12BUSY           (0x0001) /* ADC12CTL1 */
  710. #define CONSEQ_0             (0*2)
  711. #define CONSEQ_1             (1*2)
  712. #define CONSEQ_2             (2*2)
  713. #define CONSEQ_3             (3*2)
  714. #define ADC12SSEL_0          (0*8)
  715. #define ADC12SSEL_1          (1*8)
  716. #define ADC12SSEL_2          (2*8)
  717. #define ADC12SSEL_3          (3*8)
  718. #define ADC12DIV_0           (0*0x20)
  719. #define ADC12DIV_1           (1*0x20)
  720. #define ADC12DIV_2           (2*0x20)
  721. #define ADC12DIV_3           (3*0x20)
  722. #define ADC12DIV_4           (4*0x20)
  723. #define ADC12DIV_5           (5*0x20)
  724. #define ADC12DIV_6           (6*0x20)
  725. #define ADC12DIV_7           (7*0x20)
  726. #define ISSH                (0x0100)
  727. #define SHP                 (0x0200)
  728. #define SHS_0                (0*0x400)
  729. #define SHS_1                (1*0x400)
  730. #define SHS_2                (2*0x400)
  731. #define SHS_3                (3*0x400)
  732. #define CSTARTADD_0          (0*0x1000)
  733. #define CSTARTADD_1          (1*0x1000)
  734. #define CSTARTADD_2          (2*0x1000)
  735. #define CSTARTADD_3          (3*0x1000)
  736. #define CSTARTADD_4          (4*0x1000)
  737. #define CSTARTADD_5          (5*0x1000)
  738. #define CSTARTADD_6          (6*0x1000)
  739. #define CSTARTADD_7          (7*0x1000)
  740. #define CSTARTADD_8          (8*0x1000)
  741. #define CSTARTADD_9          (9*0x1000)
  742. #define CSTARTADD_10        (10*0x1000)
  743. #define CSTARTADD_11        (11*0x1000)
  744. #define CSTARTADD_12        (12*0x1000)
  745. #define CSTARTADD_13        (13*0x1000)
  746. #define CSTARTADD_14        (14*0x1000)
  747. #define CSTARTADD_15        (15*0x1000)
  748. #define INCH_0               (0) /* ADC12MCTLx */
  749. #define INCH_1               (1)
  750. #define INCH_2               (2)
  751. #define INCH_3               (3)
  752. #define INCH_4               (4)
  753. #define INCH_5               (5)
  754. #define INCH_6               (6)
  755. #define INCH_7               (7)
  756. #define INCH_8               (8)
  757. #define INCH_9               (9)
  758. #define INCH_10             (10)
  759. #define INCH_11             (11)
  760. #define INCH_12             (12)
  761. #define INCH_13             (13)
  762. #define INCH_14             (14)
  763. #define INCH_15             (15)
  764. #define SREF_0               (0*0x10)
  765. #define SREF_1               (1*0x10)
  766. #define SREF_2               (2*0x10)
  767. #define SREF_3               (3*0x10)
  768. #define SREF_4               (4*0x10)
  769. #define SREF_5               (5*0x10)
  770. #define SREF_6               (6*0x10)
  771. #define SREF_7               (7*0x10)
  772. #define EOS                 (0x80)
  773. /************************************************************
  774. * Interrupt Vectors (offset from 0xFFE0)
  775. ************************************************************/
  776. #define PORT2_VECTOR        (1 * 2)  /* 0xFFE2 Port 2 */
  777. #define PORT1_VECTOR        (4 * 2)  /* 0xFFE8 Port 1 */
  778. #define TIMERA1_VECTOR      (5 * 2)  /* 0xFFEA Timer A CC1-2, TA */
  779. #define TIMERA0_VECTOR      (6 * 2)  /* 0xFFEC Timer A CC0 */
  780. #define ADC_VECTOR          (7 * 2)  /* 0xFFEE ADC */
  781. #define USART0TX_VECTOR     (8 * 2)  /* 0xFFF0 USART 0 Transmit */
  782. #define USART0RX_VECTOR     (9 * 2)  /* 0xFFF2 USART 0 Receive */
  783. #define WDT_VECTOR          (10 * 2) /* 0xFFF4 Watchdog Timer */
  784. #define COMPARATORA_VECTOR  (11 * 2) /* 0xFFF6 Comparator A */
  785. #define TIMERB1_VECTOR      (12 * 2) /* 0xFFF8 Timer B 1-2 */
  786. #define TIMERB0_VECTOR      (13 * 2) /* 0xFFFA Timer B 0 */
  787. #define NMI_VECTOR          (14 * 2) /* 0xFFFC Non-maskable */
  788. #define RESET_VECTOR        (15 * 2) /* 0xFFFE Reset [Highest Priority] */
  789. #define UART0TX_VECTOR      USART0TX_VECTOR
  790. #define UART0RX_VECTOR      USART0RX_VECTOR
  791. /************************************************************
  792. * End of Module
  793. ************************************************************/
  794. #pragma language=default
  795. #endif /* #ifndef __msp430x13x */