- Low Supply Voltage Range 1.8 V 3.6 V
- Ultralow-Power Consumption:
  - Active Mode: 200 μA at 1 MHz, 2.2 V
  - Standby Mode: 0.7 μA
  - Off Mode (RAM Retention): 0.1  $\mu$ A
- Five Power Saving Modes
- Wake-Up From Standby Mode in 6 μs
- 16-Bit RISC Architecture, 125 ns Instruction Cycle Time
- Basic Clock Module Configurations:
  - Various Internal Resistors
  - Single External Resistor
  - 32 kHz Crystal
  - High Frequency Crystal
  - Resonator
  - External Clock Source
- 16-Bit Timer With Three Capture/Compare Registers

- On-Chip Comparator for Analog Signal Compare Function or Slope A/D Conversion
- Serial Communication Interface (USART) Software-Selects Asynchronous UART or Synchronous SPI
- Serial Onboard Programming
- Programmable Code Protection by Security Fuse
- Family Members Include:

MSP430F122: 4KB + 256B Flash Memory

(MTP<sup>†</sup>), 256B RAM

MSP430F123: 8KB + 256B Flash Memory

(MTP<sup>†</sup>), 256B RAM

 Available in a 28-Pin Plastic Small-Outline Wide Body (SOWB) Package and 28-Pin Plastic Thin Shrink Small-Outline Package (TSSOP)

# DW OR PW PACKAGE (TOP VIEW)

| TEST □□□<br>V <sub>CC</sub> □□□ | 1 <sup>()</sup> | 28<br>27 | P1.7/TA2/TDO/TDI |
|---------------------------------|-----------------|----------|------------------|
| P2.5/R <sub>osc</sub>           | 3               | 26       | P1.5/TA0/TMS     |
| V <sub>SS</sub> $\Box$          | 4               | 25       | P1.4/SMCLK/TCK   |
| XOUT $\Box$                     | 5               | 24       | □□ P1.3/TA2      |
| XIN 🗀                           | 6               | 23       | □□ P1.2/TA1      |
| RST/NMI 🗆                       | 7               | 22       | □□ P1.1/TA0      |
| P2.0/ACLK 🗆                     | 8               | 21       | P1.0/TACLK       |
| P2.1/INCLK 🗆                    | 9               | 20       | □□ P2.4/CA1/TA2  |
| P2.2/CAOUT/TAO 🞞                | 10              | 19       | P2.3/CA0/TA1     |
| P3.0/STE0                       | 11              | 18       | □□ P3.7          |
| P3.1/SIMO0 🞞                    | 12              | 17       | □□ P3.6          |
| P3.2/SOMI0 $\Box$               | 13              | 16       | P3.5/URXD0       |
| P3.3/UCLK0 🗀                    | 14              | 15       | □□ P3.4/UTXD0    |
|                                 |                 |          |                  |

#### description

The Texas Instruments MSP430 series is an ultralow-power microcontroller family consisting of several devices featuring different sets of modules targeted to various applications. The microcontroller is designed to be battery operated for an extended-application lifetime. With 16-bit RISC architecture, 16 bit integrated registers on the CPU, and a constant generator, the MSP430 achieves maximum code efficiency. The digitally-controlled oscillator provides fast wake-up from all low-power modes to active mode in less than 6 µs.



Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.

†MTP = multiple time programmable



#### description (continued)

Typical applications include sensor systems that capture analog signals, convert them to digital values, and then process the data and display them or transmit them to a host system. Stand alone RF sensor front end is another area of application. The I/O port inputs provide single slope A/D conversion capability on resistive sensors. The MSP430F12x series is an ultralow-power mixed signal microcontroller with a built-in 16-bit timer and twenty-two I/O pins. The MSP430F12x family adds a versatile analog comparator.

The flash memory provides added flexibility of in-system programming and data storage without significantly increasing the current consumption of the device. The programming voltage is generated on-chip, thereby alleviating the need for an additional supply, and even allowing for reprogramming of battery-operated systems.

The MSP430F12x series microcontrollers have built-in communication capability using asynchronous (UART) and synchronous (SPI) protocols.

#### **AVAILABLE OPTIONS**

|               | PACKAGED DEVICES               |                                |  |  |  |
|---------------|--------------------------------|--------------------------------|--|--|--|
| TA            | PLASTIC 28-PIN SOWB<br>(DW)    | PLASTIC 28-PIN TSSOP<br>(PW)   |  |  |  |
| -40°C to 85°C | MSP430F122IDW<br>MSP430F123IDW | MSP430F122IPW<br>MSP430F123IPW |  |  |  |

#### functional block diagram





#### **Terminal Functions**

| TERMINAL                      |     | DECODIFICAL |                                                                                                                                |
|-------------------------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| NAME                          | NO. | 1/0         | DESCRIPTION                                                                                                                    |
| P1.0/TACLK                    | 21  | I/O         | General-purpose digital I/O pin/Timer_A, clock signal TACLK input                                                              |
| P1.1/TA0                      | 22  | I/O         | General-purpose digital I/O pin/Timer_A, capture: CCI0A input, compare: Out0 output                                            |
| P1.2/TA1                      | 23  | I/O         | General-purpose digital I/O pin/Timer_A, capture: CCI1A input, compare: Out1 output                                            |
| P1.3/TA2                      | 24  | I/O         | General-purpose digital I/O pin/Timer_A, capture: CCI2A input, compare: Out2 output                                            |
| P1.4/SMCLK/TCK                | 25  | I/O         | General-purpose digital I/O pin/SMCLK signal output/test clock, input terminal for device programming and test                 |
| P1.5/TA0/TMS                  | 26  | I/O         | General-purpose digital I/O pin/Timer_A, compare: Out0 output/test mode select, input terminal for device programming and test |
| P1.6/TA1/TDI                  | 27  | I/O         | General-purpose digital I/O pin/Timer_A, compare: Out1 output/test data input terminal                                         |
| P1.7/TA2/TDO/TDI <sup>†</sup> | 28  | I/O         | General-purpose digital I/O pin/Timer_A, compare: Out2 output/test data output terminal or data input during programming       |
| P2.0/ACLK                     | 8   | I/O         | General-purpose digital I/O pin/ACLK output                                                                                    |
| P2.1/INCLK                    | 9   | I/O         | General-purpose digital I/O pin/Timer_A, clock signal at INCLK                                                                 |
| P2.2/CAOUT/TA0                | 10  | I/O         | General-purpose digital I/O pin/Timer_A, capture: CCI0B input/comparator_A, output                                             |
| P2.3/CA0/TA1                  | 19  | I/O         | General-purpose digital I/O pin/Timer_A, compare: Out1 output/comparator_A, input                                              |
| P2.4/CA1/TA2                  | 20  | I/O         | General-purpose digital I/O pin/Timer_A, compare: Out2 output/comparator_A, input                                              |
| P2.5/R <sub>osc</sub>         | 3   | I/O         | General-purpose digital I/O pin/Input for external resistor that defines the DCO nominal frequency                             |
| P3.0/STE0                     | 11  | I/O         | General digital I/O, slave transmit enable—USART0/SPI mode                                                                     |
| P3.1/SIMO0                    | 12  | I/O         | General digital I/O, slave in/master out of USART0/SPI mode                                                                    |
| P3.2/SOMI0                    | 13  | I/O         | General digital I/O, slave out/master in of USART0/SPI mode                                                                    |
| P3.3/UCLK0                    | 14  | I/O         | General digital I/O, external clock input—USART0/UART or SPI mode, clock output—USART0/SPI mode clock input                    |
| P3.4/UTXD0                    | 15  | I/O         | General digital I/O, transmit data out—USART0/UART mode                                                                        |
| P3.5/URXD0                    | 16  | I/O         | General digital I/O, receive data in—USART0/UART mode                                                                          |
| P3.6                          | 17  | I/O         | General digital I/O                                                                                                            |
| P3.7                          | 18  | I/O         | General digital I/O                                                                                                            |
| RST/NMI                       | 7   | I           | Reset or nonmaskable interrupt input                                                                                           |
| TEST                          | 1   | I           | Select of test mode for JTAG pins on Port1                                                                                     |
| VCC                           | 2   |             | Supply voltage                                                                                                                 |
| V <sub>SS</sub>               | 4   |             | Ground reference                                                                                                               |
| XIN                           | 6   | ı           | Input terminal of crystal oscillator                                                                                           |
| XOUT                          | 5   | I/O         | Output terminal of crystal oscillator                                                                                          |

<sup>†</sup>TDO or TDI is selected via JTAG instruction.

# short-form description

# processing unit

The processing unit is based on a consistent and orthogonally-designed CPU and instruction set. This design structure results in a RISC-like architecture, highly transparent to the application development, and noted for its programming simplicity. All operations other than program-flow instructions are consequently performed as register operations in conjunction with seven addressing modes for source, and four modes for destination operands.



#### short-form description (continued)

#### CPU

All sixteen registers are located inside the CPU, providing reduced instruction execution time. This reduces a register-register operation execution time to one cycle of the processor.

Four registers are reserved for special use as a program counter, a stack pointer, a status register, and a constant generator. The remaining twelve registers are available as general-purpose registers.

Peripherals are connected to the CPU using a data address and control buses. They can be easily handled with all instructions for memory manipulation.



#### instruction set

The instructions set for this register-register architecture provides a powerful and easy-to-use assembly language. The instruction set consists of 51 instructions with three formats and seven addressing modes. Table 1 provides a summation and example of the three types of instruction formats; the addressing modes are listed in Table 2.

**Table 1. Instruction Word Formats** 

| Dual operands, source-destination | e.g. ADD R4, R5 | R4 + R5 → R5                              |
|-----------------------------------|-----------------|-------------------------------------------|
| Single operands, destination only | e.g. CALL R8    | $PC \rightarrow (TOS), R8 \rightarrow PC$ |
| Relative jump, un-/conditional    | e.g. JNE        | Jump-on equal bit = 0                     |

Most instructions can operate on both word and byte data. Byte operations are identified by the suffix B.

Examples: Instructions for word operation Instructions for byte operation

MOV EDE,TONI MOV.B EDE,TONI ADD #235h,&MEM ADD.B #35h,&MEM

PUSH R5 PUSH.B R5

SWPB R5 -

**Table 2. Address Mode Descriptions** 

| ADDRESS MODE           | s         | d | SYNTAX           | EXAMPLE           | OPERATION                                         |
|------------------------|-----------|---|------------------|-------------------|---------------------------------------------------|
| Register               | $\sqrt{}$ | V | MOV Rs, Rd       | MOV R10, R11      | R10 → R11                                         |
| Indexed                | $\sqrt{}$ | V | MOV X(Rn), Y(Rm) | MOV 2(R5), 6(R6)  | $M(2+R5) \rightarrow M(6+R6)$                     |
| Symbolic (PC relative) | $\sqrt{}$ | V | MOV EDE, TONI    |                   | $M(EDE) \to M(TONI)$                              |
| Absolute               | $\sqrt{}$ | V | MOV &MEM, &TCDAT |                   | $M(MEM) \rightarrow M(TCDAT)$                     |
| Indirect               | $\sqrt{}$ |   | MOV @Rn, Y(Rm)   | MOV @R10, Tab(R6) | $M(R10) \rightarrow M(Tab + R6)$                  |
| Indirect autoincrement | $\sqrt{}$ |   | MOV @Rn+, RM     | MOV @R10+, R11    | $M(R10) \rightarrow R11, R10 + 2 \rightarrow R10$ |
| Immediate              | $\sqrt{}$ |   | MOV #X, TONI     | MOV #45, TONI     | #45 → M(TONI)                                     |

NOTE: s = source d = destination Rs/Rd = source register/destination register Rn = register number



#### instruction set (continued)

Computed branches (BR) and subroutine calls (CALL) instructions use the same addressing modes as the other instructions. These addressing modes provide *indirect* addressing, ideally suited for computed branches and calls. The full use of this programming capability permits a program structure different from conventional 8- and 16-bit controllers. For example, numerous routines can easily be designed to deal with pointers and stacks instead of using flag type programs for flow control.

