Subversion Repositories DevTools

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
2850 dpurdie 1
/******************************************************************************/
2
/* Legacy Header File                                                         */
3
/* Not recommended for use in new projects.                                   */
4
/* Please use the msp430.h file or the device specific header file            */
5
/******************************************************************************/
6
 
7
/********************************************************************
8
*
9
* Standard register and bit definitions for the Texas Instruments
10
* MSP430 microcontroller.
11
*
12
* This file supports assembler and C development for
13
* MSP430x09x devices.
14
*
15
* Texas Instruments, Version 1.1
16
*
17
* Rev. 1.0, Initial Release
18
* Rev. 1.0, Added LCMP : A-POOL Latch comparator
19
*
20
*
21
********************************************************************/
22
 
23
#ifndef __msp430x09x
24
#define __msp430x09x
25
 
26
#ifdef __cplusplus
27
extern "C" {
28
#endif
29
 
30
 
31
/*----------------------------------------------------------------------------*/
32
/* PERIPHERAL FILE MAP                                                        */
33
/*----------------------------------------------------------------------------*/
34
 
35
/* External references resolved by a device-specific linker command file */
36
#define SFR_8BIT(address)   extern volatile unsigned char address
37
#define SFR_16BIT(address)  extern volatile unsigned int address
38
//#define SFR_20BIT(address)  extern volatile unsigned int address
39
typedef void (* __SFR_FARPTR)();
40
#define SFR_20BIT(address) extern __SFR_FARPTR address
41
#define SFR_32BIT(address)  extern volatile unsigned long address
42
 
43
 
44
 
45
/************************************************************
46
* STANDARD BITS
47
************************************************************/
48
 
49
#define BIT0                   (0x0001)
50
#define BIT1                   (0x0002)
51
#define BIT2                   (0x0004)
52
#define BIT3                   (0x0008)
53
#define BIT4                   (0x0010)
54
#define BIT5                   (0x0020)
55
#define BIT6                   (0x0040)
56
#define BIT7                   (0x0080)
57
#define BIT8                   (0x0100)
58
#define BIT9                   (0x0200)
59
#define BITA                   (0x0400)
60
#define BITB                   (0x0800)
61
#define BITC                   (0x1000)
62
#define BITD                   (0x2000)
63
#define BITE                   (0x4000)
64
#define BITF                   (0x8000)
65
 
66
/************************************************************
67
* STATUS REGISTER BITS
68
************************************************************/
69
 
70
#define C                      (0x0001)
71
#define Z                      (0x0002)
72
#define N                      (0x0004)
73
#define V                      (0x0100)
74
#define GIE                    (0x0008)
75
#define CPUOFF                 (0x0010)
76
#define OSCOFF                 (0x0020)
77
#define SCG0                   (0x0040)
78
#define SCG1                   (0x0080)
79
 
80
/* Low Power Modes coded with Bits 4-7 in SR */
81
 
82
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
83
#define LPM0                   (CPUOFF)
84
#define LPM1                   (SCG0+CPUOFF)
85
#define LPM2                   (SCG1+CPUOFF)
86
#define LPM3                   (SCG1+SCG0+CPUOFF)
87
#define LPM4                   (SCG1+SCG0+OSCOFF+CPUOFF)
88
/* End #defines for assembler */
89
 
90
#else /* Begin #defines for C */
91
#define LPM0_bits              (CPUOFF)
92
#define LPM1_bits              (SCG0+CPUOFF)
93
#define LPM2_bits              (SCG1+CPUOFF)
94
#define LPM3_bits              (SCG1+SCG0+CPUOFF)
95
#define LPM4_bits              (SCG1+SCG0+OSCOFF+CPUOFF)
96
 
97
#include "in430.h"
98
 
99
#define LPM0         _bis_SR_register(LPM0_bits)         /* Enter Low Power Mode 0 */
100
#define LPM0_EXIT    _bic_SR_register_on_exit(LPM0_bits) /* Exit Low Power Mode 0 */
101
#define LPM1         _bis_SR_register(LPM1_bits)         /* Enter Low Power Mode 1 */
102
#define LPM1_EXIT    _bic_SR_register_on_exit(LPM1_bits) /* Exit Low Power Mode 1 */
103
#define LPM2         _bis_SR_register(LPM2_bits)         /* Enter Low Power Mode 2 */
104
#define LPM2_EXIT    _bic_SR_register_on_exit(LPM2_bits) /* Exit Low Power Mode 2 */
105
#define LPM3         _bis_SR_register(LPM3_bits)         /* Enter Low Power Mode 3 */
106
#define LPM3_EXIT    _bic_SR_register_on_exit(LPM3_bits) /* Exit Low Power Mode 3 */
107
#define LPM4         _bis_SR_register(LPM4_bits)         /* Enter Low Power Mode 4 */
108
#define LPM4_EXIT    _bic_SR_register_on_exit(LPM4_bits) /* Exit Low Power Mode 4 */
109
#endif /* End #defines for C */
110
 
111
/************************************************************
112
* CPU
113
************************************************************/
114
#define __MSP430_HAS_MSP430XV2_CPU__                /* Definition to show that it has MSP430XV2 CPU */
115
 
116
/************************************************************
117
* PERIPHERAL FILE MAP
118
************************************************************/
119
 
120
/************************************************************
121
* A-POOL
122
************************************************************/
123
#define __MSP430_HAS_APOOL__                  /* Definition to show that Module is available */
124
#define __MSP430_BASEADDRESS_APOOL__ 0x01A0
125
 
126
SFR_16BIT(APCNF);                             /* A-POOL Configuration Register */
127
SFR_8BIT(APCNF_L);                            /* A-POOL Configuration Register */
128
SFR_8BIT(APCNF_H);                            /* A-POOL Configuration Register */
129
SFR_16BIT(APCTL);                             /* A-POOL Control Register 1 */
130
SFR_8BIT(APCTL_L);                            /* A-POOL Control Register 1 */
131
SFR_8BIT(APCTL_H);                            /* A-POOL Control Register 1 */
132
SFR_16BIT(APOMR);                             /* A-POOL Operation Mode Register 2 */
133
SFR_8BIT(APOMR_L);                            /* A-POOL Operation Mode Register 2 */
134
SFR_8BIT(APOMR_H);                            /* A-POOL Operation Mode Register 2 */
135
SFR_16BIT(APVDIV);                            /* A-POOL Voltage Divider Register 3 */
136
SFR_8BIT(APVDIV_L);                           /* A-POOL Voltage Divider Register 3 */
137
SFR_8BIT(APVDIV_H);                           /* A-POOL Voltage Divider Register 3 */
138
SFR_16BIT(APTRIM);                            /* A-POOL trimming register */
139
SFR_8BIT(APTRIM_L);                           /* A-POOL trimming register */
140
SFR_8BIT(APTRIM_H);                           /* A-POOL trimming register */
141
SFR_16BIT(APINT);                             /* A-POOL Integer Conversion Register */
142
SFR_8BIT(APINT_L);                            /* A-POOL Integer Conversion Register */
143
SFR_8BIT(APINT_H);                            /* A-POOL Integer Conversion Register */
144
SFR_16BIT(APINTB);                            /* A-POOL Integer Conversion Buffer Register */
145
SFR_8BIT(APINTB_L);                           /* A-POOL Integer Conversion Buffer Register */
146
SFR_8BIT(APINTB_H);                           /* A-POOL Integer Conversion Buffer Register */
147
SFR_16BIT(APFRACT);                           /* A-POOL Fractional Conversion Register */
148
SFR_8BIT(APFRACT_L);                          /* A-POOL Fractional Conversion Register */
149
SFR_8BIT(APFRACT_H);                          /* A-POOL Fractional Conversion Register */
150
SFR_16BIT(APFRACTB);                          /* A-POOL Fractional Conversion Buffer Register */
151
SFR_8BIT(APFRACTB_L);                         /* A-POOL Fractional Conversion Buffer Register */
152
SFR_8BIT(APFRACTB_H);                         /* A-POOL Fractional Conversion Buffer Register */
153
SFR_16BIT(APIFG);                             /* A-POOL Interrupt Flag Register */
154
SFR_8BIT(APIFG_L);                            /* A-POOL Interrupt Flag Register */
155
SFR_8BIT(APIFG_H);                            /* A-POOL Interrupt Flag Register */
156
SFR_16BIT(APIE);                              /* A-POOL Interrupt Enable Register */
157
SFR_8BIT(APIE_L);                             /* A-POOL Interrupt Enable Register */
158
SFR_8BIT(APIE_H);                             /* A-POOL Interrupt Enable Register */
159
SFR_16BIT(APIV);                              /* A-POOL Interrupt Vector Word */
160
SFR_8BIT(APIV_L);                             /* A-POOL Interrupt Vector Word */
161
SFR_8BIT(APIV_H);                             /* A-POOL Interrupt Vector Word */
162
 
163
/* APCNF Control Bits */
164
#define TA0EN                  (0x0001)       /* A-POOL TimerA0 trigger enable */
165
#define TA1EN                  (0x0002)       /* A-POOL TimerA1 trigger enable */
166
#define DFSET0                 (0x0004)       /* A-POOL Deglitch Filter Bit: 0 */
167
#define DFSET1                 (0x0008)       /* A-POOL Deglitch Filter Bit: 1 */
168
#define LCMP                   (0x0010)       /* A-POOL Latch comparator */
169
#define CMPON                  (0x0020)       /* A-POOL Comparator enable */
170
#define DBON                   (0x0040)       /* A-POOL DAC buffer enable signal */
171
#define CONVON                 (0x0080)       /* A-POOL Enable for converter’s resistor ladder */
172
#define CLKSEL0                (0x0100)       /* A-POOL Conversion clock select Bit: 0 */
173
#define CLKSEL1                (0x0200)       /* A-POOL Conversion clock select Bit: 1 */
174
#define EOCBU                  (0x0400)       /* A-POOL Enable bit for loading conversion buffer */
175
#define ATBU                   (0x0800)       /* A-POOL Automatic update of conversion register */
176
#define A3PSEL                 (0x1000)       /* A-POOL Analog input A3 access Bit */
177
#define APREFON                (0x2000)       /* A-POOL Internal voltage reference enable */
178
#define VREFEN                 (0x4000)       /* A-POOL Reference voltage pin enable */
179
//#define RESERVED             (0x8000)  /* A-POOL */
180
 
181
/* APCNF Control Bits */
182
#define TA0EN_L                (0x0001)       /* A-POOL TimerA0 trigger enable */
183
#define TA1EN_L                (0x0002)       /* A-POOL TimerA1 trigger enable */
184
#define DFSET0_L               (0x0004)       /* A-POOL Deglitch Filter Bit: 0 */
185
#define DFSET1_L               (0x0008)       /* A-POOL Deglitch Filter Bit: 1 */
186
#define LCMP_L                 (0x0010)       /* A-POOL Latch comparator */
187
#define CMPON_L                (0x0020)       /* A-POOL Comparator enable */
188
#define DBON_L                 (0x0040)       /* A-POOL DAC buffer enable signal */
189
#define CONVON_L               (0x0080)       /* A-POOL Enable for converter’s resistor ladder */
190
//#define RESERVED             (0x8000)  /* A-POOL */
191
 
192
/* APCNF Control Bits */
193
#define CLKSEL0_H              (0x0001)       /* A-POOL Conversion clock select Bit: 0 */
194
#define CLKSEL1_H              (0x0002)       /* A-POOL Conversion clock select Bit: 1 */
195
#define EOCBU_H                (0x0004)       /* A-POOL Enable bit for loading conversion buffer */
196
#define ATBU_H                 (0x0008)       /* A-POOL Automatic update of conversion register */
197
#define A3PSEL_H               (0x0010)       /* A-POOL Analog input A3 access Bit */
198
#define APREFON_H              (0x0020)       /* A-POOL Internal voltage reference enable */
199
#define VREFEN_H               (0x0040)       /* A-POOL Reference voltage pin enable */
200
//#define RESERVED             (0x8000)  /* A-POOL */
201
 
202
#define DFSET_0                (0x0000)       /* A-POOL Deglitch Filter select: 0 */
203
#define DFSET_1                (0x0004)       /* A-POOL Deglitch Filter select: 1 */
204
#define DFSET_2                (0x0008)       /* A-POOL Deglitch Filter select: 2 */
205
#define DFSET_3                (0x000C)       /* A-POOL Deglitch Filter select: 3 */
206
 
207
#define CLKSEL_0               (0x0000)       /* A-POOL Conversion clock select: 0 */
208
#define CLKSEL_1               (0x0100)       /* A-POOL Conversion clock select: 1 */
209
#define CLKSEL_2               (0x0200)       /* A-POOL Conversion clock select: 2 */
210
#define CLKSEL_VLOCLK          (0x0000)       /* A-POOL Conversion clock select: VLOCLK */
211
#define CLKSEL_MCLK            (0x0100)       /* A-POOL Conversion clock select: MCLK */
212
#define CLKSEL_SMCLK           (0x0200)       /* A-POOL Conversion clock select: SMCLK */
213
 
214
/* APCTL Control Bits */
215
#define ODEN                   (0x0001)       /* A-POOL Output driver enable */
216
#define OSWP                   (0x0002)       /* A-POOL Output swap */
217
#define OSEL                   (0x0004)       /* A-POOL Output buffer select */
218
#define SLOPE                  (0x0008)       /* A-POOL Slope select of converter */
219
#define APNSEL0                (0x0010)       /* A-POOL Neg. Channel Input Select 0 */
220
#define APNSEL1                (0x0020)       /* A-POOL Neg. Channel Input Select 1 */
221
#define APNSEL2                (0x0040)       /* A-POOL Neg. Channel Input Select 2 */
222
#define APNSEL3                (0x0080)       /* A-POOL Neg. Channel Input Select 3 */
223
#define RUNSTOP                (0x0100)       /* A-POOL Converter’s Run/Stop bit */
224
#define SBSTP                  (0x0200)       /* A-POOL Saturation based conversion stop enable */
225
#define CBSTP                  (0x0400)       /* A-POOL Comparator based conversion stop enable */
226
#define TBSTP                  (0x0800)       /* A-POOL Timer based conversion stop enable for TimerA0 */
227
#define APPSEL0                (0x1000)       /* A-POOL Pos. Channel Input Select 0 */
228
#define APPSEL1                (0x2000)       /* A-POOL Pos. Channel Input Select 1 */
229
#define APPSEL2                (0x4000)       /* A-POOL Pos. Channel Input Select 2 */
230
#define APPSEL3                (0x8000)       /* A-POOL Pos. Channel Input Select 3 */
231
 
232
/* APCTL Control Bits */
233
#define ODEN_L                 (0x0001)       /* A-POOL Output driver enable */
234
#define OSWP_L                 (0x0002)       /* A-POOL Output swap */
235
#define OSEL_L                 (0x0004)       /* A-POOL Output buffer select */
236
#define SLOPE_L                (0x0008)       /* A-POOL Slope select of converter */
237
#define APNSEL0_L              (0x0010)       /* A-POOL Neg. Channel Input Select 0 */
238
#define APNSEL1_L              (0x0020)       /* A-POOL Neg. Channel Input Select 1 */
239
#define APNSEL2_L              (0x0040)       /* A-POOL Neg. Channel Input Select 2 */
240
#define APNSEL3_L              (0x0080)       /* A-POOL Neg. Channel Input Select 3 */
241
 
242
/* APCTL Control Bits */
243
#define RUNSTOP_H              (0x0001)       /* A-POOL Converter’s Run/Stop bit */
244
#define SBSTP_H                (0x0002)       /* A-POOL Saturation based conversion stop enable */
245
#define CBSTP_H                (0x0004)       /* A-POOL Comparator based conversion stop enable */
246
#define TBSTP_H                (0x0008)       /* A-POOL Timer based conversion stop enable for TimerA0 */
247
#define APPSEL0_H              (0x0010)       /* A-POOL Pos. Channel Input Select 0 */
248
#define APPSEL1_H              (0x0020)       /* A-POOL Pos. Channel Input Select 1 */
249
#define APPSEL2_H              (0x0040)       /* A-POOL Pos. Channel Input Select 2 */
250
#define APPSEL3_H              (0x0080)       /* A-POOL Pos. Channel Input Select 3 */
251
 
252
#define APNSEL_0               (0x0000)       /* A-POOL V- terminal Input Select: Channel 0 */
253
#define APNSEL_1               (0x0010)       /* A-POOL V- terminal Input Select: Channel 1 */
254
#define APNSEL_2               (0x0020)       /* A-POOL V- terminal Input Select: Channel 2 */
255
#define APNSEL_3               (0x0030)       /* A-POOL V- terminal Input Select: Channel 3 */
256
#define APNSEL_4               (0x0040)       /* A-POOL V- terminal Input Select: Channel 4 */
257
#define APNSEL_5               (0x0050)       /* A-POOL V- terminal Input Select: Channel 5 */
258
#define APNSEL_6               (0x0060)       /* A-POOL V- terminal Input Select: Channel 6 */
259
#define APNSEL_7               (0x0070)       /* A-POOL V- terminal Input Select: Channel 7 */
260
 
261
#define APPSEL_0               (0x0000)       /* A-POOL V+ Terminal Input Select: Channel 0 */
262
#define APPSEL_1               (0x1000)       /* A-POOL V+ Terminal Input Select: Channel 1 */
263
#define APPSEL_2               (0x2000)       /* A-POOL V+ Terminal Input Select: Channel 2 */
264
#define APPSEL_3               (0x3000)       /* A-POOL V+ Terminal Input Select: Channel 3 */
265
#define APPSEL_4               (0x4000)       /* A-POOL V+ Terminal Input Select: Channel 4 */
266
#define APPSEL_5               (0x5000)       /* A-POOL V+ Terminal Input Select: Channel 5 */
267
#define APPSEL_6               (0x6000)       /* A-POOL V+ Terminal Input Select: Channel 6 */
268
#define APPSEL_7               (0x7000)       /* A-POOL V+ Terminal Input Select: Channel 7 */
269
#define APPSEL_8               (0x8000)       /* A-POOL V+ Terminal Input Select: Channel 8 */
270
 
271
/* APVDIV Control Bits */
272
#define A0DIV                  (0x0001)       /* A-POOL Analog channel #0 voltage divider control */
273
#define A1DIV                  (0x0002)       /* A-POOL Analog channel #1 voltage divider control */
274
#define A2DIV0                 (0x0004)       /* A-POOL Analog channel #2 voltage divider control Bit : 0 */
275
#define A2DIV1                 (0x0008)       /* A-POOL Analog channel #2 voltage divider control Bit : 1 */
276
#define A3DIV0                 (0x0010)       /* A-POOL Analog channel #3 voltage divider control Bit : 0 */
277
#define A3DIV1                 (0x0020)       /* A-POOL Analog channel #3 voltage divider control Bit : 0 */
278
#define TMPSEN                 (0x0040)       /* A-POOL Temperature sensor enable */
279
#define VCCDIVEN               (0x0080)       /* A-POOL VCC voltage divider enable */
280
//#define RESERVED             (0x0100)  /* A-POOL */
281
//#define RESERVED             (0x0200)  /* A-POOL */
282
#define CLKTRIM0               (0x0400)       /* A-POOL Clock trimming Bit : 0 */
283
#define CLKTRIM1               (0x0800)       /* A-POOL Clock trimming Bit : 1 */
284
//#define RESERVED             (0x1000)  /* A-POOL */
285
//#define RESERVED             (0x2000)  /* A-POOL */
286
//#define RESERVED             (0x4000)  /* A-POOL */
287
//#define RESERVED             (0x8000)  /* A-POOL */
288
 
289
/* APVDIV Control Bits */
290
#define A0DIV_L                (0x0001)       /* A-POOL Analog channel #0 voltage divider control */
291
#define A1DIV_L                (0x0002)       /* A-POOL Analog channel #1 voltage divider control */
292
#define A2DIV0_L               (0x0004)       /* A-POOL Analog channel #2 voltage divider control Bit : 0 */
293
#define A2DIV1_L               (0x0008)       /* A-POOL Analog channel #2 voltage divider control Bit : 1 */
294
#define A3DIV0_L               (0x0010)       /* A-POOL Analog channel #3 voltage divider control Bit : 0 */
295
#define A3DIV1_L               (0x0020)       /* A-POOL Analog channel #3 voltage divider control Bit : 0 */
296
#define TMPSEN_L               (0x0040)       /* A-POOL Temperature sensor enable */
297
#define VCCDIVEN_L             (0x0080)       /* A-POOL VCC voltage divider enable */
298
//#define RESERVED             (0x0100)  /* A-POOL */
299
//#define RESERVED             (0x0200)  /* A-POOL */
300
//#define RESERVED             (0x1000)  /* A-POOL */
301
//#define RESERVED             (0x2000)  /* A-POOL */
302
//#define RESERVED             (0x4000)  /* A-POOL */
303
//#define RESERVED             (0x8000)  /* A-POOL */
304
 
305
/* APVDIV Control Bits */
306
//#define RESERVED             (0x0100)  /* A-POOL */
307
//#define RESERVED             (0x0200)  /* A-POOL */
308
#define CLKTRIM0_H             (0x0004)       /* A-POOL Clock trimming Bit : 0 */
309
#define CLKTRIM1_H             (0x0008)       /* A-POOL Clock trimming Bit : 1 */
310
//#define RESERVED             (0x1000)  /* A-POOL */
311
//#define RESERVED             (0x2000)  /* A-POOL */
312
//#define RESERVED             (0x4000)  /* A-POOL */
313
//#define RESERVED             (0x8000)  /* A-POOL */
314
 
315
#define A2DIV_0                (0x0000)       /* A-POOL Analog channel #2 voltage divider control: 0 */
316
#define A2DIV_1                (0x0004)       /* A-POOL Analog channel #2 voltage divider control: 1 */
317
#define A2DIV_2                (0x0008)       /* A-POOL Analog channel #2 voltage divider control: 2 */
318
#define A2DIV_3                (0x000C)       /* A-POOL Analog channel #2 voltage divider control: 3 */
319
 
320
#define A3DIV_0                (0x0000)       /* A-POOL Analog channel #3 voltage divider control: 0 */
321
#define A3DIV_1                (0x0010)       /* A-POOL Analog channel #3 voltage divider control: 1 */
322
#define A3DIV_2                (0x0020)       /* A-POOL Analog channel #3 voltage divider control: 2 */
323
#define A3DIV_3                (0x0030)       /* A-POOL Analog channel #3 voltage divider control: 3 */
324
 
325
#define CLKTRIM_0              (0x0000)       /* A-POOL Clock trimming: 0 */
326
#define CLKTRIM_1              (0x0400)       /* A-POOL Clock trimming: 1 */
327
#define CLKTRIM_2              (0x0800)       /* A-POOL Clock trimming: 2 */
328
#define CLKTRIM_3              (0x0C00)       /* A-POOL Clock trimming: 3 */
329
 
330
#define REFTRIM_0              (0x0000)       /* A-POOL Reference trimming: 0 */
331
#define REFTRIM_1              (0x1000)       /* A-POOL Reference trimming: 1 */
332
#define REFTRIM_2              (0x2000)       /* A-POOL Reference trimming: 2 */
333
#define REFTRIM_3              (0x3000)       /* A-POOL Reference trimming: 3 */
334
#define REFTRIM_4              (0x4000)       /* A-POOL Reference trimming: 4 */
335
#define REFTRIM_5              (0x5000)       /* A-POOL Reference trimming: 5 */
336
#define REFTRIM_6              (0x6000)       /* A-POOL Reference trimming: 6 */
337
#define REFTRIM_7              (0x7000)       /* A-POOL Reference trimming: 7 */
338
 
339
/* APTRIM Control Bits */
340
#define REFTSEL                (0x0001)       /* A-POOL Register bank used for the reference trimming */
341
#define REFTRIM0               (0x1000)       /* A-POOL Reference trimming bit: 0 */
342
#define REFTRIM1               (0x2000)       /* A-POOL Reference trimming bit: 1 */
343
#define REFTRIM2               (0x4000)       /* A-POOL Reference trimming bit: 2 */
344
#define REFTRIM3               (0x8000)       /* A-POOL Reference trimming bit: 3 */
345
 
346
/* APTRIM Control Bits */
347
#define REFTSEL_L              (0x0001)       /* A-POOL Register bank used for the reference trimming */
348
 
349
/* APTRIM Control Bits */
350
#define REFTRIM0_H             (0x0010)       /* A-POOL Reference trimming bit: 0 */
351
#define REFTRIM1_H             (0x0020)       /* A-POOL Reference trimming bit: 1 */
352
#define REFTRIM2_H             (0x0040)       /* A-POOL Reference trimming bit: 2 */
353
#define REFTRIM3_H             (0x0080)       /* A-POOL Reference trimming bit: 3 */
354
 
355
/* APOMR Control Bits */
356
#define CLKDIV0                (0x0001)       /* A-POOL Prescaler Control Bit: 0 */
357
#define CLKDIV1                (0x0002)       /* A-POOL Prescaler Control Bit: 1 */
358
#define CLKDIV2                (0x0004)       /* A-POOL Prescaler Control Bit: 2 */
359
#define SAREN                  (0x0008)       /* A-POOL SAR conversion enable */
360
#define CTEN                   (0x0100)       /* A-POOL Continuous time mode of comparator */
361
#define AZCMP                  (0x0200)       /* A-POOL Clocked zero compensated long term comparison */
362
#define AZSWREQ                (0x0400)       /* A-POOL SW request for Auto Zero Phase */
363
#define SVMINH                 (0x0800)       /* A-POOL Suppress the generation of an SVM interrupt event. */
364
 
365
/* APOMR Control Bits */
366
#define CLKDIV0_L              (0x0001)       /* A-POOL Prescaler Control Bit: 0 */
367
#define CLKDIV1_L              (0x0002)       /* A-POOL Prescaler Control Bit: 1 */
368
#define CLKDIV2_L              (0x0004)       /* A-POOL Prescaler Control Bit: 2 */
369
#define SAREN_L                (0x0008)       /* A-POOL SAR conversion enable */
370
 
371
/* APOMR Control Bits */
372
#define CTEN_H                 (0x0001)       /* A-POOL Continuous time mode of comparator */
373
#define AZCMP_H                (0x0002)       /* A-POOL Clocked zero compensated long term comparison */
374
#define AZSWREQ_H              (0x0004)       /* A-POOL SW request for Auto Zero Phase */
375
#define SVMINH_H               (0x0008)       /* A-POOL Suppress the generation of an SVM interrupt event. */
376
 
377
#define CLKDIV_0               (0x0000)       /* A-POOL Prescaler Control 0 : /1 */
378
#define CLKDIV_1               (0x0001)       /* A-POOL Prescaler Control 1 : /2 */
379
#define CLKDIV_2               (0x0002)       /* A-POOL Prescaler Control 2 : /4 */
380
#define CLKDIV_3               (0x0003)       /* A-POOL Prescaler Control 3 : /8 */
381
#define CLKDIV_4               (0x0004)       /* A-POOL Prescaler Control 4 : /16 */
382
#define CLKDIV_5               (0x0005)       /* A-POOL Prescaler Control 5 : /32 */
383
#define CLKDIV__1              (0x0000)       /* A-POOL Prescaler Control 0 : /1 */
384
#define CLKDIV__2              (0x0001)       /* A-POOL Prescaler Control 1 : /2 */
385
#define CLKDIV__4              (0x0002)       /* A-POOL Prescaler Control 2 : /4 */
386
#define CLKDIV__8              (0x0003)       /* A-POOL Prescaler Control 3 : /8 */
387
#define CLKDIV__16             (0x0004)       /* A-POOL Prescaler Control 4 : /16 */
388
#define CLKDIV__32             (0x0005)       /* A-POOL Prescaler Control 5 : /32 */
389
 
390
/* APIFG Control Bits */
391
#define EOCIFG                 (0x0001)       /* A-POOL End of conversion interrupt flag */
392
#define CFIFG                  (0x0002)       /* A-POOL Comparator falling edge interrupt flag */
393
#define CRIFG                  (0x0004)       /* A-POOL Comparator rising edge interrupt flag */
394
#define REFOKIFG               (0x0008)       /* A-POOL Reference voltage ready interrupt flag */
395
 
396
/* APIFG Control Bits */
397
#define EOCIFG_L               (0x0001)       /* A-POOL End of conversion interrupt flag */
398
#define CFIFG_L                (0x0002)       /* A-POOL Comparator falling edge interrupt flag */
399
#define CRIFG_L                (0x0004)       /* A-POOL Comparator rising edge interrupt flag */
400
#define REFOKIFG_L             (0x0008)       /* A-POOL Reference voltage ready interrupt flag */
401
 
402
/* APIFG Control Bits */
403
 
404
/* APIFG Control Bits */
405
#define EOCIE                  (0x0001)       /* A-POOL End of conversion interrupt enable */
406
#define CFIE                   (0x0002)       /* A-POOL Comparator falling edge interrupt enable */
407
#define CRIE                   (0x0004)       /* A-POOL Comparator rising edge interrupt enable */
408
#define REFIKIE                (0x0008)       /* A-POOL Reference voltage ready interrupt enable */
409
 
410
/* APIFG Control Bits */
411
#define EOCIE_L                (0x0001)       /* A-POOL End of conversion interrupt enable */
412
#define CFIE_L                 (0x0002)       /* A-POOL Comparator falling edge interrupt enable */
413
#define CRIE_L                 (0x0004)       /* A-POOL Comparator rising edge interrupt enable */
414
#define REFIKIE_L              (0x0008)       /* A-POOL Reference voltage ready interrupt enable */
415
 
416
/* APIFG Control Bits */
417
 
418
/* APIV Definitions */
419
#define APIV_NONE              (0x0000)       /* No Interrupt pending */
420
#define APIV_EOCIF             (0x0002)       /* EOCIFG */
421
#define APIV_CFIFG             (0x0004)       /* CFIFG */
422
#define APIV_CRIFG             (0x0006)       /* CRIFG */
423
 
424
/************************************************************
425
* COMPACT CLOCK SYSTEM
426
************************************************************/
427
#define __MSP430_HAS_CCS__                    /* Definition to show that Module is available */
428
#define __MSP430_BASEADDRESS_CCS__ 0x0160
429
 
430
SFR_16BIT(CCSCTL0);                           /* CCS Control Register 0 */
431
SFR_8BIT(CCSCTL0_L);                          /* CCS Control Register 0 */
432
SFR_8BIT(CCSCTL0_H);                          /* CCS Control Register 0 */
433
SFR_16BIT(CCSCTL1);                           /* CCS Control Register 1 */
434
SFR_8BIT(CCSCTL1_L);                          /* CCS Control Register 1 */
435
SFR_8BIT(CCSCTL1_H);                          /* CCS Control Register 1 */
436
SFR_16BIT(CCSCTL2);                           /* CCS Control Register 2 */
437
SFR_8BIT(CCSCTL2_L);                          /* CCS Control Register 2 */
438
SFR_8BIT(CCSCTL2_H);                          /* CCS Control Register 2 */
439
SFR_16BIT(CCSCTL4);                           /* CCS Control Register 4 */
440
SFR_8BIT(CCSCTL4_L);                          /* CCS Control Register 4 */
441
SFR_8BIT(CCSCTL4_H);                          /* CCS Control Register 4 */
442
SFR_16BIT(CCSCTL5);                           /* CCS Control Register 5 */
443
SFR_8BIT(CCSCTL5_L);                          /* CCS Control Register 5 */
444
SFR_8BIT(CCSCTL5_H);                          /* CCS Control Register 5 */
445
SFR_16BIT(CCSCTL6);                           /* CCS Control Register 6 */
446
SFR_8BIT(CCSCTL6_L);                          /* CCS Control Register 6 */
447
SFR_8BIT(CCSCTL6_H);                          /* CCS Control Register 6 */
448
SFR_16BIT(CCSCTL7);                           /* CCS Control Register 7 */
449
SFR_8BIT(CCSCTL7_L);                          /* CCS Control Register 7 */
450
SFR_8BIT(CCSCTL7_H);                          /* CCS Control Register 7 */
451
SFR_16BIT(CCSCTL8);                           /* CCS Control Register 8 */
452
SFR_8BIT(CCSCTL8_L);                          /* CCS Control Register 8 */
453
SFR_8BIT(CCSCTL8_H);                          /* CCS Control Register 8 */
454
 
455
/* CCSCTL0 Control Bits */
456
 
457
/* CCSCTL0 Control Bits */
458
 
459
/* CCSCTL0 Control Bits */
460
#define CCSKEY                 (0xA500)       /* CCS Password */
461
 
462
/* CCSCTL1 Control Bits */
463
#define DIVCLK                 (0x0001)       /* Clock division for CLKIN / X-OSC */
464
 
465
/* CCSCTL1 Control Bits */
466
#define DIVCLK_L               (0x0001)       /* Clock division for CLKIN / X-OSC */
467
 
468
/* CCSCTL1 Control Bits */
469
 
470
/* CCSCTL2 Control Bits */
471
#define FSEL0                  (0x0001)       /* Frequency trimming of the HF-OSC Bit: 0 */
472
#define FSEL1                  (0x0002)       /* Frequency trimming of the HF-OSC Bit: 1 */
473
#define FSEL2                  (0x0004)       /* Frequency trimming of the HF-OSC Bit: 2 */
474
#define FSEL3                  (0x0008)       /* Frequency trimming of the HF-OSC Bit: 3 */
475
#define FSEL4                  (0x0010)       /* Frequency trimming of the HF-OSC Bit: 4 */
476
#define FSEL5                  (0x0020)       /* Frequency trimming of the HF-OSC Bit: 5 */
477
#define FSEL6                  (0x0040)       /* Frequency trimming of the HF-OSC Bit: 6 */
478
 
479
/* CCSCTL2 Control Bits */
480
#define FSEL0_L                (0x0001)       /* Frequency trimming of the HF-OSC Bit: 0 */
481
#define FSEL1_L                (0x0002)       /* Frequency trimming of the HF-OSC Bit: 1 */
482
#define FSEL2_L                (0x0004)       /* Frequency trimming of the HF-OSC Bit: 2 */
483
#define FSEL3_L                (0x0008)       /* Frequency trimming of the HF-OSC Bit: 3 */
484
#define FSEL4_L                (0x0010)       /* Frequency trimming of the HF-OSC Bit: 4 */
485
#define FSEL5_L                (0x0020)       /* Frequency trimming of the HF-OSC Bit: 5 */
486
#define FSEL6_L                (0x0040)       /* Frequency trimming of the HF-OSC Bit: 6 */
487
 
488
/* CCSCTL2 Control Bits */
489
 
490
/* CCSCTL4 Control Bits */
491
#define SELM0                  (0x0001)       /* MCLK Source Select Bit: 0 */
492
#define SELM1                  (0x0002)       /* MCLK Source Select Bit: 1 */
493
//#define RESERVED            (0x0004)    /* RESERVED */
494
//#define RESERVED            (0x0008)    /* RESERVED */
495
#define SELS0                  (0x0010)       /* SMCLK Source Select Bit: 0 */
496
#define SELS1                  (0x0020)       /* SMCLK Source Select Bit: 1 */
497
//#define RESERVED            (0x0040)    /* RESERVED */
498
//#define RESERVED            (0x0080)    /* RESERVED */
499
#define SELA0                  (0x0100)       /* ACLK Source Select Bit: 0 */
500
#define SELA1                  (0x0200)       /* ACLK Source Select Bit: 1 */
501
//#define RESERVED            (0x0400)    /* RESERVED */
502
//#define RESERVED            (0x0800)    /* RESERVED */
503
//#define RESERVED            (0x1000)    /* RESERVED */
504
//#define RESERVED            (0x2000)    /* RESERVED */
505
//#define RESERVED            (0x4000)    /* RESERVED */
506
//#define RESERVED            (0x8000)    /* RESERVED */
507
 
508
/* CCSCTL4 Control Bits */
509
#define SELM0_L                (0x0001)       /* MCLK Source Select Bit: 0 */
510
#define SELM1_L                (0x0002)       /* MCLK Source Select Bit: 1 */
511
//#define RESERVED            (0x0004)    /* RESERVED */
512
//#define RESERVED            (0x0008)    /* RESERVED */
513
#define SELS0_L                (0x0010)       /* SMCLK Source Select Bit: 0 */
514
#define SELS1_L                (0x0020)       /* SMCLK Source Select Bit: 1 */
515
//#define RESERVED            (0x0040)    /* RESERVED */
516
//#define RESERVED            (0x0080)    /* RESERVED */
517
//#define RESERVED            (0x0400)    /* RESERVED */
518
//#define RESERVED            (0x0800)    /* RESERVED */
519
//#define RESERVED            (0x1000)    /* RESERVED */
520
//#define RESERVED            (0x2000)    /* RESERVED */
521
//#define RESERVED            (0x4000)    /* RESERVED */
522
//#define RESERVED            (0x8000)    /* RESERVED */
523
 
524
/* CCSCTL4 Control Bits */
525
//#define RESERVED            (0x0004)    /* RESERVED */
526
//#define RESERVED            (0x0008)    /* RESERVED */
527
//#define RESERVED            (0x0040)    /* RESERVED */
528
//#define RESERVED            (0x0080)    /* RESERVED */
529
#define SELA0_H                (0x0001)       /* ACLK Source Select Bit: 0 */
530
#define SELA1_H                (0x0002)       /* ACLK Source Select Bit: 1 */
531
//#define RESERVED            (0x0400)    /* RESERVED */
532
//#define RESERVED            (0x0800)    /* RESERVED */
533
//#define RESERVED            (0x1000)    /* RESERVED */
534
//#define RESERVED            (0x2000)    /* RESERVED */
535
//#define RESERVED            (0x4000)    /* RESERVED */
536
//#define RESERVED            (0x8000)    /* RESERVED */
537
 
538
#define SELM_0                 (0x0000)       /* MCLK Source Select 0 */
539
#define SELM_1                 (0x0001)       /* MCLK Source Select 1 */
540
#define SELM_2                 (0x0002)       /* MCLK Source Select 2 */
541
#define SELM_3                 (0x0003)       /* MCLK Source Select 3 */
542
#define SELM__HFCLK            (0x0000)       /* MCLK Source Select HFCLK */
543
#define SELM__LFCLK            (0x0001)       /* MCLK Source Select LFCLK */
544
#define SELM__CLKIN            (0x0002)       /* MCLK Source Select CLKIN */
545
 
546
#define SELS_0                 (0x0000)       /* SMCLK Source Select 0 */
547
#define SELS_1                 (0x0010)       /* SMCLK Source Select 1 */
548
#define SELS_2                 (0x0020)       /* SMCLK Source Select 2 */
549
#define SELS_3                 (0x0030)       /* SMCLK Source Select 3 */
550
#define SELS__HFCLK            (0x0000)       /* SMCLK Source Select HFCLK */
551
#define SELS__LFCLK            (0x0010)       /* SMCLK Source Select LFCLK */
552
#define SELS__CLKIN            (0x0020)       /* SMCLK Source Select CLKIN */
553
 
554
#define SELA_0                 (0x0000)       /* ACLK Source Select 0 */
555
#define SELA_1                 (0x0100)       /* ACLK Source Select 1 */
556
#define SELA_2                 (0x0200)       /* ACLK Source Select 2 */
557
#define SELA_3                 (0x0300)       /* ACLK Source Select 3 */
558
#define SELA__HFCLK            (0x0000)       /* ACLK Source Select HFCLK */
559
#define SELA__LFCLK            (0x0100)       /* ACLK Source Select LFCLK */
560
#define SELA__CLKIN            (0x0200)       /* ACLK Source Select CLKIN */
561
 
562
/* CCSCTL5 Control Bits */
563
#define DIVM0                  (0x0001)       /* MCLK Divider Bit: 0 */
564
#define DIVM1                  (0x0002)       /* MCLK Divider Bit: 1 */
565
#define DIVM2                  (0x0004)       /* MCLK Divider Bit: 2 */
566
//#define RESERVED            (0x0004)    /* RESERVED */
567
//#define RESERVED            (0x0008)    /* RESERVED */
568
#define DIVS0                  (0x0010)       /* SMCLK Divider Bit: 0 */
569
#define DIVS1                  (0x0020)       /* SMCLK Divider Bit: 1 */
570
#define DIVS2                  (0x0040)       /* SMCLK Divider Bit: 2 */
571
//#define RESERVED            (0x0040)    /* RESERVED */
572
//#define RESERVED            (0x0080)    /* RESERVED */
573
#define DIVA0                  (0x0100)       /* ACLK Divider Bit: 0 */
574
#define DIVA1                  (0x0200)       /* ACLK Divider Bit: 1 */
575
#define DIVA2                  (0x0400)       /* ACLK Divider Bit: 2 */
576
//#define RESERVED            (0x0400)    /* RESERVED */
577
//#define RESERVED            (0x0800)    /* RESERVED */
578
//#define RESERVED            (0x1000)    /* RESERVED */
579
//#define RESERVED            (0x2000)    /* RESERVED */
580
//#define RESERVED            (0x4000)    /* RESERVED */
581
//#define RESERVED            (0x8000)    /* RESERVED */
582
 
583
/* CCSCTL5 Control Bits */
584
#define DIVM0_L                (0x0001)       /* MCLK Divider Bit: 0 */
585
#define DIVM1_L                (0x0002)       /* MCLK Divider Bit: 1 */
586
#define DIVM2_L                (0x0004)       /* MCLK Divider Bit: 2 */
587
//#define RESERVED            (0x0004)    /* RESERVED */
588
//#define RESERVED            (0x0008)    /* RESERVED */
589
#define DIVS0_L                (0x0010)       /* SMCLK Divider Bit: 0 */
590
#define DIVS1_L                (0x0020)       /* SMCLK Divider Bit: 1 */
591
#define DIVS2_L                (0x0040)       /* SMCLK Divider Bit: 2 */
592
//#define RESERVED            (0x0040)    /* RESERVED */
593
//#define RESERVED            (0x0080)    /* RESERVED */
594
//#define RESERVED            (0x0400)    /* RESERVED */
595
//#define RESERVED            (0x0800)    /* RESERVED */
596
//#define RESERVED            (0x1000)    /* RESERVED */
597
//#define RESERVED            (0x2000)    /* RESERVED */
598
//#define RESERVED            (0x4000)    /* RESERVED */
599
//#define RESERVED            (0x8000)    /* RESERVED */
600
 
601
/* CCSCTL5 Control Bits */
602
//#define RESERVED            (0x0004)    /* RESERVED */
603
//#define RESERVED            (0x0008)    /* RESERVED */
604
//#define RESERVED            (0x0040)    /* RESERVED */
605
//#define RESERVED            (0x0080)    /* RESERVED */
606
#define DIVA0_H                (0x0001)       /* ACLK Divider Bit: 0 */
607
#define DIVA1_H                (0x0002)       /* ACLK Divider Bit: 1 */
608
#define DIVA2_H                (0x0004)       /* ACLK Divider Bit: 2 */
609
//#define RESERVED            (0x0400)    /* RESERVED */
610
//#define RESERVED            (0x0800)    /* RESERVED */
611
//#define RESERVED            (0x1000)    /* RESERVED */
612
//#define RESERVED            (0x2000)    /* RESERVED */
613
//#define RESERVED            (0x4000)    /* RESERVED */
614
//#define RESERVED            (0x8000)    /* RESERVED */
615
 
616
#define DIVM_0                 (0x0000)       /* MCLK Source Divider 0 */
617
#define DIVM_1                 (0x0001)       /* MCLK Source Divider 1 */
618
#define DIVM_2                 (0x0002)       /* MCLK Source Divider 2 */
619
#define DIVM_3                 (0x0003)       /* MCLK Source Divider 3 */
620
#define DIVM_4                 (0x0004)       /* MCLK Source Divider 4 */
621
#define DIVM_5                 (0x0005)       /* MCLK Source Divider 5 */
622
#define DIVM__1                (0x0000)       /* MCLK Source Divider f(MCLK)/1 */
623
#define DIVM__2                (0x0001)       /* MCLK Source Divider f(MCLK)/2 */
624
#define DIVM__4                (0x0002)       /* MCLK Source Divider f(MCLK)/4 */
625
#define DIVM__8                (0x0003)       /* MCLK Source Divider f(MCLK)/8 */
626
#define DIVM__16               (0x0004)       /* MCLK Source Divider f(MCLK)/16 */
627
#define DIVM__32               (0x0005)       /* MCLK Source Divider f(MCLK)/32 */
628
 
629
#define DIVS_0                 (0x0000)       /* SMCLK Source Divider 0 */
630
#define DIVS_1                 (0x0010)       /* SMCLK Source Divider 1 */
631
#define DIVS_2                 (0x0020)       /* SMCLK Source Divider 2 */
632
#define DIVS_3                 (0x0030)       /* SMCLK Source Divider 3 */
633
#define DIVS_4                 (0x0040)       /* SMCLK Source Divider 4 */
634
#define DIVS_5                 (0x0050)       /* SMCLK Source Divider 5 */
635
#define DIVS__1                (0x0000)       /* SMCLK Source Divider f(SMCLK)/1 */
636
#define DIVS__2                (0x0010)       /* SMCLK Source Divider f(SMCLK)/2 */
637
#define DIVS__4                (0x0020)       /* SMCLK Source Divider f(SMCLK)/4 */
638
#define DIVS__8                (0x0030)       /* SMCLK Source Divider f(SMCLK)/8 */
639
#define DIVS__16               (0x0040)       /* SMCLK Source Divider f(SMCLK)/16 */
640
#define DIVS__32               (0x0050)       /* SMCLK Source Divider f(SMCLK)/32 */
641
 
642
#define DIVA_0                 (0x0000)       /* ACLK Source Divider 0 */
643
#define DIVA_1                 (0x0100)       /* ACLK Source Divider 1 */
644
#define DIVA_2                 (0x0200)       /* ACLK Source Divider 2 */
645
#define DIVA_3                 (0x0300)       /* ACLK Source Divider 3 */
646
#define DIVA_4                 (0x0400)       /* ACLK Source Divider 4 */
647
#define DIVA_5                 (0x0500)       /* ACLK Source Divider 5 */
648
#define DIVA__1                (0x0000)       /* ACLK Source Divider f(ACLK)/1 */
649
#define DIVA__2                (0x0100)       /* ACLK Source Divider f(ACLK)/2 */
650
#define DIVA__4                (0x0200)       /* ACLK Source Divider f(ACLK)/4 */
651
#define DIVA__8                (0x0300)       /* ACLK Source Divider f(ACLK)/8 */
652
#define DIVA__16               (0x0400)       /* ACLK Source Divider f(ACLK)/16 */
653
#define DIVA__32               (0x0500)       /* ACLK Source Divider f(ACLK)/32 */
654
 
655
/* CCSCTL6 Control Bits */
656
#define XTOFF                  (0x0001)       /* Disable XT oscillator */
657
 
658
/* CCSCTL6 Control Bits */
659
#define XTOFF_L                (0x0001)       /* Disable XT oscillator */
660
 
661
/* CCSCTL6 Control Bits */
662
 
663
/* CCSCTL7 Control Bits */
664
#define XOFFG                  (0x0001)       /* X-tal Oscillator Fault Flag */
665
#define HFOFFG                 (0x0002)       /* High Frequency Oscillator Fault Flag */
666
 
667
/* CCSCTL7 Control Bits */
668
#define XOFFG_L                (0x0001)       /* X-tal Oscillator Fault Flag */
669
#define HFOFFG_L               (0x0002)       /* High Frequency Oscillator Fault Flag */
670
 
671
/* CCSCTL7 Control Bits */
672
 
673
/* CCSCTL8 Control Bits */
674
#define ACLKREQEN              (0x0001)       /* ACLK Clock Request Enable */
675
#define MCLKREQEN              (0x0002)       /* MCLK Clock Request Enable */
676
#define SMCLKREQEN             (0x0004)       /* SMCLK Clock Request Enable */
677
 
678
/* CCSCTL8 Control Bits */
679
#define ACLKREQEN_L            (0x0001)       /* ACLK Clock Request Enable */
680
#define MCLKREQEN_L            (0x0002)       /* MCLK Clock Request Enable */
681
#define SMCLKREQEN_L           (0x0004)       /* SMCLK Clock Request Enable */
682
 
683
/* CCSCTL8 Control Bits */
684
 
685
/************************************************************
686
* DIGITAL I/O Port1/2 Pull up / Pull down Resistors
687
************************************************************/
688
#define __MSP430_HAS_PORT1_R__                /* Definition to show that Module is available */
689
#define __MSP430_BASEADDRESS_PORT1_R__ 0x0200
690
#define __MSP430_HAS_PORT2_R__                /* Definition to show that Module is available */
691
#define __MSP430_BASEADDRESS_PORT2_R__ 0x0200
692
#define __MSP430_HAS_PORTA_R__                /* Definition to show that Module is available */
693
#define __MSP430_BASEADDRESS_PORTA_R__ 0x0200
694
 
695
SFR_16BIT(PAIN);                              /* Port A Input */
696
SFR_8BIT(PAIN_L);                             /* Port A Input */
697
SFR_8BIT(PAIN_H);                             /* Port A Input */
698
SFR_16BIT(PAOUT);                             /* Port A Output */
699
SFR_8BIT(PAOUT_L);                            /* Port A Output */
700
SFR_8BIT(PAOUT_H);                            /* Port A Output */
701
SFR_16BIT(PADIR);                             /* Port A Direction */
702
SFR_8BIT(PADIR_L);                            /* Port A Direction */
703
SFR_8BIT(PADIR_H);                            /* Port A Direction */
704
SFR_16BIT(PAREN);                             /* Port A Resistor Enable */
705
SFR_8BIT(PAREN_L);                            /* Port A Resistor Enable */
706
SFR_8BIT(PAREN_H);                            /* Port A Resistor Enable */
707
SFR_16BIT(PADS);                              /* Port A Resistor Drive Strenght */
708
SFR_8BIT(PADS_L);                             /* Port A Resistor Drive Strenght */
709
SFR_8BIT(PADS_H);                             /* Port A Resistor Drive Strenght */
710
SFR_16BIT(PASEL0);                            /* Port A Selection 0 */
711
SFR_8BIT(PASEL0_L);                           /* Port A Selection 0 */
712
SFR_8BIT(PASEL0_H);                           /* Port A Selection 0 */
713
SFR_16BIT(PASEL1);                            /* Port A Selection 1 */
714
SFR_8BIT(PASEL1_L);                           /* Port A Selection 1 */
715
SFR_8BIT(PASEL1_H);                           /* Port A Selection 1 */
716
SFR_16BIT(PAIES);                             /* Port A Interrupt Edge Select */
717
SFR_8BIT(PAIES_L);                            /* Port A Interrupt Edge Select */
718
SFR_8BIT(PAIES_H);                            /* Port A Interrupt Edge Select */
719
SFR_16BIT(PAIE);                              /* Port A Interrupt Enable */
720
SFR_8BIT(PAIE_L);                             /* Port A Interrupt Enable */
721
SFR_8BIT(PAIE_H);                             /* Port A Interrupt Enable */
722
SFR_16BIT(PAIFG);                             /* Port A Interrupt Flag */
723
SFR_8BIT(PAIFG_L);                            /* Port A Interrupt Flag */
724
SFR_8BIT(PAIFG_H);                            /* Port A Interrupt Flag */
725
 
726
 
727
SFR_16BIT(P1IV);                              /* Port 1 Interrupt Vector Word */
728
SFR_16BIT(P2IV);                              /* Port 2 Interrupt Vector Word */
729
#define P1IN                   (PAIN_L)       /* Port 1 Input */
730
#define P1OUT                  (PAOUT_L)      /* Port 1 Output */
731
#define P1DIR                  (PADIR_L)      /* Port 1 Direction */
732
#define P1REN                  (PAREN_L)      /* Port 1 Resistor Enable */
733
#define P1DS                   (PADS_L)       /* Port 1 Resistor Drive Strenght */
734
#define P1SEL0                 (PASEL0_L)     /* Port 1 Selection 0 */
735
#define P1SEL1                 (PASEL1_L)     /* Port 1 Selection 1 */
736
#define P1IES                  (PAIES_L)      /* Port 1 Interrupt Edge Select */
737
#define P1IE                   (PAIE_L)       /* Port 1 Interrupt Enable */
738
#define P1IFG                  (PAIFG_L)      /* Port 1 Interrupt Flag */
739
 
740
//Definitions for P1IV
741
#define P1IV_NONE              (0x0000)       /* No Interrupt pending */
742
#define P1IV_P1IFG0            (0x0002)       /* P1IV P1IFG.0 */
743
#define P1IV_P1IFG1            (0x0004)       /* P1IV P1IFG.1 */
744
#define P1IV_P1IFG2            (0x0006)       /* P1IV P1IFG.2 */
745
#define P1IV_P1IFG3            (0x0008)       /* P1IV P1IFG.3 */
746
#define P1IV_P1IFG4            (0x000A)       /* P1IV P1IFG.4 */
747
#define P1IV_P1IFG5            (0x000C)       /* P1IV P1IFG.5 */
748
#define P1IV_P1IFG6            (0x000E)       /* P1IV P1IFG.6 */
749
#define P1IV_P1IFG7            (0x0010)       /* P1IV P1IFG.7 */
750
 
751
#define P2IN                   (PAIN_H)       /* Port 2 Input */
752
#define P2OUT                  (PAOUT_H)      /* Port 2 Output */
753
#define P2DIR                  (PADIR_H)      /* Port 2 Direction */
754
#define P2REN                  (PAREN_H)      /* Port 2 Resistor Enable */
755
#define P2DS                   (PADS_H)       /* Port 2 Resistor Drive Strenght */
756
#define P2SEL0                 (PASEL0_H)     /* Port 2 Selection 0 */
757
#define P2SEL1                 (PASEL1_H)     /* Port 2 Selection 1 */
758
#define P2IES                  (PAIES_H)      /* Port 2 Interrupt Edge Select */
759
#define P2IE                   (PAIE_H)       /* Port 2 Interrupt Enable */
760
#define P2IFG                  (PAIFG_H)      /* Port 2 Interrupt Flag */
761
 
762
//Definitions for P2IV
763
#define P2IV_NONE              (0x0000)       /* No Interrupt pending */
764
#define P2IV_P2IFG0            (0x0002)       /* P2IV P2IFG.0 */
765
#define P2IV_P2IFG1            (0x0004)       /* P2IV P2IFG.1 */
766
#define P2IV_P2IFG2            (0x0006)       /* P2IV P2IFG.2 */
767
#define P2IV_P2IFG3            (0x0008)       /* P2IV P2IFG.3 */
768
#define P2IV_P2IFG4            (0x000A)       /* P2IV P2IFG.4 */
769
#define P2IV_P2IFG5            (0x000C)       /* P2IV P2IFG.5 */
770
#define P2IV_P2IFG6            (0x000E)       /* P2IV P2IFG.6 */
771
#define P2IV_P2IFG7            (0x0010)       /* P2IV P2IFG.7 */
772
 
773
 
774
/************************************************************
775
* SFR - Special Function Register Module
776
************************************************************/
777
#define __MSP430_HAS_SFR__                    /* Definition to show that Module is available */
778
#define __MSP430_BASEADDRESS_SFR__ 0x0100
779
 
780
SFR_16BIT(SFRIE1);                            /* Interrupt Enable 1 */
781
SFR_8BIT(SFRIE1_L);                           /* Interrupt Enable 1 */
782
SFR_8BIT(SFRIE1_H);                           /* Interrupt Enable 1 */
783
 
784
/* SFRIE1 Control Bits */
785
#define WDTIE                  (0x0001)       /* WDT Interrupt Enable */
786
#define OFIE                   (0x0002)       /* Osc Fault Enable */
787
//#define Reserved          (0x0004)
788
#define VMAIE                  (0x0008)       /* Vacant Memory Interrupt Enable */
789
#define NMIIE                  (0x0010)       /* NMI Interrupt Enable */
790
#define JMBINIE                (0x0040)       /* JTAG Mail Box input Interrupt Enable */
791
#define JMBOUTIE               (0x0080)       /* JTAG Mail Box output Interrupt Enable */
792
#define SVMIE                  (0x0100)       /* SVM Interrupt Enable */
793
 
794
#define WDTIE_L                (0x0001)       /* WDT Interrupt Enable */
795
#define OFIE_L                 (0x0002)       /* Osc Fault Enable */
796
//#define Reserved          (0x0004)
797
#define VMAIE_L                (0x0008)       /* Vacant Memory Interrupt Enable */
798
#define NMIIE_L                (0x0010)       /* NMI Interrupt Enable */
799
#define JMBINIE_L              (0x0040)       /* JTAG Mail Box input Interrupt Enable */
800
#define JMBOUTIE_L             (0x0080)       /* JTAG Mail Box output Interrupt Enable */
801
 
802
//#define Reserved          (0x0004)
803
#define SVMIE_H                (0x0001)       /* SVM Interrupt Enable */
804
 
805
SFR_16BIT(SFRIFG1);                           /* Interrupt Flag 1 */
806
SFR_8BIT(SFRIFG1_L);                          /* Interrupt Flag 1 */
807
SFR_8BIT(SFRIFG1_H);                          /* Interrupt Flag 1 */
808
/* SFRIFG1 Control Bits */
809
#define WDTIFG                 (0x0001)       /* WDT Interrupt Flag */
810
#define OFIFG                  (0x0002)       /* Osc Fault Flag */
811
//#define Reserved          (0x0004)
812
#define VMAIFG                 (0x0008)       /* Vacant Memory Interrupt Flag */
813
#define NMIIFG                 (0x0010)       /* NMI Interrupt Flag */
814
//#define Reserved          (0x0020)
815
#define JMBINIFG               (0x0040)       /* JTAG Mail Box input Interrupt Flag */
816
#define JMBOUTIFG              (0x0080)       /* JTAG Mail Box output Interrupt Flag */
817
#define SVMIFG                 (0x0100)       /* SVM Interrupt Flag */
818
 
819
#define WDTIFG_L               (0x0001)       /* WDT Interrupt Flag */
820
#define OFIFG_L                (0x0002)       /* Osc Fault Flag */
821
//#define Reserved          (0x0004)
822
#define VMAIFG_L               (0x0008)       /* Vacant Memory Interrupt Flag */
823
#define NMIIFG_L               (0x0010)       /* NMI Interrupt Flag */
824
//#define Reserved          (0x0020)
825
#define JMBINIFG_L             (0x0040)       /* JTAG Mail Box input Interrupt Flag */
826
#define JMBOUTIFG_L            (0x0080)       /* JTAG Mail Box output Interrupt Flag */
827
 
828
//#define Reserved          (0x0004)
829
//#define Reserved          (0x0020)
830
#define SVMIFG_H               (0x0001)       /* SVM Interrupt Flag */
831
 
832
SFR_16BIT(SFRRPCR);                           /* RESET Pin Control Register */
833
SFR_8BIT(SFRRPCR_L);                          /* RESET Pin Control Register */
834
SFR_8BIT(SFRRPCR_H);                          /* RESET Pin Control Register */
835
/* SFRRPCR Control Bits */
836
#define SYSNMI                 (0x0001)       /* NMI select */
837
#define SYSNMIIES              (0x0002)       /* NMI edge select */
838
#define SYSRSTUP               (0x0004)       /* RESET Pin pull down/up select */
839
#define SYSRSTRE               (0x0008)       /* RESET Pin Resistor enable */
840
 
841
#define SYSNMI_L               (0x0001)       /* NMI select */
842
#define SYSNMIIES_L            (0x0002)       /* NMI edge select */
843
#define SYSRSTUP_L             (0x0004)       /* RESET Pin pull down/up select */
844
#define SYSRSTRE_L             (0x0008)       /* RESET Pin Resistor enable */
845
 
846
/************************************************************
847
* COMPACT SYS - System Module
848
************************************************************/
849
#define __MSP430_HAS_SYS__                    /* Definition to show that Module is available */
850
#define __MSP430_BASEADDRESS_SYS__ 0x0180
851
 
852
SFR_16BIT(SYSCTL);                            /* System control */
853
SFR_8BIT(SYSCTL_L);                           /* System control */
854
SFR_8BIT(SYSCTL_H);                           /* System control */
855
SFR_16BIT(SYSBSLC);                           /* Boot strap configuration area */
856
SFR_8BIT(SYSBSLC_L);                          /* Boot strap configuration area */
857
SFR_8BIT(SYSBSLC_H);                          /* Boot strap configuration area */
858
SFR_16BIT(SYSJMBC);                           /* JTAG mailbox control */
859
SFR_8BIT(SYSJMBC_L);                          /* JTAG mailbox control */
860
SFR_8BIT(SYSJMBC_H);                          /* JTAG mailbox control */
861
SFR_16BIT(SYSJMBI0);                          /* JTAG mailbox input 0 */
862
SFR_8BIT(SYSJMBI0_L);                         /* JTAG mailbox input 0 */
863
SFR_8BIT(SYSJMBI0_H);                         /* JTAG mailbox input 0 */
864
SFR_16BIT(SYSJMBI1);                          /* JTAG mailbox input 1 */
865
SFR_8BIT(SYSJMBI1_L);                         /* JTAG mailbox input 1 */
866
SFR_8BIT(SYSJMBI1_H);                         /* JTAG mailbox input 1 */
867
SFR_16BIT(SYSJMBO0);                          /* JTAG mailbox output 0 */
868
SFR_8BIT(SYSJMBO0_L);                         /* JTAG mailbox output 0 */
869
SFR_8BIT(SYSJMBO0_H);                         /* JTAG mailbox output 0 */
870
SFR_16BIT(SYSJMBO1);                          /* JTAG mailbox output 1 */
871
SFR_8BIT(SYSJMBO1_L);                         /* JTAG mailbox output 1 */
872
SFR_8BIT(SYSJMBO1_H);                         /* JTAG mailbox output 1 */
873
SFR_16BIT(SYSCNF);                            /* System Configuration Register */
874
SFR_8BIT(SYSCNF_L);                           /* System Configuration Register */
875
SFR_8BIT(SYSCNF_H);                           /* System Configuration Register */
876
 
877
SFR_16BIT(SYSBERRIV);                         /* Bus Error vector generator */
878
SFR_8BIT(SYSBERRIV_L);                        /* Bus Error vector generator */
879
SFR_8BIT(SYSBERRIV_H);                        /* Bus Error vector generator */
880
SFR_16BIT(SYSUNIV);                           /* User NMI vector generator */
881
SFR_8BIT(SYSUNIV_L);                          /* User NMI vector generator */
882
SFR_8BIT(SYSUNIV_H);                          /* User NMI vector generator */
883
SFR_16BIT(SYSSNIV);                           /* System NMI vector generator */
884
SFR_8BIT(SYSSNIV_L);                          /* System NMI vector generator */
885
SFR_8BIT(SYSSNIV_H);                          /* System NMI vector generator */
886
SFR_16BIT(SYSRSTIV);                          /* Reset vector generator */
887
SFR_8BIT(SYSRSTIV_L);                         /* Reset vector generator */
888
SFR_8BIT(SYSRSTIV_H);                         /* Reset vector generator */
889
 
890
/* SYSCTL Control Bits */
891
#define SYSRIVECT              (0x0001)       /* SYS - RAM based interrupt vectors */
892
//#define RESERVED            (0x0002)  /* SYS - Reserved */
893
#define SYSPMMPE               (0x0004)       /* SYS - PMM access protect */
894
//#define RESERVED            (0x0008)  /* SYS - Reserved */
895
#define SYSBSLIND              (0x0010)       /* SYS - TCK/RST indication detected */
896
#define SYSJTAGPIN             (0x0020)       /* SYS - Dedicated JTAG pins enabled */
897
//#define RESERVED            (0x0040)  /* SYS - Reserved */
898
//#define RESERVED            (0x0080)  /* SYS - Reserved */
899
//#define RESERVED            (0x0100)  /* SYS - Reserved */
900
//#define RESERVED            (0x0200)  /* SYS - Reserved */
901
//#define RESERVED            (0x0400)  /* SYS - Reserved */
902
//#define RESERVED            (0x0800)  /* SYS - Reserved */
903
//#define RESERVED            (0x1000)  /* SYS - Reserved */
904
//#define RESERVED            (0x2000)  /* SYS - Reserved */
905
//#define RESERVED            (0x4000)  /* SYS - Reserved */
906
//#define RESERVED            (0x8000)  /* SYS - Reserved */
907
 
908
/* SYSCTL Control Bits */
909
#define SYSRIVECT_L            (0x0001)       /* SYS - RAM based interrupt vectors */
910
//#define RESERVED            (0x0002)  /* SYS - Reserved */
911
#define SYSPMMPE_L             (0x0004)       /* SYS - PMM access protect */
912
//#define RESERVED            (0x0008)  /* SYS - Reserved */
913
#define SYSBSLIND_L            (0x0010)       /* SYS - TCK/RST indication detected */
914
#define SYSJTAGPIN_L           (0x0020)       /* SYS - Dedicated JTAG pins enabled */
915
//#define RESERVED            (0x0040)  /* SYS - Reserved */
916
//#define RESERVED            (0x0080)  /* SYS - Reserved */
917
//#define RESERVED            (0x0100)  /* SYS - Reserved */
918
//#define RESERVED            (0x0200)  /* SYS - Reserved */
919
//#define RESERVED            (0x0400)  /* SYS - Reserved */
920
//#define RESERVED            (0x0800)  /* SYS - Reserved */
921
//#define RESERVED            (0x1000)  /* SYS - Reserved */
922
//#define RESERVED            (0x2000)  /* SYS - Reserved */
923
//#define RESERVED            (0x4000)  /* SYS - Reserved */
924
//#define RESERVED            (0x8000)  /* SYS - Reserved */
925
 
926
/* SYSCTL Control Bits */
927
//#define RESERVED            (0x0002)  /* SYS - Reserved */
928
//#define RESERVED            (0x0008)  /* SYS - Reserved */
929
//#define RESERVED            (0x0040)  /* SYS - Reserved */
930
//#define RESERVED            (0x0080)  /* SYS - Reserved */
931
//#define RESERVED            (0x0100)  /* SYS - Reserved */
932
//#define RESERVED            (0x0200)  /* SYS - Reserved */
933
//#define RESERVED            (0x0400)  /* SYS - Reserved */
934
//#define RESERVED            (0x0800)  /* SYS - Reserved */
935
//#define RESERVED            (0x1000)  /* SYS - Reserved */
936
//#define RESERVED            (0x2000)  /* SYS - Reserved */
937
//#define RESERVED            (0x4000)  /* SYS - Reserved */
938
//#define RESERVED            (0x8000)  /* SYS - Reserved */
939
 
940
/* SYSBSLC Control Bits */
941
#define SYSBSLSIZE0            (0x0001)       /* SYS - BSL Protection Size 0 */
942
#define SYSBSLSIZE1            (0x0002)       /* SYS - BSL Protection Size 1 */
943
#define SYSBSLR                (0x0004)       /* SYS - RAM assigned to BSL */
944
//#define RESERVED            (0x0008)  /* SYS - Reserved */
945
//#define RESERVED            (0x0010)  /* SYS - Reserved */
946
//#define RESERVED            (0x0020)  /* SYS - Reserved */
947
//#define RESERVED            (0x0040)  /* SYS - Reserved */
948
//#define RESERVED            (0x0080)  /* SYS - Reserved */
949
//#define RESERVED            (0x0100)  /* SYS - Reserved */
950
//#define RESERVED            (0x0200)  /* SYS - Reserved */
951
//#define RESERVED            (0x0400)  /* SYS - Reserved */
952
//#define RESERVED            (0x0800)  /* SYS - Reserved */
953
//#define RESERVED            (0x1000)  /* SYS - Reserved */
954
//#define RESERVED            (0x2000)  /* SYS - Reserved */
955
#define SYSBSLOFF              (0x4000)       /* SYS - BSL Memeory disabled */
956
#define SYSBSLPE               (0x8000)       /* SYS - BSL Memory protection enabled */
957
 
958
/* SYSBSLC Control Bits */
959
#define SYSBSLSIZE0_L          (0x0001)       /* SYS - BSL Protection Size 0 */
960
#define SYSBSLSIZE1_L          (0x0002)       /* SYS - BSL Protection Size 1 */
961
#define SYSBSLR_L              (0x0004)       /* SYS - RAM assigned to BSL */
962
//#define RESERVED            (0x0008)  /* SYS - Reserved */
963
//#define RESERVED            (0x0010)  /* SYS - Reserved */
964
//#define RESERVED            (0x0020)  /* SYS - Reserved */
965
//#define RESERVED            (0x0040)  /* SYS - Reserved */
966
//#define RESERVED            (0x0080)  /* SYS - Reserved */
967
//#define RESERVED            (0x0100)  /* SYS - Reserved */
968
//#define RESERVED            (0x0200)  /* SYS - Reserved */
969
//#define RESERVED            (0x0400)  /* SYS - Reserved */
970
//#define RESERVED            (0x0800)  /* SYS - Reserved */
971
//#define RESERVED            (0x1000)  /* SYS - Reserved */
972
//#define RESERVED            (0x2000)  /* SYS - Reserved */
973
 
974
/* SYSBSLC Control Bits */
975
//#define RESERVED            (0x0008)  /* SYS - Reserved */
976
//#define RESERVED            (0x0010)  /* SYS - Reserved */
977
//#define RESERVED            (0x0020)  /* SYS - Reserved */
978
//#define RESERVED            (0x0040)  /* SYS - Reserved */
979
//#define RESERVED            (0x0080)  /* SYS - Reserved */
980
//#define RESERVED            (0x0100)  /* SYS - Reserved */
981
//#define RESERVED            (0x0200)  /* SYS - Reserved */
982
//#define RESERVED            (0x0400)  /* SYS - Reserved */
983
//#define RESERVED            (0x0800)  /* SYS - Reserved */
984
//#define RESERVED            (0x1000)  /* SYS - Reserved */
985
//#define RESERVED            (0x2000)  /* SYS - Reserved */
986
#define SYSBSLOFF_H            (0x0040)       /* SYS - BSL Memeory disabled */
987
#define SYSBSLPE_H             (0x0080)       /* SYS - BSL Memory protection enabled */
988
 
989
/* SYSJMBC Control Bits */
990
#define JMBIN0FG               (0x0001)       /* SYS - Incoming JTAG Mailbox 0 Flag */
991
#define JMBIN1FG               (0x0002)       /* SYS - Incoming JTAG Mailbox 1 Flag */
992
#define JMBOUT0FG              (0x0004)       /* SYS - Outgoing JTAG Mailbox 0 Flag */
993
#define JMBOUT1FG              (0x0008)       /* SYS - Outgoing JTAG Mailbox 1 Flag */
994
#define JMBMODE                (0x0010)       /* SYS - JMB 16/32 Bit Mode */
995
//#define RESERVED            (0x0020)  /* SYS - Reserved */
996
#define JMBCLR0OFF             (0x0040)       /* SYS - Incoming JTAG Mailbox 0 Flag auto-clear disalbe */
997
#define JMBCLR1OFF             (0x0080)       /* SYS - Incoming JTAG Mailbox 1 Flag auto-clear disalbe */
998
//#define RESERVED            (0x0100)  /* SYS - Reserved */
999
//#define RESERVED            (0x0200)  /* SYS - Reserved */
1000
//#define RESERVED            (0x0400)  /* SYS - Reserved */
1001
//#define RESERVED            (0x0800)  /* SYS - Reserved */
1002
//#define RESERVED            (0x1000)  /* SYS - Reserved */
1003
//#define RESERVED            (0x2000)  /* SYS - Reserved */
1004
//#define RESERVED            (0x4000)  /* SYS - Reserved */
1005
//#define RESERVED            (0x8000)  /* SYS - Reserved */
1006
 
1007
/* SYSJMBC Control Bits */
1008
#define JMBIN0FG_L             (0x0001)       /* SYS - Incoming JTAG Mailbox 0 Flag */
1009
#define JMBIN1FG_L             (0x0002)       /* SYS - Incoming JTAG Mailbox 1 Flag */
1010
#define JMBOUT0FG_L            (0x0004)       /* SYS - Outgoing JTAG Mailbox 0 Flag */
1011
#define JMBOUT1FG_L            (0x0008)       /* SYS - Outgoing JTAG Mailbox 1 Flag */
1012
#define JMBMODE_L              (0x0010)       /* SYS - JMB 16/32 Bit Mode */
1013
//#define RESERVED            (0x0020)  /* SYS - Reserved */
1014
#define JMBCLR0OFF_L           (0x0040)       /* SYS - Incoming JTAG Mailbox 0 Flag auto-clear disalbe */
1015
#define JMBCLR1OFF_L           (0x0080)       /* SYS - Incoming JTAG Mailbox 1 Flag auto-clear disalbe */
1016
//#define RESERVED            (0x0100)  /* SYS - Reserved */
1017
//#define RESERVED            (0x0200)  /* SYS - Reserved */
1018
//#define RESERVED            (0x0400)  /* SYS - Reserved */
1019
//#define RESERVED            (0x0800)  /* SYS - Reserved */
1020
//#define RESERVED            (0x1000)  /* SYS - Reserved */
1021
//#define RESERVED            (0x2000)  /* SYS - Reserved */
1022
//#define RESERVED            (0x4000)  /* SYS - Reserved */
1023
//#define RESERVED            (0x8000)  /* SYS - Reserved */
1024
 
1025
/* SYSJMBC Control Bits */
1026
//#define RESERVED            (0x0020)  /* SYS - Reserved */
1027
//#define RESERVED            (0x0100)  /* SYS - Reserved */
1028
//#define RESERVED            (0x0200)  /* SYS - Reserved */
1029
//#define RESERVED            (0x0400)  /* SYS - Reserved */
1030
//#define RESERVED            (0x0800)  /* SYS - Reserved */
1031
//#define RESERVED            (0x1000)  /* SYS - Reserved */
1032
//#define RESERVED            (0x2000)  /* SYS - Reserved */
1033
//#define RESERVED            (0x4000)  /* SYS - Reserved */
1034
//#define RESERVED            (0x8000)  /* SYS - Reserved */
1035
 
1036
/* SYSCNF Control Bits */
1037
//#define RESERVED            (0x0001)  /* SYS - Reserved */
1038
//#define RESERVED            (0x0002)  /* SYS - Reserved */
1039
#define SVMOE                  (0x0004)       /* SYS - SVM output enable */
1040
#define SVMPO                  (0x0008)       /* SYS - SVM based Ports off flag */
1041
#define SVMPD                  (0x0010)       /* SYS - Incoming JTAG Mailbox 0 Flag */
1042
#define SVMEN                  (0x0020)       /* SYS - SVM based port disable */
1043
//#define RESERVED            (0x0040)  /* SYS - Reserved */
1044
//#define RESERVED            (0x0080)  /* SYS - Reserved */
1045
#define RAMLCK0                (0x0100)       /* SYS - Write lock enable for configuration RAM */
1046
#define RAMLCK1                (0x0200)       /* SYS - Write lock enable for application’s code RAM */
1047
//#define RESERVED            (0x0400)  /* SYS - Reserved */
1048
//#define RESERVED            (0x0800)  /* SYS - Reserved */
1049
//#define RESERVED            (0x1000)  /* SYS - Reserved */
1050
//#define RESERVED            (0x2000)  /* SYS - Reserved */
1051
//#define RESERVED            (0x4000)  /* SYS - Reserved */
1052
//#define RESERVED            (0x8000)  /* SYS - Reserved */
1053
 
1054
/* SYSCNF Control Bits */
1055
//#define RESERVED            (0x0001)  /* SYS - Reserved */
1056
//#define RESERVED            (0x0002)  /* SYS - Reserved */
1057
#define SVMOE_L                (0x0004)       /* SYS - SVM output enable */
1058
#define SVMPO_L                (0x0008)       /* SYS - SVM based Ports off flag */
1059
#define SVMPD_L                (0x0010)       /* SYS - Incoming JTAG Mailbox 0 Flag */
1060
#define SVMEN_L                (0x0020)       /* SYS - SVM based port disable */
1061
//#define RESERVED            (0x0040)  /* SYS - Reserved */
1062
//#define RESERVED            (0x0080)  /* SYS - Reserved */
1063
//#define RESERVED            (0x0400)  /* SYS - Reserved */
1064
//#define RESERVED            (0x0800)  /* SYS - Reserved */
1065
//#define RESERVED            (0x1000)  /* SYS - Reserved */
1066
//#define RESERVED            (0x2000)  /* SYS - Reserved */
1067
//#define RESERVED            (0x4000)  /* SYS - Reserved */
1068
//#define RESERVED            (0x8000)  /* SYS - Reserved */
1069
 
1070
/* SYSCNF Control Bits */
1071
//#define RESERVED            (0x0001)  /* SYS - Reserved */
1072
//#define RESERVED            (0x0002)  /* SYS - Reserved */
1073
//#define RESERVED            (0x0040)  /* SYS - Reserved */
1074
//#define RESERVED            (0x0080)  /* SYS - Reserved */
1075
#define RAMLCK0_H              (0x0001)       /* SYS - Write lock enable for configuration RAM */
1076
#define RAMLCK1_H              (0x0002)       /* SYS - Write lock enable for application’s code RAM */
1077
//#define RESERVED            (0x0400)  /* SYS - Reserved */
1078
//#define RESERVED            (0x0800)  /* SYS - Reserved */
1079
//#define RESERVED            (0x1000)  /* SYS - Reserved */
1080
//#define RESERVED            (0x2000)  /* SYS - Reserved */
1081
//#define RESERVED            (0x4000)  /* SYS - Reserved */
1082
//#define RESERVED            (0x8000)  /* SYS - Reserved */
1083
 
1084
/* SYSUNIV Definitions */
1085
#define SYSUNIV_NONE           (0x0000)       /* No Interrupt pending */
1086
#define SYSUNIV_NMIIFG         (0x0002)       /* SYSUNIV : NMIIFG */
1087
#define SYSUNIV_OFIFG          (0x0004)       /* SYSUNIV : Osc. Fail - OFIFG */
1088
#define SYSUNIV_SYSBERRIV      (0x0006)       /* SYSUNIV : Bus Error - SYSBERRIV */
1089
 
1090
/* SYSSNIV Definitions */
1091
#define SYSSNIV_NONE           (0x0000)       /* No Interrupt pending */
1092
#define SYSSNIV_SVMIFG         (0x0002)       /* SYSSNIV : SVMLIFG */
1093
#define SYSSNIV_VMAIFG         (0x0004)       /* SYSSNIV : VMAIFG */
1094
#define SYSSNIV_JMBINIFG       (0x0006)       /* SYSSNIV : JMBINIFG */
1095
#define SYSSNIV_JMBOUTIFG      (0x0008)       /* SYSSNIV : JMBOUTIFG */
1096
 
1097
/* SYSRSTIV Definitions */
1098
#define SYSRSTIV_NONE          (0x0000)       /* No Interrupt pending */
1099
#define SYSRSTIV_BOR           (0x0002)       /* SYSRSTIV : BOR */
1100
#define SYSRSTIV_SVMBOR        (0x0004)       /* SYSRSTIV : SVMBOR */
1101
#define SYSRSTIV_RSTNMI        (0x0006)       /* SYSRSTIV : RST/NMI */
1102
#define SYSRSTIV_DOBOR         (0x0008)       /* SYSRSTIV : Do BOR */
1103
#define SYSRSTIV_SECYV         (0x000A)       /* SYSRSTIV : Security violation */
1104
#define SYSRSTIV_DOPOR         (0x000C)       /* SYSRSTIV : Do POR */
1105
#define SYSRSTIV_WDTTO         (0x000E)       /* SYSRSTIV : WDT Time out */
1106
#define SYSRSTIV_WDTKEY        (0x0010)       /* SYSRSTIV : WDTKEY violation */
1107
#define SYSRSTIV_CCSKEY        (0x0012)       /* SYSRSTIV : CCS Key violation */
1108
#define SYSRSTIV_PMMKEY        (0x0014)       /* SYSRSTIV : PMMKEY violation */
1109
#define SYSRSTIV_PERF          (0x0016)       /* SYSRSTIV : peripheral/config area fetch */
1110
/************************************************************
1111
* Timer0_A3
1112
************************************************************/
1113
#define __MSP430_HAS_T0A3__                   /* Definition to show that Module is available */
1114
#define __MSP430_BASEADDRESS_T0A3__ 0x0340
1115
 
1116
SFR_16BIT(TA0CTL);                            /* Timer0_A3 Control */
1117
SFR_16BIT(TA0CCTL0);                          /* Timer0_A3 Capture/Compare Control 0 */
1118
SFR_16BIT(TA0CCTL1);                          /* Timer0_A3 Capture/Compare Control 1 */
1119
SFR_16BIT(TA0CCTL2);                          /* Timer0_A3 Capture/Compare Control 2 */
1120
SFR_16BIT(TA0R);                              /* Timer0_A3 */
1121
SFR_16BIT(TA0CCR0);                           /* Timer0_A3 Capture/Compare 0 */
1122
SFR_16BIT(TA0CCR1);                           /* Timer0_A3 Capture/Compare 1 */
1123
SFR_16BIT(TA0CCR2);                           /* Timer0_A3 Capture/Compare 2 */
1124
SFR_16BIT(TA0IV);                             /* Timer0_A3 Interrupt Vector Word */
1125
SFR_16BIT(TA0EX0);                            /* Timer0_A3 Expansion Register 0 */
1126
 
1127
/* TAxCTL Control Bits */
1128
#define TASSEL1                (0x0200)       /* Timer A clock source select 0 */
1129
#define TASSEL0                (0x0100)       /* Timer A clock source select 1 */
1130
#define ID1                    (0x0080)       /* Timer A clock input divider 1 */
1131
#define ID0                    (0x0040)       /* Timer A clock input divider 0 */
1132
#define MC1                    (0x0020)       /* Timer A mode control 1 */
1133
#define MC0                    (0x0010)       /* Timer A mode control 0 */
1134
#define TACLR                  (0x0004)       /* Timer A counter clear */
1135
#define TAIE                   (0x0002)       /* Timer A counter interrupt enable */
1136
#define TAIFG                  (0x0001)       /* Timer A counter interrupt flag */
1137
 
1138
#define MC_0                   (0*0x10u)      /* Timer A mode control: 0 - Stop */
1139
#define MC_1                   (1*0x10u)      /* Timer A mode control: 1 - Up to CCR0 */
1140
#define MC_2                   (2*0x10u)      /* Timer A mode control: 2 - Continous up */
1141
#define MC_3                   (3*0x10u)      /* Timer A mode control: 3 - Up/Down */
1142
#define ID_0                   (0*0x40u)      /* Timer A input divider: 0 - /1 */
1143
#define ID_1                   (1*0x40u)      /* Timer A input divider: 1 - /2 */
1144
#define ID_2                   (2*0x40u)      /* Timer A input divider: 2 - /4 */
1145
#define ID_3                   (3*0x40u)      /* Timer A input divider: 3 - /8 */
1146
#define TASSEL_0               (0*0x100u)     /* Timer A clock source select: 0 - TACLK */
1147
#define TASSEL_1               (1*0x100u)     /* Timer A clock source select: 1 - ACLK  */
1148
#define TASSEL_2               (2*0x100u)     /* Timer A clock source select: 2 - SMCLK */
1149
#define TASSEL_3               (3*0x100u)     /* Timer A clock source select: 3 - INCLK */
1150
#define MC__STOP               (0*0x10u)      /* Timer A mode control: 0 - Stop */
1151
#define MC__UP                 (1*0x10u)      /* Timer A mode control: 1 - Up to CCR0 */
1152
#define MC__CONTINOUS          (2*0x10u)      /* Timer A mode control: 2 - Continous up */
1153
#define MC__UPDOWN             (3*0x10u)      /* Timer A mode control: 3 - Up/Down */
1154
#define ID__1                  (0*0x40u)      /* Timer A input divider: 0 - /1 */
1155
#define ID__2                  (1*0x40u)      /* Timer A input divider: 1 - /2 */
1156
#define ID__4                  (2*0x40u)      /* Timer A input divider: 2 - /4 */
1157
#define ID__8                  (3*0x40u)      /* Timer A input divider: 3 - /8 */
1158
#define TASSEL__TACLK          (0*0x100u)     /* Timer A clock source select: 0 - TACLK */
1159
#define TASSEL__ACLK           (1*0x100u)     /* Timer A clock source select: 1 - ACLK  */
1160
#define TASSEL__SMCLK          (2*0x100u)     /* Timer A clock source select: 2 - SMCLK */
1161
#define TASSEL__INCLK          (3*0x100u)     /* Timer A clock source select: 3 - INCLK */
1162
 
1163
/* TAxCCTLx Control Bits */
1164
#define CM1                    (0x8000)       /* Capture mode 1 */
1165
#define CM0                    (0x4000)       /* Capture mode 0 */
1166
#define CCIS1                  (0x2000)       /* Capture input select 1 */
1167
#define CCIS0                  (0x1000)       /* Capture input select 0 */
1168
#define SCS                    (0x0800)       /* Capture sychronize */
1169
#define SCCI                   (0x0400)       /* Latched capture signal (read) */
1170
#define CAP                    (0x0100)       /* Capture mode: 1 /Compare mode : 0 */
1171
#define OUTMOD2                (0x0080)       /* Output mode 2 */
1172
#define OUTMOD1                (0x0040)       /* Output mode 1 */
1173
#define OUTMOD0                (0x0020)       /* Output mode 0 */
1174
#define CCIE                   (0x0010)       /* Capture/compare interrupt enable */
1175
#define CCI                    (0x0008)       /* Capture input signal (read) */
1176
#define OUT                    (0x0004)       /* PWM Output signal if output mode 0 */
1177
#define COV                    (0x0002)       /* Capture/compare overflow flag */
1178
#define CCIFG                  (0x0001)       /* Capture/compare interrupt flag */
1179
 
1180
#define OUTMOD_0               (0*0x20u)      /* PWM output mode: 0 - output only */
1181
#define OUTMOD_1               (1*0x20u)      /* PWM output mode: 1 - set */
1182
#define OUTMOD_2               (2*0x20u)      /* PWM output mode: 2 - PWM toggle/reset */
1183
#define OUTMOD_3               (3*0x20u)      /* PWM output mode: 3 - PWM set/reset */
1184
#define OUTMOD_4               (4*0x20u)      /* PWM output mode: 4 - toggle */
1185
#define OUTMOD_5               (5*0x20u)      /* PWM output mode: 5 - Reset */
1186
#define OUTMOD_6               (6*0x20u)      /* PWM output mode: 6 - PWM toggle/set */
1187
#define OUTMOD_7               (7*0x20u)      /* PWM output mode: 7 - PWM reset/set */
1188
#define CCIS_0                 (0*0x1000u)    /* Capture input select: 0 - CCIxA */
1189
#define CCIS_1                 (1*0x1000u)    /* Capture input select: 1 - CCIxB */
1190
#define CCIS_2                 (2*0x1000u)    /* Capture input select: 2 - GND */
1191
#define CCIS_3                 (3*0x1000u)    /* Capture input select: 3 - Vcc */
1192
#define CM_0                   (0*0x4000u)    /* Capture mode: 0 - disabled */
1193
#define CM_1                   (1*0x4000u)    /* Capture mode: 1 - pos. edge */
1194
#define CM_2                   (2*0x4000u)    /* Capture mode: 1 - neg. edge */
1195
#define CM_3                   (3*0x4000u)    /* Capture mode: 1 - both edges */
1196
 
1197
/* TAxEX0 Control Bits */
1198
#define TAIDEX0                (0x0001)       /* Timer A Input divider expansion Bit: 0 */
1199
#define TAIDEX1                (0x0002)       /* Timer A Input divider expansion Bit: 1 */
1200
#define TAIDEX2                (0x0004)       /* Timer A Input divider expansion Bit: 2 */
1201
 
1202
#define TAIDEX_0               (0*0x0001u)    /* Timer A Input divider expansion : /1 */
1203
#define TAIDEX_1               (1*0x0001u)    /* Timer A Input divider expansion : /2 */
1204
#define TAIDEX_2               (2*0x0001u)    /* Timer A Input divider expansion : /3 */
1205
#define TAIDEX_3               (3*0x0001u)    /* Timer A Input divider expansion : /4 */
1206
#define TAIDEX_4               (4*0x0001u)    /* Timer A Input divider expansion : /5 */
1207
#define TAIDEX_5               (5*0x0001u)    /* Timer A Input divider expansion : /6 */
1208
#define TAIDEX_6               (6*0x0001u)    /* Timer A Input divider expansion : /7 */
1209
#define TAIDEX_7               (7*0x0001u)    /* Timer A Input divider expansion : /8 */
1210
 
1211
/* T0A3IV Definitions */
1212
#define TA0IV_NONE             (0x0000)       /* No Interrupt pending */
1213
#define TA0IV_TA0CCR1          (0x0002)       /* TA0CCR1_CCIFG */
1214
#define TA0IV_TA0CCR2          (0x0004)       /* TA0CCR2_CCIFG */
1215
#define TA0IV_3                (0x0006)       /* Reserved */
1216
#define TA0IV_4                (0x0008)       /* Reserved */
1217
#define TA0IV_5                (0x000A)       /* Reserved */
1218
#define TA0IV_6                (0x000C)       /* Reserved */
1219
#define TA0IV_TA0IFG           (0x000E)       /* TA0IFG */
1220
 
1221
/************************************************************
1222
* Timer1_A3
1223
************************************************************/
1224
#define __MSP430_HAS_T1A3__                   /* Definition to show that Module is available */
1225
#define __MSP430_BASEADDRESS_T1A3__ 0x0380
1226
 
1227
SFR_16BIT(TA1CTL);                            /* Timer1_A3 Control */
1228
SFR_16BIT(TA1CCTL0);                          /* Timer1_A3 Capture/Compare Control 0 */
1229
SFR_16BIT(TA1CCTL1);                          /* Timer1_A3 Capture/Compare Control 1 */
1230
SFR_16BIT(TA1CCTL2);                          /* Timer1_A3 Capture/Compare Control 2 */
1231
SFR_16BIT(TA1R);                              /* Timer1_A3 */
1232
SFR_16BIT(TA1CCR0);                           /* Timer1_A3 Capture/Compare 0 */
1233
SFR_16BIT(TA1CCR1);                           /* Timer1_A3 Capture/Compare 1 */
1234
SFR_16BIT(TA1CCR2);                           /* Timer1_A3 Capture/Compare 2 */
1235
SFR_16BIT(TA1IV);                             /* Timer1_A3 Interrupt Vector Word */
1236
SFR_16BIT(TA1EX0);                            /* Timer1_A3 Expansion Register 0 */
1237
 
1238
/* Bits are already defined within the Timer0_Ax */
1239
 
1240
/* TA1IV Definitions */
1241
#define TA1IV_NONE             (0x0000)       /* No Interrupt pending */
1242
#define TA1IV_TA1CCR1          (0x0002)       /* TA1CCR1_CCIFG */
1243
#define TA1IV_TA1CCR2          (0x0004)       /* TA1CCR2_CCIFG */
1244
#define TA1IV_3                (0x0006)       /* Reserved */
1245
#define TA1IV_4                (0x0008)       /* Reserved */
1246
#define TA1IV_5                (0x000A)       /* Reserved */
1247
#define TA1IV_6                (0x000C)       /* Reserved */
1248
#define TA1IV_TA1IFG           (0x000E)       /* TA1IFG */
1249
 
1250
/************************************************************
1251
* WATCHDOG TIMER A
1252
************************************************************/
1253
#define __MSP430_HAS_WDT_A__                  /* Definition to show that Module is available */
1254
#define __MSP430_BASEADDRESS_WDT_A__ 0x0150
1255
 
1256
SFR_16BIT(WDTCTL);                            /* Watchdog Timer Control */
1257
SFR_8BIT(WDTCTL_L);                           /* Watchdog Timer Control */
1258
SFR_8BIT(WDTCTL_H);                           /* Watchdog Timer Control */
1259
/* The bit names have been prefixed with "WDT" */
1260
/* WDTCTL Control Bits */
1261
#define WDTIS0                 (0x0001)       /* WDT - Timer Interval Select 0 */
1262
#define WDTIS1                 (0x0002)       /* WDT - Timer Interval Select 1 */
1263
#define WDTIS2                 (0x0004)       /* WDT - Timer Interval Select 2 */
1264
#define WDTCNTCL               (0x0008)       /* WDT - Timer Clear */
1265
#define WDTTMSEL               (0x0010)       /* WDT - Timer Mode Select */
1266
#define WDTSSEL0               (0x0020)       /* WDT - Timer Clock Source Select 0 */
1267
#define WDTSSEL1               (0x0040)       /* WDT - Timer Clock Source Select 1 */
1268
#define WDTHOLD                (0x0080)       /* WDT - Timer hold */
1269
 
1270
/* WDTCTL Control Bits */
1271
#define WDTIS0_L               (0x0001)       /* WDT - Timer Interval Select 0 */
1272
#define WDTIS1_L               (0x0002)       /* WDT - Timer Interval Select 1 */
1273
#define WDTIS2_L               (0x0004)       /* WDT - Timer Interval Select 2 */
1274
#define WDTCNTCL_L             (0x0008)       /* WDT - Timer Clear */
1275
#define WDTTMSEL_L             (0x0010)       /* WDT - Timer Mode Select */
1276
#define WDTSSEL0_L             (0x0020)       /* WDT - Timer Clock Source Select 0 */
1277
#define WDTSSEL1_L             (0x0040)       /* WDT - Timer Clock Source Select 1 */
1278
#define WDTHOLD_L              (0x0080)       /* WDT - Timer hold */
1279
 
1280
/* WDTCTL Control Bits */
1281
 
1282
#define WDTPW                  (0x5A00)
1283
 
1284
#define WDTIS_0                (0*0x0001u)    /* WDT - Timer Interval Select: /2G */
1285
#define WDTIS_1                (1*0x0001u)    /* WDT - Timer Interval Select: /128M */
1286
#define WDTIS_2                (2*0x0001u)    /* WDT - Timer Interval Select: /8192k */
1287
#define WDTIS_3                (3*0x0001u)    /* WDT - Timer Interval Select: /512k */
1288
#define WDTIS_4                (4*0x0001u)    /* WDT - Timer Interval Select: /32k */
1289
#define WDTIS_5                (5*0x0001u)    /* WDT - Timer Interval Select: /8192 */
1290
#define WDTIS_6                (6*0x0001u)    /* WDT - Timer Interval Select: /512 */
1291
#define WDTIS_7                (7*0x0001u)    /* WDT - Timer Interval Select: /64 */
1292
#define WDTIS__2G              (0*0x0001u)    /* WDT - Timer Interval Select: /2G */
1293
#define WDTIS__128M            (1*0x0001u)    /* WDT - Timer Interval Select: /128M */
1294
#define WDTIS__8192K           (2*0x0001u)    /* WDT - Timer Interval Select: /8192k */
1295
#define WDTIS__512K            (3*0x0001u)    /* WDT - Timer Interval Select: /512k */
1296
#define WDTIS__32K             (4*0x0001u)    /* WDT - Timer Interval Select: /32k */
1297
#define WDTIS__8192            (5*0x0001u)    /* WDT - Timer Interval Select: /8192 */
1298
#define WDTIS__512             (6*0x0001u)    /* WDT - Timer Interval Select: /512 */
1299
#define WDTIS__64              (7*0x0001u)    /* WDT - Timer Interval Select: /64 */
1300
 
1301
#define WDTSSEL_0              (0*0x0020u)    /* WDT - Timer Clock Source Select: SMCLK */
1302
#define WDTSSEL_1              (1*0x0020u)    /* WDT - Timer Clock Source Select: ACLK */
1303
#define WDTSSEL_2              (2*0x0020u)    /* WDT - Timer Clock Source Select: VLO_CLK */
1304
#define WDTSSEL_3              (3*0x0020u)    /* WDT - Timer Clock Source Select: reserved */
1305
#define WDTSSEL__SMCLK         (0*0x0020u)    /* WDT - Timer Clock Source Select: SMCLK */
1306
#define WDTSSEL__ACLK          (1*0x0020u)    /* WDT - Timer Clock Source Select: ACLK */
1307
#define WDTSSEL__VLO           (2*0x0020u)    /* WDT - Timer Clock Source Select: VLO_CLK */
1308
 
1309
/* WDT-interval times [1ms] coded with Bits 0-2 */
1310
/* WDT is clocked by fSMCLK (assumed 1MHz) */
1311
#define WDT_MDLY_32         (WDTPW+WDTTMSEL+WDTCNTCL+WDTIS2)                         /* 32ms interval (default) */
1312
#define WDT_MDLY_8          (WDTPW+WDTTMSEL+WDTCNTCL+WDTIS2+WDTIS0)                  /* 8ms     " */
1313
#define WDT_MDLY_0_5        (WDTPW+WDTTMSEL+WDTCNTCL+WDTIS2+WDTIS1)                  /* 0.5ms   " */
1314
#define WDT_MDLY_0_064      (WDTPW+WDTTMSEL+WDTCNTCL+WDTIS2+WDTIS1+WDTIS0)           /* 0.064ms " */
1315
/* WDT is clocked by fACLK (assumed 32KHz) */
1316
#define WDT_ADLY_1000       (WDTPW+WDTTMSEL+WDTCNTCL+WDTIS2+WDTSSEL0)                /* 1000ms  " */
1317
#define WDT_ADLY_250        (WDTPW+WDTTMSEL+WDTCNTCL+WDTIS2+WDTSSEL0+WDTIS0)         /* 250ms   " */
1318
#define WDT_ADLY_16         (WDTPW+WDTTMSEL+WDTCNTCL+WDTIS2+WDTSSEL0+WDTIS1)         /* 16ms    " */
1319
#define WDT_ADLY_1_9        (WDTPW+WDTTMSEL+WDTCNTCL+WDTIS2+WDTSSEL0+WDTIS1+WDTIS0)  /* 1.9ms   " */
1320
/* Watchdog mode -> reset after expired time */
1321
/* WDT is clocked by fSMCLK (assumed 1MHz) */
1322
#define WDT_MRST_32         (WDTPW+WDTCNTCL+WDTIS2)                                  /* 32ms interval (default) */
1323
#define WDT_MRST_8          (WDTPW+WDTCNTCL+WDTIS2+WDTIS0)                           /* 8ms     " */
1324
#define WDT_MRST_0_5        (WDTPW+WDTCNTCL+WDTIS2+WDTIS1)                           /* 0.5ms   " */
1325
#define WDT_MRST_0_064      (WDTPW+WDTCNTCL+WDTIS2+WDTIS1+WDTIS0)                    /* 0.064ms " */
1326
/* WDT is clocked by fACLK (assumed 32KHz) */
1327
#define WDT_ARST_1000       (WDTPW+WDTCNTCL+WDTSSEL0+WDTIS2)                         /* 1000ms  " */
1328
#define WDT_ARST_250        (WDTPW+WDTCNTCL+WDTSSEL0+WDTIS2+WDTIS0)                  /* 250ms   " */
1329
#define WDT_ARST_16         (WDTPW+WDTCNTCL+WDTSSEL0+WDTIS2+WDTIS1)                  /* 16ms    " */
1330
#define WDT_ARST_1_9        (WDTPW+WDTCNTCL+WDTSSEL0+WDTIS2+WDTIS1+WDTIS0)           /* 1.9ms   " */
1331
 
1332
 
1333
/************************************************************
1334
* Interrupt Vectors (offset from 0xFFFF - 0x20)
1335
************************************************************/
1336
 
1337
#pragma diag_suppress 1107
1338
#define VECTOR_NAME(name)             name##_ptr
1339
#define EMIT_PRAGMA(x)                _Pragma(#x)
1340
#define CREATE_VECTOR(name)           void * const VECTOR_NAME(name) = (void *)(long)&name
1341
#define PLACE_VECTOR(vector,section)  EMIT_PRAGMA(DATA_SECTION(vector,section))
1342
#define PLACE_INTERRUPT(func)         EMIT_PRAGMA(CODE_SECTION(func,".text:_isr"))
1343
#define ISR_VECTOR(func,offset)       CREATE_VECTOR(func); \
1344
                                      PLACE_VECTOR(VECTOR_NAME(func), offset) \
1345
                                      PLACE_INTERRUPT(func)
1346
 
1347
 
1348
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
1349
#define PORT2_VECTOR            ".int05"                    /* 0xFFEA Port 2 */
1350
#else
1351
#define PORT2_VECTOR            (5 * 1u)                     /* 0xFFEA Port 2 */
1352
/*#define PORT2_ISR(func)         ISR_VECTOR(func, ".int05")  */ /* 0xFFEA Port 2 */ /* CCE V2 Style */
1353
#endif
1354
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
1355
#define TIMER0_A1_VECTOR        ".int06"                    /* 0xFFEC Timer0_A3 CC1-2, TA1 */
1356
#else
1357
#define TIMER0_A1_VECTOR        (6 * 1u)                     /* 0xFFEC Timer0_A3 CC1-2, TA1 */
1358
/*#define TIMER0_A1_ISR(func)     ISR_VECTOR(func, ".int06")  */ /* 0xFFEC Timer0_A3 CC1-2, TA1 */ /* CCE V2 Style */
1359
#endif
1360
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
1361
#define TIMER0_A0_VECTOR        ".int07"                    /* 0xFFEE Timer0_A3 CC0 */
1362
#else
1363
#define TIMER0_A0_VECTOR        (7 * 1u)                     /* 0xFFEE Timer0_A3 CC0 */
1364
/*#define TIMER0_A0_ISR(func)     ISR_VECTOR(func, ".int07")  */ /* 0xFFEE Timer0_A3 CC0 */ /* CCE V2 Style */
1365
#endif
1366
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
1367
#define PORT1_VECTOR            ".int08"                    /* 0xFFF0 Port 1 */
1368
#else
1369
#define PORT1_VECTOR            (8 * 1u)                     /* 0xFFF0 Port 1 */
1370
/*#define PORT1_ISR(func)         ISR_VECTOR(func, ".int08")  */ /* 0xFFF0 Port 1 */ /* CCE V2 Style */
1371
#endif
1372
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
1373
#define APOOL_VECTOR            ".int09"                    /* 0xFFF2 Analog Pool */
1374
#else
1375
#define APOOL_VECTOR            (9 * 1u)                     /* 0xFFF2 Analog Pool */
1376
/*#define APOOL_ISR(func)         ISR_VECTOR(func, ".int09")  */ /* 0xFFF2 Analog Pool */ /* CCE V2 Style */
1377
#endif
1378
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
1379
#define WDT_VECTOR              ".int10"                    /* 0xFFF4 Watchdog Timer */
1380
#else
1381
#define WDT_VECTOR              (10 * 1u)                    /* 0xFFF4 Watchdog Timer */
1382
/*#define WDT_ISR(func)           ISR_VECTOR(func, ".int10")  */ /* 0xFFF4 Watchdog Timer */ /* CCE V2 Style */
1383
#endif
1384
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
1385
#define TIMER1_A1_VECTOR        ".int11"                    /* 0xFFF6 Timer1_A5 CC1-4, TA */
1386
#else
1387
#define TIMER1_A1_VECTOR        (11 * 1u)                    /* 0xFFF6 Timer1_A5 CC1-4, TA */
1388
/*#define TIMER1_A1_ISR(func)     ISR_VECTOR(func, ".int11")  */ /* 0xFFF6 Timer1_A5 CC1-4, TA */ /* CCE V2 Style */
1389
#endif
1390
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
1391
#define TIMER1_A0_VECTOR        ".int12"                    /* 0xFFF8 Timer1_A5 CC0 */
1392
#else
1393
#define TIMER1_A0_VECTOR        (12 * 1u)                    /* 0xFFF8 Timer1_A5 CC0 */
1394
/*#define TIMER1_A0_ISR(func)     ISR_VECTOR(func, ".int12")  */ /* 0xFFF8 Timer1_A5 CC0 */ /* CCE V2 Style */
1395
#endif
1396
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
1397
#define UNMI_VECTOR             ".int13"                    /* 0xFFFA User Non-maskable */
1398
#else
1399
#define UNMI_VECTOR             (13 * 1u)                    /* 0xFFFA User Non-maskable */
1400
/*#define UNMI_ISR(func)          ISR_VECTOR(func, ".int13")  */ /* 0xFFFA User Non-maskable */ /* CCE V2 Style */
1401
#endif
1402
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
1403
#define SYSNMI_VECTOR           ".int14"                    /* 0xFFFC System Non-maskable */
1404
#else
1405
#define SYSNMI_VECTOR           (14 * 1u)                    /* 0xFFFC System Non-maskable */
1406
/*#define SYSNMI_ISR(func)        ISR_VECTOR(func, ".int14")  */ /* 0xFFFC System Non-maskable */ /* CCE V2 Style */
1407
#endif
1408
#ifdef __ASM_HEADER__ /* Begin #defines for assembler */
1409
#define RESET_VECTOR            ".reset"                    /* 0xFFFE Reset [Highest Priority] */
1410
#else
1411
#define RESET_VECTOR            (15 * 1u)                    /* 0xFFFE Reset [Highest Priority] */
1412
/*#define RESET_ISR(func)         ISR_VECTOR(func, ".int15")  */ /* 0xFFFE Reset [Highest Priority] */ /* CCE V2 Style */
1413
#endif
1414
 
1415
/************************************************************
1416
* End of Modules
1417
************************************************************/
1418
 
1419
#ifdef __cplusplus
1420
}
1421
#endif /* extern "C" */
1422
 
1423
#endif /* #ifndef __msp430x09x */
1424