#### operation modes and interrupts

The MSP430 operating modes support various advanced requirements for ultralow-power and ultralow energy consumption. This is achieved by the intelligent management of the operations during the different module operation modes and CPU states. The advanced requirements are fully supported during interrupt event handling. An interrupt event awakens the system from each of the various operating modes and returns with the *RETI* instruction to the mode that was selected before the interrupt event. The different requirements of the CPU and modules, which are driven by system cost and current consumption objectives, necessitate the use of different clock signals:

- Auxiliary clock ACLK (from LFXT1CLK/crystal's frequency), used by the peripheral modules
- Main system clock MCLK, used by the CPU and system
- Subsystem clock SMCLK, used by the peripheral modules

#### low-power consumption capabilities

The various operating modes are controlled by the software through controlling the operation of the internal clock system. This clock system provides many combinations of hardware and software capabilities to run the application with the lowest power consumption and with optimized system costs:

- Use the internal clock (DCO) generator without any external components.
- Select an external crystal or ceramic resonator for lowest frequency or cost.
- Select and activate the proper clock signals (LFXT1CLK and/or DCOCLK) and clock pre-divider function.
- Apply an external clock source.

Four of the control bits that influence the operation of the clock system and support fast turnon from low power operating modes are located in the status register SR. The four bits that control the CPU and the system clock generator are SCG1, SCG0, OscOff, and CPUOff.



#### status register R2

| _15                                 | 9 | 8    | 7    | 6    | 5      | 4      | 3    | 2    | 1    | 0    |
|-------------------------------------|---|------|------|------|--------|--------|------|------|------|------|
| Reserved For Future<br>Enhancements |   | V    | SCG1 | SCG0 | OscOff | CPUOff | GIE  | N    | z    | С    |
| rw-0                                |   | rw-0 | rw-0 | rw-0 | rw-0   | rw-0   | rw-0 | rw-0 | rw-0 | rw-0 |

The bits CPUOff, SCG1, SCG0, and OscOff are the most important low-power control bits when the basic function of the system clock generator is established. They are pushed onto the stack whenever an interrupt is accepted and thereby saved so that the previous mode of operation can be retrieved after the interrupt request. During execution of an interrupt handler routine, the bits can be manipulated via indirect access of the data on the stack. That allows the program to resume execution in another power operating mode after the return from interrupt (RETI).

SCG1: The clock signal SMCLK, used for peripherals, is enabled when bit SCG1 is reset or disabled if

the bit is set.

SCG0: The dc-generator is active when SCG0 is reset. The dc-generator can be deactivated only if the SCG0 bit is set and the DCOCLK signal is not used for MCLK or SMCLK. The current consumed

by the dc-generator defines the basic frequency of the DCOCLK. It is a dc current.

The clock signal DCOCLK is deactivated if it is not used for MCLK. There are two situations when the SCG0 bit cannot switch off the dc-generator signal:

1. DCOCLK frequency is used for MCLK (CPUOff=0 and SELM.1=0).

2. DCOCLK frequency is used for SMCLK (SCG1=0 and SELS=0).

#### NOTE:

When the current is switched off (SCG0=1) the start of the DCOCLK is delayed slightly. The delay is in the µs-range (see device parameters for details).

OscOff: The LFXT1 crystal oscillator is active when the OscOff bit is reset. The LFXT1 oscillator can only be deactivated if the OscOff bit is set and it is not used for MCLK or SMCLK. The setup time to start a crystal oscillation needs consideration when oscillator off option is used. Mask

programmable (ROM) devices can disable this feature so that the oscillator can never be switched

off by software.

CPUOff: The clock signal MCLK, used for the CPU, is active when the CPUOff bit is reset or stopped if it

is set.



#### interrupt vector addresses

The interrupt vectors and the power-up starting address are located in the memory with an address range of 0FFFFh-0FFE0h. The vector contains the 16-bit address of the appropriate interrupt handler instruction sequence.

| INTERRUPT SOURCE                                     | INTERRUPT FLAG                                                                         | SYSTEM INTERRUPT                                     | WORD ADDRESS | PRIORITY    |
|------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------|--------------|-------------|
| Power-up, external reset, watchdog                   | WDTIFG (see Note1)<br>KEYV (see Note 1)                                                | Reset                                                | 0FFFEh       | 15, highest |
| NMI, oscillator fault, flash memory access violation | NMIIFG (see Notes 1 and 4)<br>OFIFG (see Notes 1 and 4)<br>ACCVIFG (see Notes 1 and 4) | (non)-maskable,<br>(non)-maskable,<br>(non)-maskable | 0FFFCh       | 14          |
|                                                      |                                                                                        |                                                      | 0FFFAh       | 13          |
|                                                      |                                                                                        |                                                      | 0FFF8h       | 12          |
| Comparator_A                                         | CAIFG                                                                                  | maskable                                             | 0FFF6h       | 11          |
| Watchdog timer                                       | WDTIFG                                                                                 | maskable                                             | 0FFF4h       | 10          |
| Timer_A                                              | CCIFG0 (see Note 2)                                                                    | maskable                                             | 0FFF2h       | 9           |
| Timer_A                                              | CCIFG1, CCIFG2, TAIFG (see Notes 1 and 2)                                              | maskable                                             | 0FFF0h       | 8           |
| USART0 receive                                       | URXIFG.0                                                                               | maskable                                             | 0FFEEh       | 7           |
| USART0 transmit                                      | UTXIFG.0                                                                               | maskable                                             | 0FFECh       | 6           |
|                                                      |                                                                                        |                                                      | 0FFEAh       | 5           |
|                                                      |                                                                                        |                                                      | 0FFE8h       | 4           |
| I/O Port P2 (eight flags – see Note 3)               | P2IFG.0 to P2IFG.7<br>(see Notes 1 and 2)                                              | maskable                                             | 0FFE6h       | 3           |
| I/O Port P1 (eight flags)                            | P1IFG.0 to P1IFG.7<br>(see Notes 1 and 2)                                              | maskable                                             | 0FFE4h       | 2           |
|                                                      |                                                                                        |                                                      | 0FFE2h       | 1           |
|                                                      |                                                                                        |                                                      | 0FFE0h       | 0, lowest   |

NOTES: 1. Multiple source flags

- 2. Interrupt flags are located in the module
- 3. There are eight Port P2 interrupt flags, but only six Port P2 I/O pins (P2.0–5) are implemented on the 11x1 devices.
- 4. (non)-maskable: the individual interrupt enable bit can disable an interrupt event, but the general interrupt enable cannot.

# special function registers

Most interrupt and module enable bits are collected into the lowest address space. Special function register bits that are not allocated to a functional purpose are not physically present in the device. Simple software access is provided with this arrangement.

#### interrupt enable 1 and 2



WDTIE: Watchdog timer enable signal OFIE: Oscillator fault enable signal

NMIIE: (Non)maskable interrupt enable signal ACCVIE: Access violation at flash memory



URXIE0: USARTO, UART, and SPI receive-interrupt-enable signal UTXIE0: USARTO, UART, and SPI transmit-interrupt-enable signal

#### interrupt flag register 1 and 2



WDTIFG: Set on overflow or security key violation or

Reset on V<sub>CC</sub> power-on or reset condition at RST/NMI-pin

OFIFG: Flag set on oscillator fault NMIIFG: Set via RST/NMI-pin



URXIFG0: USART0, UART, and SPI receive flag UTXIFG0: USART0, UART, and SPI transmit flag



#### module enable registers 1 and 2



URXE0: USART0, UART receive enable UTXE0: USART0, UART transmit enable

USPIIE0: USARTO, SPI (synchronous peripheral interface) transmit and receive enable

**Legend rw:** Bit can be read and written.

rw-0: Bit can be read and written. It is reset by PUC

SFR bit is not present in device.

# memory organization



#### boot ROM containing bootstrap loader

The bootstrap loader downloads data into the flash memory module. Various write, read, and erase operations are needed for a proper download environment. The bootstrap loader is only available on F devices.

#### functions of the bootstrap loader:

Definition of read: apply and transmit data of peripheral registers or memory to pin P1.1 (BSLTX)

write: read data from pin P2.2 (BSLRX) and write them into flash memory

#### unprotected functions

Mass erase, erase of the main memory (Segment0 to Segment7/15)

Access to the MSP430 via the bootstrap loader is protected. It must be enabled before any protected function can be performed. The 256 bits in 0FFE0h to 0FFFFh provide the access key.

#### protected functions

All protected functions can be executed only if the access is enabled.

- Write/program byte into flash memory; Parameters passed are start address and number of bytes (the block-write feature of the flash memory is not supported and not useful with the UART protocol).
- Segment erase of Segment0 to Segment7/15 in the main memory and segment erase of SegmentA and SegmentB in the information memory.
- Read all data in main memory and information memory.
- Read and write to all byte peripheral modules and RAM.
- Modify PC and start program execution immediately.

#### NOTE:

Unauthorized readout of code and data is prevented by the user's definition of the data in the interrupt memory locations. Also, blowing the security fuse prevents read out of the Flash data via JTAG.

#### features of the bootstrap loader are:

- UART communication protocol, fixed to 9600 baud
- Port pin P1.1 for transmit, P2.2 for receive
- TI standard serial protocol definition
- Implemented in flash memory version only
- Program execution starts with the user vector at 0FFFEh or with the bootstrap loader (start vector is at address 0C00h)

#### hardware resources used for serial input/output:

- Pins P1.1 and P2.2 for serial data transmission
- Test and RST/NMI to start program execution at the reset or bootstrap loader vector
- Basic clock module: Rsel=5, DCO=4, MOD=0, DCOCLK for MCLK and SMCLK, clock divider for MCLK and SMCLK at default: dividing by 1
- Timer\_A: Timer\_A operates in continuous mode with MCLK source selected, input divider set to 1, using CCR0, and polling of CCIFG0.
- WDT: Watchdog timer is halted
- Interrupt: GIE=0, NMIIE=0, OFIE=0, ACCVIE=0
- Memory allocation and stack pointer:

If the stack pointer points to RAM addresses above 0220h, 6 bytes of the stack are allocated plus RAM addresses 0200h to 0219h. Otherwise the stack pointer is set to 0220h and allocates RAM from 0200h to 021Fh.



# boot ROM containing bootstrap loader (continued)

#### NOTE

When writing RAM data via bootstrap loader, take care that the stack is outside the range of the data being written.

Program execution begins with the user's reset vector at FFFEh (standard method) if TEST is held low while RST/NMI goes from low to high:



Program execution begins with the bootstrap vector at 0C00h (boot ROM) if a minimum of two positive edges have been applied to TEST while RST/NMI is low, and TEST is high when RST/NMI goes from low to high. The TEST signal is normally used internally to switch pins P1.4, P1.5, P1.6, and P1.7 between their application function and the JTAG function. If the second rising edge at TEST is applied while RST/NMI is held low, the internal TEST signal is held low and the pins remain in the application mode:



Test mode can be entered again after TEST is taken low and then back high.

The bootstrap loader will not be started (via the vector in address 0C00h), if:

- There were less than two positive edges at TEST while RST/NMI is low
- TEST is low if RST/NMI goes from low to high
- JTAG has control over the MSP430 resources
- Supply voltage VCC drops and a POR is executed
- RST/NMI is operating as (non)maskable NMI function but NMI bit in watchdog control register remains unchanged. The bootstrap loader may not be disturbed when the RST/NMI pin is pulled low.



#### flash memory

The flash memory consists of 512-byte segments in the main memory and 128-byte segments in the information memory. See device memory maps for specific device information.

Segment0 to Segment7/15 can be erased individually, or altogether as a group.

SegmentA and SegmentB can be erased individually, or as a group with segments 0–7/15.

The memory in SegmentA and SegmentB is also called *Information Memory.* 

VPP is generated internally. VCC current increases during programming.

During program/erase cycles, VCC must not drop below the minimum specified for program/erase operation.

Program and erase timings are controlled by the flash timing generator—no software intervention is needed. The input frequency of the flash timing generator should be in the proper range and must be applied until the write/program or erase operation is completed.



NOTE: All segments not implemented on all devices.

During program or erase, no code can be executed from flash memory and all interrupts must be disabled by setting the GIE, NMIE, ACCVIE, and OFIE bits to zero. If a user program requires execution concurrent with a flash program or erase operation, the program must be executed from memory other than the flash memory (e.g., boot ROM, RAM). In the event a flash program or erase operation is initiated while the program counter is pointing to the flash memory, the CPU will execute JMP \$ instructions until the flash program or erase operation is completed. Normal execution of the previously running software then resumes.

Unprogrammed, new devices may have some bytes programmed in the information memory (needed for test during manufacturing). The user should perform an erase of the information memory prior to first use.

#### flash memory control register FCTL1

All control bits are reset during PUC. PUC is active after V<sub>CC</sub> is applied, a reset condition is applied to the RST/NMI pin, the watchdog timer expires, a watchdog access violation occurs, or an improper flash operation has been performed. A more detailed description of the control-bit functions is found in the flash memory module description (refer to *MSP430x1xx User's Guide*, literature number SLAU049). Any write to control register FCTL1 during erase, mass erase, or write (programming) will end in an access violation with ACCVIFG=1. Special conditions apply for block-write mode. Refer to *MSP430x1xx User's Guide*, literature number SLAU049 for details.



#### flash memory control register FCTL1 (continued)

Read access is possible at any time without restrictions.

The control bits of control register FCTL1 are:



0: No block-write acceleration is selected.

1: Block-write is used. This bit needs to be reset and set between segment borders.

Table 3. Allowed Combinations of Control Bits Allowed for Flash Memory Access

| FUNCTION PERFORMED                                                                           | BLKWRT | WRT | MEras | Erase | BUSY  | WAIT  | Lock |
|----------------------------------------------------------------------------------------------|--------|-----|-------|-------|-------|-------|------|
| Write word or byte                                                                           | 0      | 1   | 0     | 0     | 0     | 0     | 0    |
| Write word or byte in same block, block-write mode                                           | 1      | 1   | 0     | 0     | 0 → 1 | 0 → 1 | 0    |
| Erase one segment by writing to any address in the target segment                            | 0      | 0   | 0     | 1     | 0     | 0     | 0    |
| Erase all segments (0 to 7) but not the information memory (segments A and B)                | 0      | 0   | 1     | 0     | 0     | 0     | 0    |
| Erase all segments (0 to 7 and A and B) by writing to any address in the flash memory module | 0      | 0   | 1     | 1     | 0     | 0     | 0    |

NOTE: The table shows all valid combinations. Any other combination will result in an access violation.

#### flash memory, timing generator, control register FCTL2

The timing generator (Figure 1) generates all the timing signals necessary for write, erase, and mass erase from the selected clock source. One of three different clock sources may be selected by control bits SSEL0 and SSEL1 in control register FCTL2. The selected clock source should be divided to meet the frequency requirements specified in the recommended operating conditions.



# flash memory, timing generator, control register FCTL2 (continued)

The flash timing generator is reset with PUC. It is also reset if the emergency exit bit EMEX is set.

Control register FCTL2 may not be written to if the BUSY bit is set; otherwise, an access violation will occur (ACCVIFG=1).

Read access is possible at any time without restrictions.



Figure 1. Flash Memory Timing Generator Diagram



The control bits are:

FN0-FN5 012Ah, bit0-5

These six bits define the division rate of the clock signal. The division rate is 1 to 64, according to the digital value of FN5 to FN0 plus one.

SSEL0, SSEL1 012Ah, bit6,7 Clock source select

0: ACLK

1: MCLK

2: SMCLK

3: SMCLK

The flash timing generator is reset with PUC. It is also reset if the EMEX bit is set.

# flash memory control register FCTL3

There are no restrictions to modify this control register.





# flash memory control register FCTL3 (continued)

**BUSY** 

012Ch, bit0,

The BUSY bit shows if an access to the flash memory is allowed (BUSY=0), or if an access violation occurs. The BUSY bit is read-only, but a write operation is allowed. The BUSY bit should be tested before each write and erase cycle. The flash timing-generator hardware immediately sets the BUSY bit after start of a write, block-write, erase, or *mass* erase operation. If the timing generator has completed the operation, the BUSY bit is reset by the hardware.

No program code can be executed from the *busy* flash memory during the entire program or erase cycle.

- 0: Flash memory is not busy.
- 1: Flash memory is busy, and remains in busy state if block-write function is in *wait* mode.

KEYV, 012Ch, bit1

Key violation

- 0: Key 0A5h (high byte) was not violated.
- 1: Key 0A5h (high byte) was violated. Violation occurs when a write access to registers FCTL1, FCTL2, or FCTL3 is executed and the *high byte* is not equal to 0A5h. If the security key is violated, bit KEYV is set and a PUC is performed.

ACCVIFG, 012Ch, bit2

Access violation interrupt flag

The access-violation flag is set when any combination of control bits other than those shown in Table 3 is attempted, or an instruction is fetched while a block-write operation is active.

Reading the control registers will not set the ACCVIFG bit.

NOTE: The respective interrupt-enable bit ACCVIE is located in the interrupt enable register IE1 in the special function register. The software can set the ACCVIFG bit. If set by software, an NMI is also executed.

WAIT, 012CH, bit3

In the block-write mode, the WAIT bit indicates that data has been written and the flash memory is prepared to receive the next data for programming. The WAIT bit is read only, but a write to the WAIT bit is allowed.

- 0: The block-write operation has began and programming is in progress.
- 1: The block-write operation is active and data programming is complete.



#### flash memory control register FCTL3 (continued)

LOCK 012Ch, bit4,

The lock bit may be set during any write, segment-erase, or *mass*-erase request. Any active sequence in progress is completed normally. In segment-write mode, the BLKWRT bit is reset and the WAIT bit is set after the mode ends. The lock bit is controlled by software or hardware. If an access violation occurs and the ACCVIFG is set, the LOCK bit is set automatically.

- 0: Flash memory may be read, programmed, erased, or *mass* erased.
- 1: Flash memory may be read but not programmed, erased, or *mass* erased. A current program, erase, or *mass*-erase operation will complete normally. The access-violation interrupt flag ACCVIFG is set when data are written to the flash memory module while the lock bit is set.

EMEX, 012Ch, bit5,

Emergency exit. The emergency exit should only be used if the flash memory write or erase operation is out of control.

- 0: No function.
- Stops the active operation immediately, and shuts down all internal parts in the flash memory controller. Current consumption immediately drops back to the active mode. All bits in control register FCTL1 are reset. Since the EMEX bit is automatically reset by hardware, the software always reads EMEX as 0.

#### flash memory, interrupt and security key violation

One NMI vector is used for three NMI events: RST/NMI (NMIIFG), oscillator fault (OFIFG), and flash-memory access violation (ACCVIFG). The software can determine the source of the interrupt request since all flags remain set until they are reset by software. The enable flag(s) should be set simultaneously with one instruction before the return-from-interrupt RETI instruction. This ensures that the stack remains under control. A pending NMI interrupt request will not increase stack demand unnecessarily.





Figure 2. Block Diagram of NMI Interrupt Sources



# MSP430x12x MIXED SIGNAL MICROCONTROLLER

SLAS312 - JULY 2001

#### peripherals

Peripherals are connected to the CPU through data, address, and control buses and can be handled easily with memory manipulation instructions.

## oscillator and system clock

Three clocks are used in the system—the system (master) clock MCLK, the subsystem (master) clock SMCLK, and the auxiliary clock ACLK:

Main system clock MCLK, used by the CPU and the system Subsystem clock SMCLK, used by the peripheral modules

Auxiliary clock ACLK, originated by LFXT1CLK (crystal frequency) and used by the peripheral modules

After a POR, the DCOCLK is used by default, the DCOR bit is reset, and the DCO is set to the nominal initial frequency. Additionally, if LFXT1CLK (in XT1 mode) fails as the source for MCLK, the DCOCLK is automatically selected to ensure fail-safe operation.

SMCLK can be generated from LFXT1CLK or DCOCLK. ACLK is always generated from LFXT1CLK.

The crystal oscillator can be defined to operate with watch crystals (32768 Hz) or with higher-frequency ceramic resonators or crystals. The crystal or ceramic resonator is connected across two terminals. No external components are required for watch-crystal operation. If the high frequency XT1 mode is selected, external capacitors from XIN to VSS and XOUT to VSS are required as specified by the crystal manufacturer.

The LFXT1 oscillator starts after applying VCC. If the OscOff bit is set to 1, the oscillator stops when it is not used for MCLK. The clock signals ACLK and SMCLK may be used externally via port pins.

Different application requirements and system conditions dictate different system clock requirements, including:

High frequency for quick reaction to system hardware requests or events

Low frequency to minimize current consumption, EMI, etc.

Stable peripheral clock for timer applications, such as real-time clock (RTC)

Start-stop operation to be enabled with minimum delay



#### oscillator and system clock (continued)



Figure 3. Clock Signals

Two clock sources, LFXT1CLK and DCOCLK, can be used to drive the MSP430 system. The LFXT1CLK is generated from the LFXT1 crystal oscillator. The LFXT1 crystal oscillator can operate in three modes—low frequency (LF), moderate frequency (XT1), and external input mode. The LFXT1 crystal oscillator may be switched off when it is not in use.

DCOCLK is generated from the DCO. The nominal DCO frequency is defined by the dc generator and can be set by one external resistor, or can be set to one of eight values with integrated resistors. Additional adjustments and modulations of DCOCLK are possible by software manipulation of registers in the DCO module. DCOCLK is stopped automatically when it is not used by the CPU or peripheral modules. The dc generator can be shut down with the SCG0 bit to realize additional power savings when DCOCLK is not in use.

#### NOTE:

The system clock generator always starts with the DCOCLK selected for MCLK (CPU clock) to ensure proper start of program execution. The software defines the final system clock generation through control bit manipulation.

#### digital I/O

There are three eight-bit I/O ports, port P1, P2, and P3—implemented (12x1 parts only have six port P2 I/O signals available on external pins). Ports P1 and P2 have seven control registers and port P3 has four control registers to give maximum flexibility of digital input/output to the application:

- All individual I/O bits are programmable independently.
- Any combination of input, output, and interrupt conditions is possible.
- Interrupt processing of external events is fully implemented for all eight bits of port P1 and for six bits of port P2.
- Read/write access to all registers with all instructions



#### digital I/O (continued)

The seven registers are:

Input register
 8 bits at port P1, P2, P3 Contains information at the pins

Output register
 8 bits at port P1, P2, P3 Contains output information

Direction register
 8 bits at port P1, P2, P3 Controls direction

Interrupt edge select 8 bits at port P1/P2 Input signal change necessary for interrupt

Interrupt flags
 8 bits at port P1/P2
 Indicates if interrupt(s) are pending

Interrupt enable
 8 bits at port P1/P2
 Contains interrupt enable bits

• Selection (Port or Mod.) 8 bits at ports P1, P2, P3 Determines if pin(s) have port or module function

All these registers contain eight bits. Two interrupt vectors are implemented: one commonly used for any interrupt event on ports P1.0 to P1.7, and one commonly used for any interrupt event on ports P2.0 to P2.7.

#### NOTE:

Six bits of port P2, P2.0 to P2.5, are available on external pins – but all control and data bits for port P2 are implemented. Port P3 has no interrupt capability.

#### watchdog timer

The primary function of the watchdog timer (WDT) module is to perform a controlled system restart after a software problem has occurred. If the selected time interval expires, a system reset is generated. If this watchdog function is not needed in an application, the module can work as an interval timer, which generates an interrupt after the selected time interval.

The watchdog timer counter (WDTCNT) is a 16-bit up-counter which is not directly accessible by software. The WDTCNT is controlled through the watchdog timer control register (WDTCTL), which is a 16-bit read/write register. Writing to WDTCTL is, in both operating modes (watchdog or timer), only possible by using the correct password in the high-byte. The low-byte stores data written to the WDTCTL. The high-byte must be the password 05Ah. If any value other than 05Ah is written to the high-byte of the WDTCTL, a system reset PUC is generated. When the password is read, its value is 069h. This minimizes accidental write operations to the WDTCTL register. In addition to the watchdog timer control bits, there are two bits included in the WDTCTL register that configure the NMI pin.

#### Timer\_A (Three capture/compare registers)

The Timer\_A module on 12x devices offers one sixteen bit counter and three capture/compare registers. The timer clock source can be selected to come from two external sources TACLK (SSEL=0) or INCLK (SSEL=3), or from two internal sources, the ACLK (SSEL=1) or SMCLK (SSEL=2). The clock source can be divided by one, two, four, or eight. The timer can be fully controlled (in word mode) since it can be halted, read, and written. It can be stopped, run continuously, counted up or up/down, using one compare block to determine the period. The three capture/compare blocks are configured by the application to run in capture or compare mode.

The capture mode is primarily used to measure external or internal events using any combination of positive, negative, or both edges of the signal. Capture mode can be started and stopped by software. Three different external events TA0, TA1, and TA2 can be selected. At capture/compare register CCR2 the ACLK is the capture signal if CCI2B is selected. Software capture is chosen if CCISx=2 or CCISx=3 (see Figure 4).

The compare mode is primarily used to generate timings for the software or application hardware, or to generate pulse-width modulated output signals for various purposes like D/A conversion functions or motor control. An individual output module is assigned to each of the three capture/compare registers. The output modules can run independently of the compare function, or can be triggered in several ways.



#### Timer\_A (3 capture/compare registers) (continued)



Figure 4. Timer\_A, MSP430x12x Configuration

Two interrupt vectors are used by the Timer\_A module. One individual vector is assigned to capture/compare block CCR0, and one common interrupt vector is implemented for the timer and the other two capture/compare blocks. The three interrupt events using the same vector are identified by an individual interrupt vector word. The interrupt vector word is used to add an offset to the program counter to continue the interrupt handler software at the corresponding program location. This simplifies the interrupt handler and gives each interrupt event the same overhead of 5 cycles in the interrupt handler.

#### **UART With Timer\_A3**

Serial communication is implemented by using software and one capture/compare block. The hardware supports the output of the serial-data stream, bit by bit, with the timing determined by the comparator/timer. The data input uses the capture feature. The capture flag finds the start of a character, while the compare feature latches the input-data stream, bit by bit. The software/hardware interface connects the mixed-signal controller to external devices, systems, or networks.



# Comparator\_A

The primary function of the comparator module is to support precision A/D slope conversion applications, battery voltage supervision, and observation of external analog signals. The comparator is connected to port pins P2.3/CA0/TA1 and P2.4/CA1/TA2. It is controlled by twelve control bits in registers CACTL1 and CACTL2.



Figure 5. Block Diagram of Comparator\_A



# Comparator\_A (continued)

| The | CO | ntro | l hits | are: |
|-----|----|------|--------|------|
|     |    |      |        |      |

| CAOUT,         | 05Ah, bit0,   | Comparator output                                                                                                                                                                                                         |
|----------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CAF,           | 05Ah, bit1,   | The comparator output is transparent or fed through a small filter                                                                                                                                                        |
| P2CA0,         | 05Ah, bit2,   | <ul><li>0: Pin P2.3/CA0/TA1 is not connected to Comparator_A.</li><li>1: Pin P2.3/CA0/TA1 is connected to Comparator_A.</li></ul>                                                                                         |
| P2CA1,         | 05Ah, bit3,   | <ul><li>0: Pin P2.4/CA1/TA2 is not connected to Comparator_A.</li><li>1: Pin P2.4/CA1/TA2 is connected to Comparator_A.</li></ul>                                                                                         |
| CACTL2.4<br>to | 05Ah, bit4,   | Bits are implemented but do not control any hardware in this device.                                                                                                                                                      |
| CATCTL2.7      | 05Ah, bit7,   |                                                                                                                                                                                                                           |
| CAIFG,         | 059h, bit0,   | Comparator_A interrupt flag                                                                                                                                                                                               |
| CAIE,          | 059h, bit1,   | Comparator_A interrupt enable                                                                                                                                                                                             |
| CAIES,         | 059h, bit2,   | Comparator_A interrupt edge select bit 0: The rising edge sets the Comparator_A interrupt flag CAIFG 1: The falling edge set the Comparator_A interrupt flag CAIFG                                                        |
| CAON,          | 059h, bit3,   | The comparator is switched on.                                                                                                                                                                                            |
| CAREF,         | 059h, bit4,5, | Comparator_A reference 0: Internal reference is switched off, an external reference can be applied. 1: 0.25 × VCC reference selected. 2: 0.50 × VCC reference selected. 3: A diode reference selected.                    |
| CARSEL,        | 059h, bit6,   | An internal reference $V_{\sf CAREF}$ , selected by CAREF bits, can be applied to signal path CA0 or CA1. The signal $V_{\sf CAREF}$ is only driven by a voltage source if the value of CAREF control bits is 1, 2, or 3. |
| CAEX,          | 059h, bit7,   | The comparator inputs are exchanged, used to measure and compensate the offset of the comparator.                                                                                                                         |

Eight additional bits are implemented into the Comparator\_A module and enable the SW to switch off the input buffer of port P2. A CMOS input buffer would dissipate supply current when the input is not near VSS or VCC. Comparator\_A port disable control bits CAPD0 to CAPD7 are initially reset, and the port input buffer is active. The port input buffer is disabled if the appropriate control bit is set.

#### Comparator\_A (continued)



Ensure that the comparator input terminals are connected to signal, power, or ground level. Otherwise, floating levels may cause unexpected interrupts and current consumption may be increased.

#### slope a/d conversion

The Comparator\_A is well suited for use in single or multiple-slope conversions. The internal-reference levels may be used to set a reference during timing measurement of charge or discharge operations. They can also be used externally to bias analog circuitry.

Voltage, current, and resistive or capacitive sensor measurements are basic functions. The sensors sense physical conditions like temperature, pressure, acceleration, etc.

#### **USARTO**

The function of the USART peripheral USART0 is described in the applicable chapters of the MSP430x1xx User's Guide.

The universal synchronous/asynchronous interface is a dedicated peripheral module used in serial communications.

The USART supports synchronous SPI (3- or 4-pin), and asynchronous UART communication protocols, using double-buffered transmit and receive channels. Data streams of 7 or 8 bits in length can be transferred at a rate determined by the program or by an external clock. Low-power applications are optimized by UART mode options which allow for the reception of only the first byte of a complete frame. The application software should then decide if the succeeding data is to be processed. This option reduces power consumption. Two dedicated interrupt vectors are assigned to the USART0 module—one for the receive and one for the transmit channels.

The USART function is available at the respective pins if bits P3SEL.0 to P3SEL.5 are defined correctly. The P3SEL.x bits determine whether the port function (initial state) or the USART function is connected to the pins.

UART mode on pins P3.4/UTXD0, P3.5/URXD0:

Select bits P3SEL.4 and P3SEL.5 must be set for receive and transmit function. Bit P3SEL.3 is set only if the clock source for the UART is applied on P3.3/UCLK0.

Bits UTXE0 (transmitter enable) and URXE0 (receive enable) must be set.



#### **USART0** (continued)

SPI mode on pins P3.0/STE0 (only in 4-pin mode), P3.1/SIMO0, P3.2/SOMI0, P3.3/UCLK0:

Select bits P3SEL.1, P3SEL.2, and P3SEL.3 must be set.

Select bit P3SEL.0 is set only if 4-pin SPI mode is used.

Bit USPIE0 (SPI enable) must be set.

Note that the SWRST bit in the USART control register is initially set by PUC to reset the USART function. The transmit interrupt flag UTXIFG0 is set (initial state) if the transmitter can accept data for transmission.



Figure 6. Block Diagram of USART

# peripheral file map

| PERIPHERALS WITH WORD ACCESS |                                                                                                                                                                                                                                                                             |                                                                                     |                                                                                                                                              |  |  |  |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Timer_A                      | Reserved Reserved Reserved Reserved Capture/compare register Capture/compare register Capture/compare register Timer_A register Reserved Reserved Reserved Capture/compare control Capture/compare control Capture/compare control Timer_A control Timer_A interrupt vector | CCR2 CCR1 CCR0 TAR  CCTL2 CCTL1 CCTL0 TACTL TAIV                                    | 017Eh<br>017Ch<br>017Ch<br>017Ah<br>0178h<br>0176h<br>0174h<br>0172h<br>016Eh<br>016Ch<br>016Ah<br>0168h<br>0166h<br>0164h<br>0162h<br>0162h |  |  |  |
| Flash Memory                 | Flash control 3 Flash control 2 Flash control 1                                                                                                                                                                                                                             | FCTL3<br>FCTL2<br>FCTL1                                                             | 012Ch<br>012Ah<br>0128h                                                                                                                      |  |  |  |
| Watchdog                     | Watchdog/timer control                                                                                                                                                                                                                                                      | WDTCTL                                                                              | 0120h                                                                                                                                        |  |  |  |
| PEF                          | RIPHERALS WITH BYTE ACCESS                                                                                                                                                                                                                                                  | <u> </u>                                                                            |                                                                                                                                              |  |  |  |
| USART0                       | Transmit buffer Receive buffer Baud rate Baud rate Modulation control Receive control Transmit control UART control                                                                                                                                                         | UTXBUF.0<br>URXBUF.0<br>UBR1.0<br>UBR0.0<br>UMCTL.0<br>URCTL.0<br>UTCTL.0<br>UCTL.0 | 077h<br>076h<br>075h<br>074h<br>073h<br>072h<br>071h<br>070h                                                                                 |  |  |  |
| Comparator_A                 | Comparator_A port disable<br>Comparator_A control2<br>Comparator_A control1                                                                                                                                                                                                 | CAPD<br>CACTL2<br>CACTL1                                                            | 05Bh<br>05Ah<br>059h                                                                                                                         |  |  |  |
| System Clock                 | Basic clock sys. control2 Basic clock sys. control1 DCO clock freq. control                                                                                                                                                                                                 | BCSCTL2<br>BCSCTL1<br>DCOCTL                                                        | 058h<br>057h<br>056h                                                                                                                         |  |  |  |
| Port P3                      | Port P3 selection Port P3 direction Port P3 output Port P3 input                                                                                                                                                                                                            | P2SEL<br>P3DIR<br>P3OUT<br>P3IN                                                     | 01Bh<br>01Ah<br>019h<br>018h                                                                                                                 |  |  |  |
| Port P2                      | Port P2 selection Port P2 interrupt enable Port P2 interrupt edge select Port P2 interrupt flag Port P2 direction Port P2 output Port P2 input                                                                                                                              | P2SEL P2IE P2IES P2IFG P2DIR P2OUT P2IN                                             | 02Eh<br>02Dh<br>02Ch<br>02Bh<br>02Ah<br>029h<br>028h                                                                                         |  |  |  |



# peripheral file map (continued)

| PERIPHERALS WITH BYTE ACCESS (CONTINUED) |                                                                                                                   |                                          |                                              |  |  |  |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------|------------------------------------------|----------------------------------------------|--|--|--|
| Port P1                                  | Port P1 selection Port P1 interrupt enable Port P1 interrupt edge select                                          | P1SEL<br>P1IE<br>P1IES                   | 026h<br>025h<br>024h                         |  |  |  |
|                                          | Port P1 interrupt flag Port P1 direction Port P1 output Port P1 input                                             | P1IFG<br>P1DIR<br>P1OUT<br>P1IN          | 023h<br>022h<br>021h<br>020h                 |  |  |  |
| Special Function                         | Module enable2 Module enable1 SFR interrupt flag2 SFR interrupt flag1 SFR interrupt enable2 SFR interrupt enable1 | ME2<br>ME1<br>IFG2<br>IFG1<br>IE2<br>IE1 | 005h<br>004h<br>003h<br>002h<br>001h<br>000h |  |  |  |

# absolute maximum ratings†

| Voltage applied at V <sub>CC</sub> to V <sub>SS</sub>       |                                 |
|-------------------------------------------------------------|---------------------------------|
| Voltage applied to any pin (referenced to VSS)              | 0.3 V to V <sub>CC</sub> +0.3 V |
| Diode current at any device terminal                        | ±2 mA                           |
| Storage temperature, T <sub>stq</sub> (unprogrammed device) | –55°C to 150°C                  |
|                                                             | –40°C to 85°C                   |

<sup>†</sup> Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

NOTE: All voltages referenced to VSS.



# recommended operating conditions

|                                                                                 |                                             |                                        | MIN                 | NOM                  | MAX                 | UNITS   |  |
|---------------------------------------------------------------------------------|---------------------------------------------|----------------------------------------|---------------------|----------------------|---------------------|---------|--|
| Supply voltage during program execution, V <sub>CO</sub>                        | (see Note 5)                                | MSP430F12x                             | 1.8                 |                      | 3.6                 | V       |  |
| Supply voltage during program/erase flash me                                    | mory, V <sub>CC</sub>                       | MSP430F12x                             | 2.7                 |                      | 3.6                 | V       |  |
| Supply voltage, VSS                                                             |                                             |                                        | 0                   |                      | V                   |         |  |
| Operating free-air temperature range, TA                                        | MSP430F12x                                  | -40                                    |                     | 85                   | °C                  |         |  |
|                                                                                 | LF mode selected, XTS=0                     | Watch crystal                          |                     | 32768                |                     | Hz      |  |
| LFXT1 crystal frequency, f(LFXT1) (see Note 6)                                  | VT1 calcated made, VTC 1                    | Ceramic resonator                      | 450                 |                      | 8000                | lel I=  |  |
| (See Note o)                                                                    | XT1 selected mode, XTS=1                    | Crystal                                | 1000                |                      | 8000                | kHz     |  |
| Processor frequency f                                                           | V <sub>CC</sub> = 1.8 V,<br>MSP430F12x      | dc                                     |                     | 4.15                 | MHz                 |         |  |
| Processor frequency f <sub>(system)</sub> (MCLK signal)                         |                                             | V <sub>CC</sub> = 3.6 V,<br>MSP430F12x | dc                  |                      | 8                   | IVII IZ |  |
| Flash timing generator frequency, f(FTG)                                        |                                             | MSP430F12x                             | 257                 |                      | 476                 | kHz     |  |
| Cumulative program time, block write, t(CPT) (                                  | V <sub>CC</sub> = 2.7 V/3.6 V<br>MSP430F12x |                                        |                     | 3                    | ms                  |         |  |
| Low-level input voltage (TEST, RST/NMI), V <sub>IL</sub>                        | $V_{CC} = 2.2 \text{ V/3 V}$                | V <sub>SS</sub>                        |                     | V <sub>SS</sub> +0.6 | V                   |         |  |
| High-level input voltage (TEST, RST/NMI), V <sub>IH</sub> (excluding XIN, XOUT) |                                             | V <sub>CC</sub> = 2.2 V/3 V            | 0.8V <sub>CC</sub>  |                      | Vcc                 | V       |  |
| Input lovels at VIN VOLIT                                                       | VIL(XIN, XOUT)                              | V 22V/2V                               | V <sub>SS</sub>     |                      | 0.2×V <sub>CC</sub> | V       |  |
| Input levels at XIN, XOUT                                                       | VIH(XIN, XOUT)                              | V <sub>CC</sub> = 2.2 V/3 V            | 0.8×V <sub>CC</sub> |                      | Vcc                 | l v     |  |

NOTES: 5. The LFXT1 oscillator in LF-mode requires a resistor of 5.1 M $\Omega$  from XOUT to VSS when VCC <2.5 V. The LFXT1 oscillator in XT1-mode accepts a ceramic resonator or a crystal frequency of 4 MHz at VCC  $\geq$  2.2 V. The LFXT1 oscillator in XT1-mode accepts a ceramic resonator or a crystal frequency of 8 MHz at VCC  $\geq$  2.8 V.

- The LFXT1 oscillator in LF-mode requires a watch crystal.
   The LFXT1 oscillator in XT1-mode accepts a ceramic resonator or a crystal.
- 7. The cumulative program time must not be exceeded during a block-write operation.



NOTE: Minimum processor frequency is defined by system clock. Flash program or erase operations require a minimum  $V_{CC}$  of 2.7 V.

Figure 7. Frequency vs Supply Voltage



# electrical characteristics over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted)

supply current (into  $V_{CC}$ ) excluding external current ( $f_{(system)} = 1 \text{ MHz}$ )

|                                  | PARAMETER              | TEST CONDITIONS                                                                    |                             | MIN | TYP | MAX | UNIT |
|----------------------------------|------------------------|------------------------------------------------------------------------------------|-----------------------------|-----|-----|-----|------|
|                                  |                        | $T_A = -40^{\circ}C + 85^{\circ}C$ ,<br>$f_{MCLK} = f_{(SMCLK)} = 1 \text{ MHz}$ , | V <sub>CC</sub> = 2.2 V     |     | 200 | 250 | μА   |
| I <sub>(AM)</sub>                | Active mode            | f(ACLK) = 32,768 Hz,<br>Program executes in Flash                                  | V <sub>CC</sub> = 3 V       |     | 300 | 350 | μΑ   |
|                                  |                        | $T_A = -40^{\circ}\text{C} + 85^{\circ}\text{C},$                                  | V <sub>CC</sub> = 2.2 V     |     | 3   | 5   |      |
|                                  |                        | f(MCLK) = f(SMCLK) = f(ACLK) = 4096 Hz,<br>Program executes in Flash               | V <sub>CC</sub> = 3 V       |     | 11  | 18  | μΑ   |
| I(CPUOff) Low-power mode, (LPM0) |                        | $T_A = -40^{\circ}\text{C} + 85^{\circ}\text{C},$                                  |                             |     | 32  | 45  |      |
| I(CPUOff)                        | Low-power mode, (LPMO) | f(MCLK) = 0, $f(SMCLK) = 1$ MHz,<br>f(ACLK) = 32,768 Hz                            | V <sub>CC</sub> = 3 V       |     | 55  | 70  | μΑ   |
| la puo                           | Low-power mode, (LPM2) | $T_A = -40^{\circ}\text{C} + 85^{\circ}\text{C},$<br>f(MCLK) = f(SMCLK) = 0  MHz,  | V <sub>CC</sub> = 2.2 V     |     | 11  | 14  |      |
| l(LPM2)                          |                        | f(ACLK) = 1(SMCLK) = 0 Mi12,<br>f(ACLK) = 32,768 Hz, SCG0 = 0                      | V <sub>CC</sub> = 3 V       |     | 17  | 22  | μΑ   |
|                                  |                        | $T_A = -40$ °C                                                                     |                             |     | 0.8 | 1.2 |      |
|                                  |                        | T <sub>A</sub> = 25°C                                                              | $V_{CC} = 2.2 \text{ V}$    |     | 0.7 | 1   | μΑ   |
| 10                               | Low navier made (LDM2) | T <sub>A</sub> = 85°C                                                              | 1                           |     | 1.6 | 2.3 |      |
| I(LPM3)                          | Low-power mode, (LPM3) | $T_A = -40^{\circ}C$                                                               |                             |     | 1.8 | 2.2 |      |
|                                  |                        | T <sub>A</sub> = 25°C                                                              | V <sub>CC</sub> = 3 V       |     | 1.6 | 1.9 | μΑ   |
|                                  |                        | T <sub>A</sub> = 85°C                                                              | 1                           |     | 2.3 | 3.4 |      |
|                                  |                        | $T_A = -40$ °C                                                                     |                             |     | 0.1 | 0.5 | μА   |
| I(LPM4)                          |                        | T <sub>A</sub> = 25°C                                                              | V <sub>CC</sub> = 2.2 V/3 V |     | 0.1 | 0.5 |      |
|                                  |                        | T <sub>A</sub> = 85°C                                                              | ]                           |     | 0.8 | 1.9 |      |

NOTE: All inputs are tied to 0 V or V<sub>CC</sub>. Outputs do not source or sink any current.

# current consumption of active mode versus system frequency

$$I_{AM} = I_{AM[1 \text{ MHz}]} \times f_{system} [MHz]$$

# current consumption of active mode versus supply voltage

$$I_{AM} = I_{AM[3\ V]} + 120\ \mu\text{A/V} \times (V_{CC} - 3\ V)$$

#### Schmitt-trigger inputs Port P1 to Port P3; P1.0 to P1.7, P2.0 to P2.5, P3.0 to P3.7

|                  | PARAMETER                               | TEST CONDITIONS          | MIN | TYP MAX | UNIT |
|------------------|-----------------------------------------|--------------------------|-----|---------|------|
| \/               | Positive-going input threshold voltage  | $V_{CC} = 2.2 \text{ V}$ | 1.1 | 1.5     | V    |
| V <sub>IT+</sub> | Fositive-going input the shold voltage  | $V_{CC} = 3 V$           | 1.5 | 1.9     | v    |
| \/               | No gotivo going input threehold valtage | $V_{CC} = 2.2 \text{ V}$ | 0.4 | 0.9     | V    |
| VIT-             | Negative-going input threshold voltage  | $V_{CC} = 3 V$           | 0.9 | 1.3     | v    |
| \/.              | Input voltage hysteresis. (VIT. – VIT.) | V <sub>CC</sub> = 2.2 V  | 0.3 | 1.1     | V    |
| V <sub>hys</sub> |                                         | $V_{CC} = 3 V$           | 0.5 | 1       | ]    |



electrical characteristics over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted) (continued)

outputs Port 1 to P3; P1.0 to P1.7, P2.0 to P2.5, P3.0 to P3.7

|                   | PARAMETER TEST CONDITIONS                   |                                 |                         |                      | MIN                   | TYP MAX               | UNIT |
|-------------------|---------------------------------------------|---------------------------------|-------------------------|----------------------|-----------------------|-----------------------|------|
|                   |                                             | $I_{(OHmax)} = -1.5 \text{ mA}$ | V00 = 2 2 V             | See Note 8           | V <sub>CC</sub> -0.25 | Vcc                   |      |
| V                 | I V OLI I I I I I I I I I I I I I I I I I I | $I_{(OHmax)} = -6 \text{ mA}$   | V <sub>CC</sub> = 2.2 V | See Note 9           | VCC-0.6               | Vcc                   | V    |
| VOH               |                                             | $I_{(OHmax)} = -1.5 \text{ mA}$ | V 2.V                   | See Note 8           | V <sub>CC</sub> -0.25 | VCC                   | V    |
|                   | $I_{(OHmax)} = -6 \text{ mA}$               | VCC = 3 V                       | See Note 9              | V <sub>CC</sub> -0.6 | Vcc                   |                       |      |
|                   |                                             | $I_{(OLmax)} = 1.5 \text{ mA}$  | Vaa - 2.2.V             | See Note 8           | Vss                   | V <sub>SS</sub> +0.25 |      |
| \ <sub>\\\\</sub> | Low lovel output voltage                    | I <sub>(OLmax)</sub> = 6 mA     | V <sub>CC</sub> = 2.2 V | See Note 9           | VSS                   | V <sub>SS</sub> +0.6  | V    |
| VOL               | VOL Low-level output voltage                | $I_{(OLmax)} = 1.5 \text{ mA}$  | V00 = 3 V               | See Note 8           | V <sub>SS</sub>       | V <sub>SS</sub> +0.25 | V    |
|                   |                                             | I <sub>(OLmax)</sub> = 6 mA     | VCC = 3 V               | See Note 9           | Vss                   | V <sub>SS</sub> +0.6  |      |

- NOTES: 8. The maximum total current,  $I_{OHmax}$  and  $I_{OLmax}$ , for all outputs combined, should not exceed  $\pm 12$  mA to hold the maximum voltage drop specified.
  - 9. The maximum total current, IOHmax and IOLmax, for all outputs combined, should not exceed ±48 mA to hold the maximum voltage drop specified.
  - 10. One output loaded at a time.

#### outputs - Ports P1, P2, and P3

# TYPICAL LOW-LEVEL OUTPUT CURRENT LOW-LEVEL OUTPUT VOLTAGE



NOTE: Only one output is loaded at a time.

# TYPICAL LOW-LEVEL OUTPUT CURRENT **LOW-LEVEL OUTPUT VOLTAGE**



Figure 9

TYPICAL HIGH-LEVEL OUTPUT CURRENT

**HIGH-LEVEL OUTPUT VOLTAGE** 

electrical characteristics over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted) (continued)

outputs - Ports P1, P2, and P3 (continued)

# TYPICAL HIGH-LEVEL OUTPUT CURRENT VS HIGH-LEVEL OUTPUT VOLTAGE VCC = 2.2 V P1.0 VCC = 2.2 V P1.0 TA = 85°C TA = 85°C TA = 25°C

1.5

Figure 11

2.0

VOH - High-Level Output Voltage - V

2.5

3.0

3.5

1.0

Figure 10

1.0

VOH - High-Level Output Voltage - V

1.5

2.0

NOTE: Only one output is loaded at a time.

0.5

#### leakage current

0

-28

|                                                        | PARAMETER                      | TEST CONDITIONS                                      | VCC       | MIN | TYP | MAX | UNIT |
|--------------------------------------------------------|--------------------------------|------------------------------------------------------|-----------|-----|-----|-----|------|
| I <sub>Ikg</sub> (Px.x) High-impedance leakage current | High impodence leakage current | Port P1: P1.x, $0 \le x \le 7$ (see Notes 11 and 12) | 2.2 V/3 V |     |     | ±50 | nA   |
|                                                        |                                | Port P2: P2.x, $0 \le x \le 5$ (see Notes 11 and 12) | 2.2 V/3 V |     |     | ±50 | ΠA   |

NOTES: 11. The leakage current is measured with VSS or VCC applied to the corresponding pin(s), unless otherwise noted.

2.5

12. The leakage of the digital port pins is measured individually. The port pin must be selected for input and there must be no optional pullup or pulldown resistor.

-60

0

0.5

#### inputs Px.x, TAx

|                                              | PARAMETER                                       | TEST CONDITIONS                                    | VCC       | MIN | TYP | MAX | UNIT  |
|----------------------------------------------|-------------------------------------------------|----------------------------------------------------|-----------|-----|-----|-----|-------|
|                                              |                                                 | Port P1, P2: P1.x to P2.x,                         | 2.2 V/3 V | 1.5 |     |     | cycle |
| t <sub>(int)</sub> External interrupt timing | External trigger signal for the interrupt flag, | 2.2 V                                              | 62        |     |     |     |       |
|                                              |                                                 | (see Note 13)                                      | 3 V       | 50  |     |     | ns    |
|                                              |                                                 | ner_A, capture timing TA0, TA1, TA2. (see Note 14) | 2.2 V/3 V | 1.5 |     |     | cycle |
| t <sub>(cap)</sub> Timer_A, capture tim      | Timer_A, capture timing                         |                                                    | 2.2 V     | 62  |     |     |       |
|                                              |                                                 |                                                    | 3 V       | 50  |     |     | ns    |

NOTES: 13. The external signal sets the interrupt flag every time the minimum t<sub>int</sub> cycle and time parameters are met. It may be set even with trigger signals shorter than t<sub>int</sub>. Both the cycle and timing specifications must be met to ensure the flag is set. t<sub>int</sub> is measured in MCLK cycles.

14. The external capture signal triggers the capture event every time when the minimum t<sub>Cap</sub> cycles and time parameters are met. A capture may be triggered with capture signals even shorter than t<sub>Cap</sub>. Both the cycle and timing specifications must be met to ensure a correct capture of the 16-bit timer value and to ensure the flag is set.



electrical characteristics over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted) (continued)

#### internal signals TAx, SMCLK at Timer\_A

| PARAMETER             |                         | PARAMETER TEST CONDITIONS                               |           | MIN | TYP MAX | UNIT |
|-----------------------|-------------------------|---------------------------------------------------------|-----------|-----|---------|------|
| f(IN) Input frequency |                         | Internal TA0, TA1, TA2, t <sub>H</sub> = t <sub>l</sub> | 2.2 V     |     | 8       | MHz  |
|                       |                         | Internal IAO, IAT, IAZ, tH = tL                         | 3 V       |     | 10      |      |
| f(TAint)              | Timer_A clock frequency | Internally, SMCLK signal applied                        | 2.2 V/3 V | dc  | fSystem |      |

#### **USART (see Note 15)**

|                  | PARAMETER             | TEST CONDITIONS         | MIN | TYP | MAX | UNIT |
|------------------|-----------------------|-------------------------|-----|-----|-----|------|
| t <sub>(τ)</sub> | LICADT: dealitch time | V <sub>CC</sub> = 2.2 V | 200 | 430 | 800 | 20   |
|                  | USART: deglitch time  | V <sub>CC</sub> = 3 V   | 150 | 280 | 500 | ns   |

NOTE 15: The signal applied to the USART receive signal/terminal (URXD) should meet the timing requirements of  $t_{(\tau)}$  to ensure that the URXS flip-flop is set. The URXS flip-flop is set with negative pulses meeting the minimum-timing condition of  $t_{(\tau)}$ . The operating conditions to set the flag must be met independently from this timing constraint. The deglitch circuitry is active only on negative transitions on the URXD line.

#### outputs P1.x, P2.x, P3.x, TAx

| P.                 | ARAMETER                                   | TEST                                        | CONDITIONS                                                  | Vcc                            | MIN           | TYP           | MAX           | UNIT |  |
|--------------------|--------------------------------------------|---------------------------------------------|-------------------------------------------------------------|--------------------------------|---------------|---------------|---------------|------|--|
| f(P20)             |                                            | P2.0/ACLK,                                  | C <sub>L</sub> = 20 pF                                      | 2.2 V/3 V                      |               |               | fSystem       |      |  |
| f(TAx)             | Output frequency                           | TA0, TA1, TA2,<br>Internal clock source, SM | C <sub>L</sub> = 20 pF,<br>CLK signal applied (see Note 16) | 2.2 V/3 V                      | dc            |               | fSystem       | MHz  |  |
|                    |                                            |                                             | fSMCLK = fLFXT1 = fXT1                                      |                                | 40%           |               | 60%           |      |  |
|                    | P1.4/SMCLK,  CL = 20 pF  fSMCLK = fLFXT1/r | D1 4/SMCLK                                  | fSMCLK = fLFXT1 = fLF                                       | 2.2 V/3 V                      | 35%           |               | 65%           |      |  |
|                    |                                            | fSMCLK = fLFXT1/n                           |                                                             | 50%–<br>15 ns                  | 50%           | 50%+<br>15 ns |               |      |  |
| <sup>t</sup> (Xdc) |                                            |                                             | fSMCLK = fDCOCLK                                            | 2.2 V/3 V                      | 50%–<br>15 ns | 50%           | 50%+<br>15 ns |      |  |
|                    |                                            | DO O/A CLIK                                 | $f_{P20} = f_{LFXT1} = f_{XT1}$                             |                                | 40%           |               | 60%           |      |  |
|                    |                                            |                                             | P2.0/ACLK,<br>C <sub>I</sub> = 20 pF                        | $f_{P20} = f_{LFXT1} = f_{LF}$ | 2.2 V/3 V     | 30%           |               | 70%  |  |
|                    |                                            | $f_{P20} = f_{LFXT1/n}$                     |                                                             |                                | 50%           |               |               |      |  |
| t(TAdc)            |                                            | TA0, TA1, TA2,                              | $C_L = 20 \text{ pF}$ , Duty cycle = 50%                    | 2.2 V/3 V                      |               | 0             | ±50           | ns   |  |

NOTE 16: The limits of the system clock MCLK has to be met. MCLK and SMCLK can have different frequencies.



# electrical characteristics over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted) (continued)

#### Comparator\_A (see Note 17)

|                            | PARAMETER                            | TEST CONDITIONS                                                                         | VCC       | MIN  | TYP  | MAX                | UNIT |
|----------------------------|--------------------------------------|-----------------------------------------------------------------------------------------|-----------|------|------|--------------------|------|
| lan)                       |                                      | CAON=1, CARSEL=0, CAREF=0                                                               | 2.2 V     |      | 25   | 40                 |      |
| l(DD)                      |                                      | CAON=1, CARSEL=0, CAREF=0                                                               | 3 V       |      | 45   | 60                 | μΑ   |
| I(Refladder/               |                                      | CAON=1, CARSEL=0,<br>CAREF=1/2/3, No load at                                            | 2.2 V     |      | 30   | 50                 | μA   |
| RefDiode)                  |                                      | P2.3/CA0/TA1 and P2.4/CA1/TA2                                                           | 3 V       |      | 45   | 71                 | μΑ   |
| V(IC)                      | Common-mode input voltage            | CAON =1                                                                                 | 2.2 V/3 V | 0    |      | V <sub>CC</sub> -1 | V    |
| V(Ref025)                  | Voltage at 0.25 V <sub>CC</sub> node | PCA0=1, CARSEL=1, CAREF=1,<br>No load at P2.3/CA0/TA1 and<br>P2.4/CA1/TA2, See Figure 5 | 2.2 V/3 V | 0.23 | 0.24 | 0.25               |      |
| V(Ref050)                  | Voltage at 0.5 V <sub>CC</sub> node  | PCA0=1, CARSEL=1, CAREF=2,<br>No load at P2.3/CA0/TA1 and<br>P2.4/CA1/TA2, See Figure 5 | 2.2 V/3 V | 0.47 | 0.48 | 0.5                |      |
|                            |                                      | PCA0=1, CARSEL=1, CAREF=3,<br>No load at P2.3/CA0/TA1 and                               | 2.2 V     | 390  | 480  | 540                |      |
| V(RefVT)                   |                                      | P2.4/CA1/TA2, $T_A = 85^{\circ}C$                                                       | 3 V       | 400  | 490  | 550                | mV   |
| V <sub>(offset)</sub>      | Offset voltage                       | See Note 18                                                                             | 2.2 V/3 V | -30  |      | 30                 | mV   |
| V <sub>hys</sub>           | Input hysteresis                     | CAON=1                                                                                  | 2.2 V/3 V | 0    | 0.7  | 1.4                | mV   |
|                            |                                      | T <sub>A</sub> = 25°C, Overdrive 10 mV, Without                                         | 2.2 V     | 160  | 210  | 300                |      |
| 4                          |                                      | filter: CAF=0                                                                           | 3 V       | 80   | 150  | 240                | ns   |
| <sup>t</sup> (response LH) | )                                    | T <sub>A</sub> = 25°C, Overdrive 10 mV, With fil-                                       | 2.2 V     | 1.4  | 1.9  | 3.4                |      |
|                            |                                      | ter: CAF=1                                                                              | 3 V       | 0.9  | 1.5  | 2.6                | μs   |
|                            |                                      | T <sub>A</sub> = 25°C,                                                                  | 2.2 V     | 130  | 210  | 300                |      |
|                            |                                      | Overdrive 10 mV, without filter: CAF=0                                                  | 3 V       | 80   | 150  | 240                | ns   |
| t(response HL)             | )                                    | T <sub>A</sub> = 25°C,                                                                  | 2.2 V     | 1.4  | 1.9  | 3.4                |      |
|                            |                                      | Overdrive 10 mV, with filter: CAF=1                                                     | 3 V       | 0.9  | 1.5  | 2.6                | μs   |

NOTES: 17. The leakage current for the Comparator\_A terminals is identical to I<sub>lkg(Px.x)</sub> specification.

<sup>18.</sup> The input offset voltage can be cancelled by using the CAEX bit to invert the Comparator\_A inputs on successive measurements. The two successive measurements are then summed together.

electrical characteristics over recommended operating free-air temperature (unless otherwise noted) (continued)



650 V<sub>CC</sub> = 2.2 V 600 V(REFVT) - Reference Volts -mV **Typical** 550 500 450 400 -25 75 95 -45 15 35 55  $T_A$  – Free-Air Temperature –  $^{\circ}$ C

Figure 12.  $V_{(RefVT)}$  vs Temperature,  $V_{CC} = 3 V$ 

Figure 13.  $V_{(RefVT)}$  vs Temperature,  $V_{CC} = 2.2 \text{ V}$ 



Figure 14. Block Diagram of Comparator\_A Module



Figure 15. Overdrive Definition



electrical characteristics over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted) (continued)

#### **PUC/POR**

|                    | PARAMETER | TEST CONDITIONS              |                             | MIN | TYP | MAX | UNIT |
|--------------------|-----------|------------------------------|-----------------------------|-----|-----|-----|------|
| t(POR_delay)       | _         |                              |                             |     | 150 | 250 | μs   |
|                    |           | T <sub>A</sub> = -40°C       | V <sub>CC</sub> = 2.2 V/3 V | 1.4 |     | 1.8 | V    |
| V(POR)             | POR       | T <sub>A</sub> = 25°C        |                             | 1.1 |     | 1.5 | V    |
|                    |           | T <sub>A</sub> = 85°C        |                             | 0.8 |     | 1.2 | V    |
| V <sub>(min)</sub> |           |                              |                             | 0   |     | 0.4 | V    |
| t(reset)           | PUC/POR   | Reset is accepted internally |                             | 2   |     |     | μs   |



Figure 16. Power-On Reset (POR) vs Supply Voltage



Figure 17.  $V_{(POR)}$  vs Temperature

#### **RAM**

|         | PARAMETER                | MIN | NOM | MAX | UNIT |
|---------|--------------------------|-----|-----|-----|------|
| V(RAMh) | CPU halted (see Note 19) | 1.6 |     |     | V    |

NOTE 19: This parameter defines the minimum supply voltage V<sub>CC</sub> when the data in the program memory RAM remains unchanged. No program execution should happen during this supply voltage condition.



# electrical characteristics over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted) (continued)

#### crystal oscillator,LFXT1

|                     | PARAMETER          | TEST CONDITIONS                        | VCC         | MIN | TYP | MAX | UNIT |  |
|---------------------|--------------------|----------------------------------------|-------------|-----|-----|-----|------|--|
| C <sub>(XIN)</sub>  | Input capacitance  | XTS=0; LF mode selected                | 2.2 V / 3 V |     | 12  |     | рF   |  |
|                     |                    | XTS=1; XT1 mode selected (see Note 20) | 2.2 V / 3 V |     | 2   |     |      |  |
| C <sub>(XOUT)</sub> | Output capacitance | XTS=0; LF mode selected                | 2.2 V / 3 V |     | 12  |     | pF   |  |
|                     |                    | XTS=1; XT1 mode selected (see Note 20) | 2.2 V / 3 V |     | 2   |     | рг   |  |

NOTE 20: Requires external capacitors at both terminals. Values are specified by crystal manufacturers.

#### **DCO**

| PARAMETER           | TEST CONDITIONS                                                                            | VCC       | MIN                 | TYP   | MAX   | UNIT  |
|---------------------|--------------------------------------------------------------------------------------------|-----------|---------------------|-------|-------|-------|
| f(DCO03)            | R <sub>Sel</sub> = 0, DCO = 3, MOD = 0, DCOR = 0, T <sub>A</sub> = 25°C                    | 2.2 V     | 0.08                | 0.12  | 0.15  | MHz   |
|                     |                                                                                            | 3 V       | 0.08                | 0.13  | 0.16  |       |
| f(DCO13)            | $R_{Sel} = 1$ , DCO = 3, MOD = 0, DCOR = 0, $T_A = 25$ °C                                  | 2.2 V     | 0.14                | 0.19  | 0.23  | MHz   |
|                     |                                                                                            | 3 V       | 0.14                | 0.18  | 0.22  |       |
| f(DCO23)            | $R_{sel} = 2$ , DCO = 3, MOD = 0, DCOR = 0, $T_A = 25$ °C                                  | 2.2 V     | 0.22                | 0.30  | 0.36  | MHz   |
|                     |                                                                                            | 3 V       | 0.22                | 0.28  | 0.34  |       |
| f(DCO33)            | R <sub>sel</sub> = 3, DCO = 3, MOD = 0, DCOR = 0, T <sub>A</sub> = 25°C                    | 2.2 V     | 0.37                | 0.49  | 0.59  | MHz   |
|                     |                                                                                            | 3 V       | 0.37                | 0.47  | 0.56  |       |
| f(DCO43)            | R <sub>Sel</sub> = 4, DCO = 3, MOD = 0, DCOR = 0, T <sub>A</sub> = 25°C                    | 2.2 V     | 0.61                | 0.77  | 0.93  | MHz   |
|                     |                                                                                            | 3 V       | 0.61                | 0.75  | 0.9   |       |
| <i>t</i>            | R <sub>Sel</sub> = 5, DCO = 3, MOD = 0, DCOR = 0, T <sub>A</sub> = 25°C                    | 2.2 V     | 1                   | 1.2   | 1.5   | MHz   |
| f(DCO53)            |                                                                                            | 3 V       | 1                   | 1.3   | 1.5   |       |
| £                   | R <sub>Sel</sub> = 6, DCO = 3, MOD = 0, DCOR = 0, T <sub>A</sub> = 25°C                    | 2.2 V     | 1.6                 | 1.9   | 2.2   | MHz   |
| f(DCO63)            |                                                                                            | 3 V       | 1.69                | 2     | 2.29  |       |
| <b>.</b>            | R <sub>Sel</sub> = 7, DCO = 3, MOD = 0, DCOR = 0, T <sub>A</sub> = 25°C                    | 2.2 V     | 2.4                 | 2.9   | 3.4   | MHz   |
| f(DCO73)            |                                                                                            | 3 V       | 2.7                 | 3.2   | 3.65  |       |
| ,                   | R <sub>Sel</sub> = 7, DCO = 7, MOD = 0, DCOR = 0, T <sub>A</sub> = 25°C                    | 2.2 V     | 4                   | 4.5   | 4.9   | MHz   |
| f(DCO77)            |                                                                                            | 3 V       | 4.4                 | 4.9   | 5.4   |       |
| f(D0047)            | R <sub>Sel</sub> = 4, DCO = 7, MOD = 0, DCOR = 0, T <sub>A</sub> = 25°C                    |           | F <sub>D</sub> CO40 |       | MHz   |       |
| f(DCO47)            | N <sub>SE</sub>   = 4, DCO = 7, NIOD = 0, DCON = 0, 1A = 23 C                              |           | x1.7                | x2.1  | x2.5  | IVITZ |
| S <sub>(Rsel)</sub> | $S_R = f_{Rsel+1}/f_{Rsel}$                                                                | 2.2 V/3 V | 1.35                | 1.65  | 2     | ratio |
| S <sub>(DCO)</sub>  | S <sub>DCO</sub> = f <sub>DCO+1</sub> /f <sub>DCO</sub>                                    | 2.2 V/3 V | 1.07                | 1.12  | 1.16  |       |
| Dt                  | Temperature drift, R <sub>Sel</sub> = 4, DCO = 3, MOD = 0 (see Note 21)                    | 2.2 V     | -0.31               | -0.36 | -0.40 | %/°C  |
|                     |                                                                                            | 3 V       | -0.33               | -0.38 | -0.43 |       |
| DV                  | Drift with V <sub>CC</sub> variation, R <sub>Sel</sub> = 4, DCO = 3, MOD = 0 (see Note 21) | 2.2 V/3 V | 0                   | 5     | 10    | %/V   |

NOTES: 21. These parameters are not production tested.



<sup>22.</sup> Please do not exceed maximum system frequency.

electrical characteristics over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted) (continued)



Figure 18. DCO Characteristics

# principle characteristics of the DCO

- Individual devices have a minimum and maximum operation frequency. The specified parameters for fDCOx0 to fDCOx7 are valid for all devices.
- The DCO control bits DCO0, DCO1 and DCO2 have a step size as defined in parameter S<sub>DCO</sub>.
- The modulation control bits MOD0 to MOD4 select how often  $f_{DCO+1}$  is used within the period of 32 DCOCLK cycles.  $f_{DCO}$  is used for the remaining cycles. The frequency is an average =  $f_{DCO} \times (2^{MOD/32})$ .
- All ranges selected by  $R_{sel(n)}$  overlap with  $R_{sel(n+1)}$ :  $R_{sel0}$  overlaps with  $R_{sel1}$ , ...  $R_{sel6}$  overlaps with  $R_{sel7}$ .

### wake-up from lower power modes (LPMx)

|                     | PARAMETER                | TEST CO                      | NDITIONS                     | MIN | TYP | MAX | UNIT |
|---------------------|--------------------------|------------------------------|------------------------------|-----|-----|-----|------|
| t(LPM0)             |                          | V <sub>CC</sub> = 2.2 V/3 V  |                              |     | 100 |     |      |
| t(LPM2)             |                          | $V_{CC} = 2.2 \text{ V/3 V}$ |                              |     | 100 |     | ns   |
| · ,                 |                          | f(MCLK) = 1 MHz,             | V <sub>CC</sub> = 2.2 V/3 V  |     |     | 6   |      |
| t(LPM3)             | Delay time (see Note 22) | f(MCLK) = 2 MHz,             | V <sub>CC</sub> = 2.2 V/3 V  |     |     | 6   | μs   |
|                     | Delay time (see Note 23) | f(MCLK) = 3 MHz,             | $V_{CC} = 2.2 \text{ V/3 V}$ |     |     | 6   |      |
| <sup>t</sup> (LPM4) |                          | f(MCLK) = 1 MHz,             | V <sub>CC</sub> = 2.2 V/3 V  |     |     | 6   |      |
|                     |                          | f(MCLK) = 2 MHz,             | V <sub>CC</sub> = 2.2 V/3 V  |     |     | 6   | μs   |
|                     |                          | f(MCLK) = 3 MHz,             | V <sub>CC</sub> = 2.2 V/3 V  |     |     | 6   |      |

NOTE 23: Parameter applicable only if DCOCLK is used for MCLK.

SLAS312 - JULY 2001

# electrical characteristics over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted) (continued)

#### JTAG/programming

| PARAMETER         | TEST CONDITIONS                                       | MIN                                    | TYP             | MAX             | UNIT |         |
|-------------------|-------------------------------------------------------|----------------------------------------|-----------------|-----------------|------|---------|
| face              | TCK frequency, JTAG/test (see Note 26)                | V <sub>CC</sub> = 2.2 V                | dc              |                 |      | MHz     |
| f(TCK)            | Tok frequency, 31AG/test (see Note 20)                | V <sub>CC</sub> = 3 V                  | dc              |                 | 10   | IVII IZ |
| V <sub>(FB)</sub> | Fuse blow voltage (see Notes 24 and 25)               | 6                                      |                 | 7               | V    |         |
| I <sub>(FB)</sub> | Supply current on TEST during fuse blow (see Note 25) |                                        |                 | 100             | mA   |         |
| t(FB)             | Time to blow the fuse (see Note 25)                   |                                        |                 |                 | 1    | ms      |
| I(DD-PGM)         | Current during program cycle (see Note 27)            | V <sub>CC</sub> = 2.7 V/3.6 V          |                 | 3               | 5    | mA      |
| I(DD-ERASE)       | Current during erase cycle (see Note 27)              | $V_{CC} = 2.7 \text{ V}/3.6 \text{ V}$ |                 | 3               | 7    | mA      |
| t(retention)      | Write/erase cycles                                    |                                        | 10 <sup>4</sup> | 10 <sup>5</sup> |      |         |
|                   | Data retention T <sub>J</sub> = 25°C                  |                                        | 100             |                 |      | Year    |

NOTES: 24. The power source to blow the fuse is applied to TEST pin.

- 25. Once the JTAG fuse is blown, no further access to the MSP430 JTAG/test feature is possible. The JTAG block is switched to bypass
- 26. f<sub>(TCK)</sub> may be restricted to meet the timing requirements of the module selected.
- 27. Duration of the program/erase cycle is determined by f(FTG) applied to the flash timing controller. It can be calculated as follows:

t(word write) =  $35 \times 1/f(FTG)$ t(block write, byte 0) =  $30 \times 1/f(FTG)$ t(block write, byte 1 – 63) =  $20 \times 1/f(FTG)$ 

 $t(mass erase) = 5297 \times 1/f(FTG)$ 

 $t(page erase) = 4819 \times 1/f(FTG)$ 



# input/output schematic

# Port P1, P1.0 to P1.3, input/output with Schmitt-trigger



NOTE: x = Bit/identifier, 0 to 3 for port P1

| P1Sel.0 | P1DIR.0 | P1DIR.0 | P1OUT.0 | VSS          | P1IN.0 | TACLK <sup>†</sup> | P1IE.0 | P1IFG.0 | P1IES.0 |
|---------|---------|---------|---------|--------------|--------|--------------------|--------|---------|---------|
| P1Sel.1 | P1DIR.1 | P1DIR.1 | P1OUT.1 | Out0 signal† | P1IN.1 | CCI0A <sup>†</sup> | P1IE.1 | P1IFG.1 | P1IES.1 |
| P1Sel.2 | P1DIR.2 | P1DIR.2 | P1OUT.2 | Out1 signal† | P1IN.2 | CCI1A <sup>†</sup> | P1IE.2 | P1IFG.2 | P1IES.2 |
| P1Sel.3 | P1DIR.3 | P1DIR.3 | P1OUT.3 | Out2 signal† | P1IN.3 | CCI2A <sup>†</sup> | P1IE.3 | P1IFG.3 | P1IES.3 |

<sup>†</sup> Signal from or to Timer\_A

Port P1, P1.4 to P1.7, input/output with Schmitt-trigger and in-system access features



| P1Sel.4 | P1DIR.4 | P1DIR.4 | P1OUT.4 | SMCLK                    | P1IN.4 | unused | P1IE.4 | P1IFG.4 | P1IES.4 |
|---------|---------|---------|---------|--------------------------|--------|--------|--------|---------|---------|
| P1Sel.5 | P1DIR.5 | P1DIR.5 | P1OUT.5 | Out0 signal <sup>†</sup> | P1IN.5 | unused | P1IE.5 | P1IFG.5 | P1IES.5 |
| P1Sel.6 | P1DIR.6 | P1DIR.6 | P1OUT.6 | Out1 signal <sup>†</sup> | P1IN.6 | unused | P1IE.6 | P1IFG.6 | P1IES.6 |
| P1Sel.7 | P1DIR.7 | P1DIR.7 | P1OUT.7 | Out2 signal <sup>†</sup> | P1IN.7 | unused | P1IE.7 | P1IFG.7 | P1IES.7 |

<sup>†</sup> Signal from or to Timer\_A



# Port P2, P2.0 to P2.2, input/output with Schmitt-trigger



| PnSel.x | PnDIR.x | DIRECTION<br>CONTROL<br>FROM MODULE | PnOUT.x | MODULE X OUT | PnIN.x | MODULE X IN | PnIE.x | PnIFG.x | PnIES.x |
|---------|---------|-------------------------------------|---------|--------------|--------|-------------|--------|---------|---------|
| P2Sel.0 | P2DIR.0 | P2DIR.0                             | P2OUT.0 | ACLK         | P2IN.0 | unused      | P2IE.0 | P2IFG.0 | P1IES.0 |
| P2Sel.1 | P2DIR.1 | P2DIR.1                             | P2OUT.1 | VSS          | P2IN.1 | INCLK†      | P2IE.1 | P2IFG.1 | P1IES.1 |
| P2Sel.2 | P2DIR.2 | P2DIR.2                             | P2OUT.2 | CAOUT        | P2IN.2 | CCI0B†      | P2IE.2 | P2IFG.2 | P1IES.2 |

<sup>†</sup> Signal from or to Timer\_A

# Port P2, P2.3 to P2.4, input/output with Schmitt-trigger



| PnSel.x | PnDIR.x | DIRECTION<br>CONTROL<br>FROM MODULE | PnOUT.x | MODULE X OUT             | PnIN.x | MODULE X IN | PnIE.x | PnIFG.x | PnIES.x |
|---------|---------|-------------------------------------|---------|--------------------------|--------|-------------|--------|---------|---------|
| P2Sel.3 | P2DIR.3 | P2DIR.3                             | P2OUT.3 | Out1 signal <sup>†</sup> | P2IN.3 | unused      | P2IE.3 | P2IFG.3 | P1IES.3 |
| P2Sel.4 | P2DIR.4 | P2DIR.4                             | P2OUT.4 | Out2 signal†             | P2IN.4 | unused      | P2IE.4 | P2IFG.4 | P1IES.4 |

<sup>†</sup> Signal from Timer\_A



Port P2, P2.5, input/output with Schmitt-trigger and R<sub>OSC</sub> function for the Basic Clock module



| PnSel.x | PnDIR.x | DIRECTION<br>CONTROL<br>FROM MODULE | PnOUT.x | MODULE X OUT | PnIN.x | MODULE X IN | PnIE.x | PnIFG.x | PnlES.x |
|---------|---------|-------------------------------------|---------|--------------|--------|-------------|--------|---------|---------|
| P2Sel.5 | P2DIR.5 | P2DIR.5                             | P2OUT.5 | VSS          | P2IN.5 | unused      | P2IE.5 | P2IFG.5 | P2IES.5 |

# Port P2, unbonded bits P2.6 and P2.7



NOTE: x = Bit/identifier, 6 to 7 for port P2 without external pins

| P2Sel.x | P2DIR.x | DIRECTION-<br>CONTROL<br>FROM MODULE | P2OUT.x | MODULE X OUT | P2IN.x | MODULE X IN | P2IE.x | P2IFG.x | P2IES.x |
|---------|---------|--------------------------------------|---------|--------------|--------|-------------|--------|---------|---------|
| P2Sel.6 | P2DIR.6 | P2DIR.6                              | P2OUT.6 | VSS          | P2IN.6 | unused      | P2IE.6 | P2IFG.6 | P2IES.6 |
| P2Sel.7 | P2DIR.7 | P2DIR.7                              | P2OUT.7 | VSS          | P2IN.7 | unused      | P2IE.7 | P2IFG.7 | P2IES.7 |

NOTE: Unbonded bits 6 and 7 of port P2 can be used as interrupt flags. Only software can affect the interrupt flags. They work as software interrupts.



# port P3, P3.0 and P3.4 to P3.7, input/output with Schmitt-trigger



| PnSel.x | PnDIR.x | DIRECTION<br>CONTROL<br>FROM MODULE | PnOUT.x | MODULE X OUT     | PnIN.x | MODULE X IN |
|---------|---------|-------------------------------------|---------|------------------|--------|-------------|
| P3Sel.0 | P3DIR.0 | DVSS                                | P3OUT.0 | DVSS             | P3IN.0 | STE0        |
| P3Sel.4 | P3DIR.4 | DV <sub>CC</sub>                    | P3OUT.4 | UTXD0†           | P3IN.4 | Unused      |
| P3Sel.5 | P3DIR.5 | DVSS                                | P3OUT.5 | DVSS             | P3IN.5 | URXD0‡      |
| P3Sel.6 | P3DIR.6 | DV <sub>SS</sub>                    | P3OUT.6 | DV <sub>SS</sub> | P3IN.6 | Unused      |
| P3Sel.7 | P3DIR.7 | $DV_SS$                             | P3OUT.7 | DV <sub>SS</sub> | P3IN.7 | Unused      |

<sup>†</sup> Output from USART0 module

# port P3, P3.1, input/output with Schmitt-trigger



<sup>‡</sup> Input to USART0 module

### port P3, P3.2, input/output with Schmitt-trigger



### port P3, P3.3, input/output with Schmitt-trigger



NOTE: UART mode:

The UART clock can only be an input. If UART mode and UART function are selected, the P3.3/UCLK0 is always an input.

SPI, slave mode:

The clock applied to UCLK0 is used to shift data in and out.

SPI, master mode:

The clock to shift data in and out is supplied to connected devices on pin P3.3/UCLK0 (in slave mode).

### JTAG fuse check mode

MSP430 devices that have the fuse on the TEST terminal have a fuse check mode that tests the continuity of the fuse the first time the JTAG port is accessed after a power-on reset (POR). When activated, a fuse check current flows from the TEST pin to ground if the fuse is not burned. Care must be taken to avoid accidentally activating the fuse check mode and increasing overall system power consumption.

When the TEST pin is taken back low after a test or programming session, the fuse check mode and sense currents are terminated.

#### NOTE:

The CODE and RAM data protection is ensured if the JTAG fuse is blown and the 256-bit bootloader access key is used. Also see the *bootstrap loader* section for more information.



### **MECHANICAL DATA**

# DW (R-PDSO-G\*\*)

### **16 PINS SHOWN**

### PLASTIC SMALL-OUTLINE PACKAGE



NOTES: A. All linear dimensions are in inches (millimeters).

- B. This drawing is subject to change without notice.
- C. Body dimensions do not include mold flash or protrusion not to exceed 0.006 (0,15).
- D. Falls within JEDEC MS-013



SLAS312 - JULY 2001

# PW (R-PDSO-G\*\*)

#### PLASTIC SMALL-OUTLINE PACKAGE

### 14 PINS SHOWN



NOTES: A. All linear dimensions are in millimeters.

B. This drawing is subject to change without notice.

C. Body dimensions do not include mold flash or protrusion not to exceed 0,15.

D. Falls within JEDEC MO-153

#### **IMPORTANT NOTICE**

Texas Instruments and its subsidiaries (TI) reserve the right to make changes to their products or to discontinue any product or service without notice, and advise customers to obtain the latest version of relevant information to verify, before placing orders, that information being relied on is current and complete. All products are sold subject to the terms and conditions of sale supplied at the time of order acknowledgment, including those pertaining to warranty, patent infringement, and limitation of liability.

TI warrants performance of its products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent TI deems necessary to support this warranty. Specific testing of all parameters of each device is not necessarily performed, except those mandated by government requirements.

Customers are responsible for their applications using TI components.

In order to minimize risks associated with the customer's applications, adequate design and operating safeguards must be provided by the customer to minimize inherent or procedural hazards.

TI assumes no liability for applications assistance or customer product design. TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such products or services might be or are used. TI's publication of information regarding any third party's products or services does not constitute TI's approval, license, warranty or endorsement thereof.

Reproduction of information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations and notices. Representation or reproduction of this information with alteration voids all warranties provided for an associated TI product or service, is an unfair and deceptive business practice, and TI is not responsible nor liable for any such use.

Resale of TI's products or services with <u>statements different from or beyond the parameters</u> stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service, is an unfair and deceptive business practice, and TI is not responsible nor liable for any such use.

Also see: Standard Terms and Conditions of Sale for Semiconductor Products, www.ti.com/sc/docs/stdterms.htm

Mailing Address:

Texas Instruments
Post Office Box 655303
Dallas, Texas 75265