Chapter Excerpt from SLAU208



Chapter 1 SLAU400F–August 2012–Revised March 2018

# Timer\_A

Page

**NOTE:** This chapter is an excerpt from the *MSP430x5xx and MSP430x6xx Family User's Guide*. The most recent version of the full user's guide is available from <a href="http://www.ti.com/lit/pdf/slau208">http://www.ti.com/lit/pdf/slau208</a>.

Timer\_A is a 16-bit timer and counter with multiple capture/compare registers. There can be multiple Timer\_A modules on a given device (see the device-specific data sheet). This chapter describes the operation and use of the Timer\_A module.

#### Topic



#### Timer\_A Introduction

## 1.1 Timer\_A Introduction

Timer\_A is a 16-bit timer/counter with up to seven capture/compare registers. Timer\_A can support multiple capture/compares, PWM outputs, and interval timing. Timer\_A also has extensive interrupt capabilities. Interrupts may be generated from the counter on overflow conditions and from each of the capture/compare registers.

Timer\_A features include:

- Asynchronous 16-bit timer/counter with four operating modes
- Selectable and configurable clock source
- Up to seven configurable capture/compare registers
- Configurable outputs with pulse width modulation (PWM) capability
- Asynchronous input and output latching
- Interrupt vector register for fast decoding of all Timer\_A interrupts

The block diagram of Timer\_A is shown in Figure 1-1.

### NOTE: Use of the word count

*Count* is used throughout this chapter. It means the counter must be in the process of counting for the action to take place. If a particular value is directly written to the counter, an associated action does not take place.

#### NOTE: Nomenclature

There may be multiple instantiations of Timer\_A on a given device. The prefix TAx is used, where x is a greater than equal to zero indicating the Timer\_A instantiation. For devices with one instantiation, x = 0. The suffix n, where n = 0 to 6, represents the specific capture/compare registers associated with the Timer\_A instantiation.



**Timer Block** TASSEL ID IDEX Timer Clock MC *∤*2 **∤**2 *∤* 3 15 0 2 16-bit Timer TAxCLK 00 Divider Divider Count - EQU0 TAxR /1/2/4/8 /1.../8 Mode ACLK 01 Clear RC SMCLK 10 Set TAxCTL T INCLK 11 TAIFG TACLR CCR0 CCR1 CCR2 CCR3 CCR4 CCR5 CCR6 CCIS СМ logic COV ∤2 2 SCS CCI6A 00 Capture 15 0 Mode CCI6B 01 0 TAxCCR6 GND · 10 Sync Timer Clock 1 VCC 11 Ϋ́ Comparator 6 CCI EQU6 CAP A SCCI γ ΕN 0 Set TAxCCR6 CCIFG OUT -Output Þ D Set Q OUT6 Signal Unit4 EQU0 Timer Clock Reset 3 POR OUTMOD

Copyright © 2016, Texas Instruments Incorporated

Figure 1-1. Timer\_A Block Diagram



The Timer\_A module is configured with user software. The setup and operation of Timer\_A are discussed in the following sections.

#### 1.2.1 16-Bit Timer Counter

The 16-bit timer/counter register, TAxR, increments or decrements (depending on mode of operation) with each rising edge of the clock signal. TAxR can be read or written with software. Additionally, the timer can generate an interrupt when it overflows.

TAR may be cleared by setting the TACLR bit. Setting TACLR also clears the clock divider counter logic (the divider setting remains unchanged) and count direction for up/down mode.

#### NOTE: Modifying Timer\_A registers

TI recommends stopping the timer before modifying its operation (with exception of the interrupt enable, interrupt flag, and TACLR) to avoid errant operating conditions.

When the timer clock is asynchronous to the CPU clock, any read from TAxR should occur while the timer is not operating or the results may be unpredictable. Alternatively, the timer may be read multiple times while operating, and a majority vote taken in software to determine the correct reading. Any write to TAxR takes effect immediately.

### 1.2.1.1 Clock Source Select and Divider

The timer clock can be sourced from ACLK, SMCLK, or externally from TAxCLK or INCLK. The clock source is selected with the TASSEL bits. The selected clock source may be passed directly to the timer or divided by 2, 4, or 8, using the ID bits. The selected clock source can be further divided by 2, 3, 4, 5, 6, 7, or 8 using the TAIDEX bits. The timer clock divider logic is reset when TACLR is set.

#### NOTE: Timer\_A dividers

After programming ID or TAIDEX bits, set the TACLR bit. This clears the contents of TAXR and resets the clock divider logic to a defined state. The clock dividers are implemented as down counters. Therefore, when the TACLR bit is cleared, the timer clock immediately begins clocking at the first rising edge of the Timer\_A clock source selected with the TASSEL bits and continues clocking at the divider settings set by the ID and TAIDEX bits.

### 1.2.2 Starting the Timer

The timer may be started or restarted in the following ways:

- The timer counts when  $MC > \{0\}$  and the clock source is active.
- When the timer mode is either up or up/down, the timer may be stopped by writing 0 to TAxCCR0. The timer may then be restarted by writing a nonzero value to TAxCCR0. In this scenario, the timer starts incrementing in the up direction from zero.

### 1.2.3 Timer Mode Control

The timer has four modes of operation: stop, up, continuous, and up/down (see Table 1-1). The operating mode is selected with the MC bits.

| MC | Mode       | Description                                                                             |
|----|------------|-----------------------------------------------------------------------------------------|
| 00 | Stop       | The timer is halted.                                                                    |
| 01 | Up         | The timer repeatedly counts from zero to the value of TAxCCR0                           |
| 10 | Continuous | The timer repeatedly counts from zero to 0FFFFh.                                        |
| 11 | Up/down    | The timer repeatedly counts from zero up to the value of TAxCCR0 and back down to zero. |

| Tahlo | 1_1 | Timor | Modes |
|-------|-----|-------|-------|
| Iable |     | Inner | woues |

### 1.2.3.1 Up Mode

The up mode is used if the timer period must be different from 0FFFFh counts. The timer repeatedly counts up to the value of compare register TAxCCR0, which defines the period (see Figure 1-2). The number of timer counts in the period is TAxCCR0 + 1. When the timer value equals TAxCCR0, the timer restarts counting from zero. If up mode is selected when the timer value is greater than TAxCCR0, the timer immediately restarts counting from zero.



Figure 1-2. Up Mode

The TAXCCR0 CCIFG interrupt flag is set when the timer *counts* to the TAXCCR0 value. The TAIFG interrupt flag is set when the timer *counts* from TAXCCR0 to zero. Figure 1-3 shows the flag set cycle.



Figure 1-3. Up Mode Flag Setting

### 1.2.3.1.1 Changing Period Register TAxCCR0

When changing TAxCCR0 while the timer is running, if the new period is greater than or equal to the old period or greater than the current count value, the timer counts up to the new period. If the new period is less than the current count value, the timer rolls to zero. However, one additional count may occur before the counter rolls to zero.



#### 1.2.3.2 Continuous Mode

In the continuous mode, the timer repeatedly counts up to 0FFFFh and restarts from zero as shown in Figure 1-4. The capture/compare register TAxCCR0 works the same way as the other capture/compare registers.



Figure 1-4. Continuous Mode

The TAIFG interrupt flag is set when the timer *counts* from 0FFFFh to zero. Figure 1-5 shows the flag set cycle.



Figure 1-5. Continuous Mode Flag Setting

### 1.2.3.3 Use of Continuous Mode

The continuous mode can be used to generate independent time intervals and output frequencies. Each time an interval is completed, an interrupt is generated. The next time interval is added to the TAxCCRn register in the interrupt service routine. Figure 1-6 shows two separate time intervals,  $t_0$  and  $t_1$ , being added to the capture/compare registers. In this usage, the time interval is controlled by hardware, not software, without impact from interrupt latency. Up to n (where n = 0 to 6), independent time intervals or output frequencies can be generated using capture/compare registers.





Time intervals can be produced with other modes as well, where TAxCCR0 is used as the period register. Their handling is more complex since the sum of the old TAxCCRn data and the new period can be higher than the TAxCCR0 value. When the previous TAxCCRn value plus  $t_x$  is greater than the TAxCCR0 data, the TAxCCR0 value must be subtracted to obtain the correct time interval.

### 1.2.3.4 Up/Down Mode

The up/down mode is used if the timer period must be different from 0FFFFh counts, and if symmetrical pulse generation is needed. The timer repeatedly counts up to the value of compare register TAxCCR0 and back down to zero (see Figure 1-7). The period is twice the value in TAxCCR0.



Figure 1-7. Up/Down Mode

The count direction is latched. This allows the timer to be stopped and then restarted in the same direction it was counting before it was stopped. If this is not desired, the TACLR bit must be set to clear the direction. Setting TACLR also clears the TAR value and the clock divider counter logic (the divider setting remains unchanged).

In up/down mode, the TAXCCR0 CCIFG interrupt flag and the TAIFG interrupt flag are set only once during a period, separated by one-half the timer period. The TAXCCR0 CCIFG interrupt flag is set when the timer *counts* from TAXCCR0-1 to TAXCCR0, and TAIFG is set when the timer completes *counting* down from 0001h to 0000h. Figure 1-8 shows the flag set cycle.





### 1.2.3.4.1 Changing Period Register TAxCCR0

When changing TAxCCR0 while the timer is running and counting in the down direction, the timer continues its descent until it reaches zero. The new period takes effect after the counter counts down to zero.

When the timer is counting in the up direction, and the new period is greater than or equal to the old period or greater than the current count value, the timer counts up to the new period before counting down.

When the timer is counting in the up direction and the new period is less than the current count value, the timer begins counting down. However, one additional count may occur before the counter begins counting down.



### 1.2.3.5 Use of Up/Down Mode

The up/down mode supports applications that require dead times between output signals (see Section 1.2.5). For example, to avoid overload conditions, two outputs driving an H-bridge must never be in a high state simultaneously. In the example shown in Figure 1-9, the  $t_{dead}$  is:

 $t_{dead} = t_{timer} \times (TAxCCR1 - TAxCCR2)$ 

Where:

 $t_{dead}$  = Time during which both outputs need to be inactive

 $t_{timer}$  = Cycle time of the timer clock

TAxCCRn = Content of capture/compare register n

The TAxCCRn registers are not buffered. They update immediately when written to. Therefore, any required dead time is not maintained automatically.



Figure 1-9. Output Unit in Up/Down Mode

### 1.2.4 Capture/Compare Blocks

Up to seven identical capture/compare blocks, TAxCCRn (where n = 0 to 7), are present in Timer\_A. Any of the blocks may be used to capture the timer data or to generate time intervals.

### 1.2.4.1 Capture Mode

The capture mode is selected when CAP = 1. Capture mode is used to record time events. It can be used for speed computations or time measurements. The capture inputs CCIxA and CCIxB are connected to external pins or internal signals and are selected with the CCIS bits. The CM bits select the capture edge of the input signal as rising, falling, or both. A capture occurs on the selected edge of the input signal. If a capture occurs:

- The timer value is copied into the TAxCCRn register.
- The interrupt flag CCIFG is set.

The input signal level can be read at any time from the CCI bit. Devices may have different signals connected to CCIxA and CCIxB. See the device-specific data sheet for the connections of these signals.

The capture signal can be asynchronous to the timer clock and cause a race condition. Setting the SCS bit synchronizes the capture with the next timer clock. Setting the SCS bit to synchronize the capture signal with the timer clock is recommended (see Figure 1-10).







### NOTE: Changing Capture Inputs

Changing capture inputs while in capture mode may cause unintended capture events. To avoid this scenario, capture inputs should only be changed when capture mode is disabled  $(CM = \{0\} \text{ or } CAP = 0).$ 

Overflow logic is provided in each capture/compare register to indicate if a second capture was performed before the value from the first capture was read. Bit COV is set when this occurs as shown in Figure 1-11. COV must be reset with software.



Figure 1-11. Capture Cycle



#### 1.2.4.1.1 Capture Initiated by Software

Captures can be initiated by software. The CMx bits can be set for capture on both edges. Software then sets CCIS1 = 1 and toggles bit CCIS0 to switch the capture signal between  $V_{CC}$  and GND, initiating a capture each time CCIS0 changes state:

#### NOTE: Capture Initiated by Software

In general, changing capture inputs while in capture mode may cause unintended capture events. For this scenario, switching the capture input between VCC and GND, disabling the capture mode is not required.

#### 1.2.4.2 Compare Mode

The compare mode is selected when CAP = 0. The compare mode is used to generate PWM output signals or interrupts at specific time intervals. When TAXR *counts* to the value in a TAXCCRn, where n represents the specific capture/compare register.

- Interrupt flag CCIFG is set.
- Internal signal EQUn = 1.
- EQUn affects the output according to the output mode.
- The input signal CCI is latched into SCCI.

### 1.2.5 Output Unit

Each capture/compare block contains an output unit. The output unit is used to generate output signals, such as PWM signals. Each output unit has eight operating modes that generate signals based on the EQU0 and EQUn signals.

### 1.2.5.1 Output Modes

The output modes are defined by the OUTMOD bits and are described in Table 1-2. The OUTn signal is changed with the rising edge of the timer clock for all modes except mode 0. Output modes 2, 3, 6, and 7 are not useful for output unit 0 because EQUn = EQU0.

| OUTMODx | Mode         | Description                                                                                                                                                                      |
|---------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000     | Output       | The output signal OUTn is defined by the OUT bit. The OUTn signal updates immediately when OUT is updated.                                                                       |
| 001     | Set          | The output is set when the timer <i>counts</i> to the TAxCCRn value. It remains set until a reset of the timer, or until another output mode is selected and affects the output. |
| 010     | Toggle/Reset | The output is toggled when the timer <i>counts</i> to the TAxCCRn value. It is reset when the timer <i>counts</i> to the TAxCCR0 value.                                          |
| 011     | Set/Reset    | The output is set when the timer <i>counts</i> to the TAxCCRn value. It is reset when the timer <i>counts</i> to the TAxCCR0 value.                                              |
| 100     | Toggle       | The output is toggled when the timer <i>counts</i> to the TAxCCRn value. The output period is double the timer period.                                                           |
| 101     | Reset        | The output is reset when the timer <i>counts</i> to the TAxCCRn value. It remains reset until another output mode is selected and affects the output.                            |
| 110     | Toggle/Set   | The output is toggled when the timer <i>counts</i> to the TAxCCRn value. It is set when the timer <i>counts</i> to the TAxCCR0 value.                                            |
| 111     | Reset/Set    | The output is reset when the timer <i>counts</i> to the TAxCCRn value. It is set when the timer <i>counts</i> to the TAxCCR0 value.                                              |

| Table 1-2. ( | Output | Modes |
|--------------|--------|-------|
|--------------|--------|-------|



### 1.2.5.1.1 Output Example—Timer in Up Mode

The OUTn signal is changed when the timer *counts* up to the TAxCCRn value and rolls from TAxCCR0 to zero, depending on the output mode. An example is shown in Figure 1-12 using TAxCCR0 and TAxCCR1.



Figure 1-12. Output Example – Timer in Up Mode



### 1.2.5.1.2 Output Example – Timer in Continuous Mode

The OUTn signal is changed when the timer reaches the TAxCCRn and TAxCCR0 values, depending on the output mode. An example is shown in Figure 1-13 using TAxCCR0 and TAxCCR1.



Figure 1-13. Output Example – Timer in Continuous Mode

# 1.2.5.1.3 Output Example – Timer in Up/Down Mode

The OUTn signal changes when the timer equals TAxCCRn in either count direction and when the timer equals TAxCCR0, depending on the output mode. An example is shown in Figure 1-14 using TAxCCR0 and TAxCCR2.



### NOTE: Switching between output modes

When switching between output modes, one of the OUTMOD bits should remain set during the transition, unless switching to mode 0. Otherwise, output glitching can occur, because a NOR gate decodes output mode 0. A safe method for switching between output modes is to use output mode 7 as a transition state:

| BIS | #OUTMOD_7,&TA0CCTL1 | ; Set output mode=7   |
|-----|---------------------|-----------------------|
| BIC | #OUTMOD,&TA0CCTL1   | ; Clear unwanted bits |



### 1.2.6 Timer\_A Interrupts

Two interrupt vectors are associated with the 16-bit Timer\_A module:

- TAxCCR0 interrupt vector for TAxCCR0 CCIFG
- TAXIV interrupt vector for all other CCIFG flags and TAIFG

In capture mode, any CCIFG flag is set when a timer value is captured in the associated TAxCCRn register. In compare mode, any CCIFG flag is set if TAxR *counts* to the associated TAxCCRn value. Software may also set or clear any CCIFG flag. All CCIFG flags request an interrupt when their corresponding CCIE bit and the GIE bit are set.

### 1.2.6.1 TAxCCR0 Interrupt

The TAXCCR0 CCIFG flag has the highest Timer\_A interrupt priority and has a dedicated interrupt vector as shown in Figure 1-15. The TAXCCR0 CCIFG flag is automatically reset when the TAXCCR0 interrupt request is serviced.



Figure 1-15. Capture/Compare TAxCCR0 Interrupt Flag

### 1.2.6.2 TAxIV, Interrupt Vector Generator

The TAxCCRy CCIFG flags and TAIFG flags are prioritized and combined to source a single interrupt vector. The interrupt vector register TAxIV is used to determine which flag requested an interrupt.

The highest-priority enabled interrupt generates a number in the TAxIV register (see register description). This number can be evaluated or added to the program counter to automatically enter the appropriate software routine. Disabled Timer\_A interrupts do not affect the TAxIV value.

Any access, read or write, of the TAxIV register automatically resets the highest-pending interrupt flag. If another interrupt flag is set, another interrupt is immediately generated after servicing the initial interrupt. For example, if the TAxCCR1 and TAxCCR2 CCIFG flags are set when the interrupt service routine accesses the TAxIV register, TAxCCR1 CCIFG is reset automatically. After the RETI instruction of the interrupt service routine is executed, the TAxCCR2 CCIFG flag generates another interrupt.



### 1.2.6.2.1 TAxIV Software Example

The following software example shows the recommended use of TAxIV and the handling overhead. The TAxIV value is added to the PC to automatically jump to the appropriate routine. The example assumes a single instantiation of the largest timer configuration available.

The numbers at the right margin show the necessary CPU cycles for each instruction. The software overhead for different interrupt sources includes interrupt latency and return-from-interrupt cycles, but not the task handling itself. The latencies are:

- Capture/compare block TA0CCR0: 11 cycles
- Capture/compare blocks TA0CCR1, TA0CCR2, TA0CCR3, TA0CCR4, TA0CCR5, TA0CCR6: 16 cycles
- Timer overflow TA0IFG: 14 cycles

| ; Interr      | upt handl        | er for TAOCCRO |                            | Cycles |
|---------------|------------------|----------------|----------------------------|--------|
| CCIFG_0_<br>; | _HND<br><br>RETI | ; Start of     | handler Interrupt latency  | 6<br>5 |
| ; Interr      | upt handl        | er for TAOIFG, | TA0CCR1 through TA0CCR6 CC | CIFG.  |
| TA0_HND       |                  |                | ; Interrupt latency        | 6      |
|               | ADD              |                | ; Add offset to Jump table | 3      |
|               | RETI             |                | ; Vector 0: No interrupt   | 5      |
|               | JMP              |                | ; Vector 2: TAOCCR1        | 2      |
|               | JMP              |                | ; Vector 4: TAOCCR2        | 2      |
|               | JMP              |                | ; Vector 6: TAOCCR3        | 2      |
|               | JMP              |                | ; Vector 8: TAOCCR4        | 2      |
|               | JMP              |                | ; Vector 10: TAOCCR5       | 2<br>2 |
|               | JMP              | CCIFG_6_HND    | ; Vector 12: TAOCCR6       | Z      |
| TA0IFG_H      | IND              |                | ; Vector 14: TA0IFG Flag   |        |
|               |                  |                | ; Task starts here         |        |
|               | RETI             |                |                            | 5      |
| CCIFG_6       |                  |                | ; Vector 12: TA0CCR6       |        |
| CCIFG_0_      | -                |                | ; Task starts here         |        |
|               | •••<br>RETT      |                | ; Back to main program     | 5      |
|               | KEIT             |                | / Back to main program     | 5      |
| CCIFG_5_      | HND              |                | ; Vector 10: TAOCCR5       |        |
|               |                  |                | ; Task starts here         |        |
|               | RETI             |                | ; Back to main program     | 5      |
| CCIFG_4       | HND              |                | ; Vector 8: TA0CCR4        |        |
|               | •••              |                | ; Task starts here         |        |
|               | RETI             |                | ; Back to main program     | 5      |
| CCIFG_3       | HND              |                | ; Vector 6: TA0CCR3        |        |
| 00110_0       |                  |                | ; Task starts here         |        |
|               | RETI             |                | ; Back to main program     | 5      |
|               |                  |                |                            |        |
| CCIFG_2_      | HND              |                | ; Vector 4: TAOCCR2        |        |
|               |                  |                | ; Task starts here         |        |
|               | RETI             |                | ; Back to main program     | 5      |
| CCIFG_1_      | HND              |                | ; Vector 2: TA0CCR1        |        |
|               |                  |                | ; Task starts here         |        |
|               | RETI             |                | ; Back to main program     | 5      |
|               |                  |                |                            |        |



Timer\_A Registers

www.ti.com

# 1.3 Timer\_A Registers

Timer\_A registers are listed in Table 1-3 for the largest configuration available. The base address can be found in the device-specific data sheet.

| Offset | Acronym  | Register Name                      | Туре       | Access | Reset | Section       |
|--------|----------|------------------------------------|------------|--------|-------|---------------|
| 00h    | TAxCTL   | Timer_Ax Control                   | Read/write | Word   | 0000h | Section 1.3.1 |
| 02h    | TAxCCTL0 | Timer_Ax Capture/Compare Control 0 | Read/write | Word   | 0000h | Section 1.3.3 |
| 04h    | TAxCCTL1 | Timer_Ax Capture/Compare Control 1 | Read/write | Word   | 0000h | Section 1.3.3 |
| 06h    | TAxCCTL2 | Timer_Ax Capture/Compare Control 2 | Read/write | Word   | 0000h | Section 1.3.3 |
| 08h    | TAxCCTL3 | Timer_Ax Capture/Compare Control 3 | Read/write | Word   | 0000h | Section 1.3.3 |
| 0Ah    | TAxCCTL4 | Timer_Ax Capture/Compare Control 4 | Read/write | Word   | 0000h | Section 1.3.3 |
| 0Ch    | TAxCCTL5 | Timer_Ax Capture/Compare Control 5 | Read/write | Word   | 0000h | Section 1.3.3 |
| 0Eh    | TAxCCTL6 | Timer_Ax Capture/Compare Control 6 | Read/write | Word   | 0000h | Section 1.3.3 |
| 10h    | TAxR     | Timer_Ax Counter                   | Read/write | Word   | 0000h | Section 1.3.2 |
| 12h    | TAxCCR0  | Timer_Ax Capture/Compare 0         | Read/write | Word   | 0000h | Section 1.3.4 |
| 14h    | TAxCCR1  | Timer_Ax Capture/Compare 1         | Read/write | Word   | 0000h | Section 1.3.4 |
| 16h    | TAxCCR2  | Timer_Ax Capture/Compare 2         | Read/write | Word   | 0000h | Section 1.3.4 |
| 18h    | TAxCCR3  | Timer_Ax Capture/Compare 3         | Read/write | Word   | 0000h | Section 1.3.4 |
| 1Ah    | TAxCCR4  | Timer_Ax Capture/Compare 4         | Read/write | Word   | 0000h | Section 1.3.4 |
| 1Ch    | TAxCCR5  | Timer_Ax Capture/Compare 5         | Read/write | Word   | 0000h | Section 1.3.4 |
| 1Eh    | TAxCCR6  | Timer_Ax Capture/Compare 6         | Read/write | Word   | 0000h | Section 1.3.4 |
| 2Eh    | TAxIV    | Timer_Ax Interrupt Vector          | Read only  | Word   | 0000h | Section 1.3.5 |
| 20h    | TAxEX0   | Timer_Ax Expansion 0               | Read/write | Word   | 0000h | Section 1.3.6 |

### Table 1-3. Timer\_A Registers

# 1.3.1 TAxCTL Register

Timer\_Ax Control Register

|        |        |        | Figure 1-16 | 6. TAxCTL Reg | ister  |        |        |
|--------|--------|--------|-------------|---------------|--------|--------|--------|
| 15     | 14     | 13     | 12          | 11            | 10     | 9      | 8      |
|        |        | Rese   | erved       |               |        | TAS    | SEL    |
| rw-(0) | rw-(0) | rw-(0) | rw-(0)      | rw-(0)        | rw-(0) | rw-(0) | rw-(0) |
| 7      | 6      | 5      | 4           | 3             | 2      | 1      | 0      |
| 1[     | C      | M      | IC          | Reserved      | TACLR  | TAIE   | TAIFG  |
| rw-(0) | rw-(0) | rw-(0) | rw-(0)      | rw-(0)        | w-(0)  | rw-(0) | rw-(0) |

| Table 1-4.     | TAxCTL | Register | Description |
|----------------|--------|----------|-------------|
| 1 4 6 1 6 1 11 |        |          |             |

| Bit   | Field    | Туре | Reset | Description                                                                                                                                                                                                                                                                          |
|-------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-10 | Reserved | RW   | 0h    | Reserved                                                                                                                                                                                                                                                                             |
| 9-8   | TASSEL   | RW   | Oh    | Timer_A clock source select<br>00b = TAxCLK<br>01b = ACLK<br>10b = SMCLK<br>11b = INCLK                                                                                                                                                                                              |
| 7-6   | ID       | RW   | Oh    | Input divider. These bits along with the TAIDEX bits select the divider for the input clock.<br>00b = /1<br>01b = /2<br>10b = /4<br>11b = /8                                                                                                                                         |
| 5-4   | MC       | RW   | Oh    | Mode control. Setting MC = 00h when Timer_A is not in use conserves power.<br>00b = Stop mode: Timer is halted<br>01b = Up mode: Timer counts up to TAxCCR0<br>10b = Continuous mode: Timer counts up to 0FFFFh<br>11b = Up/down mode: Timer counts up to TAxCCR0 then down to 0000h |
| 3     | Reserved | RW   | 0h    | Reserved                                                                                                                                                                                                                                                                             |
| 2     | TACLR    | RW   | 0h    | Timer_A clear. Setting this bit clears TAR, the clock divider logic (the divider setting remains unchanged), and the count direction. The TACLR bit is automatically reset and is always read as zero.                                                                               |
| 1     | TAIE     | RW   | Oh    | Timer_A interrupt enable. This bit enables the TAIFG interrupt request.<br>0b = Interrupt disabled<br>1b = Interrupt enabled                                                                                                                                                         |
| 0     | TAIFG    | RW   | Oh    | Timer_A interrupt flag<br>0b = No interrupt pending<br>1b = Interrupt pending                                                                                                                                                                                                        |



Timer\_A Registers

# 1.3.2 TAxR Register

Timer\_Ax Counter Register

|        |        |        | Figure 1-1 | 7. TAxR Regi | ster   |        |        |
|--------|--------|--------|------------|--------------|--------|--------|--------|
| 15     | 14     | 13     | 12         | 11           | 10     | 9      | 8      |
|        |        |        | TA         | xR           |        |        |        |
| rw-(0) | rw-(0) | rw-(0) | rw-(0)     | rw-(0)       | rw-(0) | rw-(0) | rw-(0) |
| 7      | 6      | 5      | 4          | 3            | 2      | 1      | 0      |
|        |        |        | TA         | xR           |        |        |        |
| rw-(0) | rw-(0) | rw-(0) | rw-(0)     | rw-(0)       | rw-(0) | rw-(0) | rw-(0) |

# Table 1-5. TAxR Register Description

| Bit  | Field | Туре | Reset | Description                                                  |
|------|-------|------|-------|--------------------------------------------------------------|
| 15-0 | TAxR  | RW   | 0h    | Timer_A register. The TAxR register is the count of Timer_A. |

# 1.3.3 TAxCCTLn Register

Timer\_Ax Capture/Compare Control n Register

|        |        |        | Figure 1-18. | TAxCCTLn Re | egister |          |        |
|--------|--------|--------|--------------|-------------|---------|----------|--------|
| 15     | 14     | 13     | 12           | 11          | 10      | 9        | 8      |
| C      | M      | CC     | CIS          | SCS         | SCCI    | Reserved | CAP    |
| rw-(0) | rw-(0) | rw-(0) | rw-(0)       | rw-(0)      | r-(0)   | r-(0)    | rw-(0) |
| 7      | 6      | 5      | 4            | 3           | 2       | 1        | 0      |
|        | OUTMOD |        | CCIE         | CCI         | OUT     | COV      | CCIFG  |
| rw-(0) | rw-(0) | rw-(0) | rw-(0)       | r           | rw-(0)  | rw-(0)   | rw-(0) |

| Table 1-6. TAxCCTLn Register Description |
|------------------------------------------|
|------------------------------------------|

| Bit   | Field    | Туре | Reset | Description                                                                                                                                                                                                                                     |  |  |  |  |
|-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 15-14 | СМ       | RW   | Oh    | Capture mode<br>00b = No capture<br>01b = Capture on rising edge<br>10b = Capture on falling edge<br>11b = Capture on both rising and falling edges                                                                                             |  |  |  |  |
| 13-12 | CCIS     | RW   | Oh    | Capture/compare input select. These bits select the TAxCCR0 input signal. See<br>the device-specific data sheet for specific signal connections.<br>00b = CCIxA<br>01b = CCIxB<br>10b = GND<br>11b = VCC                                        |  |  |  |  |
| 11    | SCS      | RW   | Oh    | Synchronize capture source. This bit is used to synchronize the capture input<br>signal with the timer clock.<br>Ob = Asynchronous capture<br>1b = Synchronous capture                                                                          |  |  |  |  |
| 10    | SCCI     | RW   | 0h    | Synchronized capture/compare input. The selected CCI input signal is latched with the EQUx signal and can be read from this bit.                                                                                                                |  |  |  |  |
| 9     | Reserved | R    | 0h    | Reserved. Reads as 0.                                                                                                                                                                                                                           |  |  |  |  |
| 8     | САР      | RW   | Oh    | Capture mode<br>0b = Compare mode<br>1b = Capture mode                                                                                                                                                                                          |  |  |  |  |
| 7-5   | OUTMOD   | RW   | Oh    | Output mode. Modes 2, 3, 6, and 7 are not useful for TAxCCR0 because EQUx<br>= EQU0.<br>000b = OUT bit value<br>001b = Set<br>010b = Toggle/reset<br>011b = Set/reset<br>100b = Toggle<br>101b = Reset<br>110b = Toggle/set<br>111b = Reset/set |  |  |  |  |
| 4     | CCIE     | RW   | Oh    | Capture/compare interrupt enable. This bit enables the interrupt request of the corresponding CCIFG flag.<br>0b = Interrupt disabled<br>1b = Interrupt enabled                                                                                  |  |  |  |  |
| 3     | CCI      | R    | 0h    | Capture/compare input. The selected input signal can be read by this bit.                                                                                                                                                                       |  |  |  |  |
| 2     | OUT      | RW   | Oh    | Output. For output mode 0, this bit directly controls the state of the output.<br>0b = Output low<br>1b = Output high                                                                                                                           |  |  |  |  |



Timer\_A Registers

www.ti.com

| Bit | Field | Туре | Reset | Description                                                                                                                                                               |  |  |  |
|-----|-------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 1   | COV   | RW   | 0h    | Capture overflow. This bit indicates a capture overflow occurred. COV must be reset with software.<br>0b = No capture overflow occurred<br>1b = Capture overflow occurred |  |  |  |
| 0   | CCIFG | RW   | Oh    | Capture/compare interrupt flag<br>0b = No interrupt pending<br>1b = Interrupt pending                                                                                     |  |  |  |

# Table 1-6. TAxCCTLn Register Description (continued)

# 1.3.4 TAxCCRn Register

Timer\_A Capture/Compare n Register

|        |        |        | Figure 1-19. | TAxCCRn Re | gister |        |        |
|--------|--------|--------|--------------|------------|--------|--------|--------|
| 15     | 14     | 13     | 12           | 11         | 10     | 9      | 8      |
|        |        |        | TAxC         | CCRn       |        |        |        |
| rw-(0) | rw-(0) | rw-(0) | rw-(0)       | rw-(0)     | rw-(0) | rw-(0) | rw-(0) |
| 7      | 6      | 5      | 4            | 3          | 2      | 1      | 0      |
|        |        |        | TAxC         | CCRn       |        |        |        |
| rw-(0) | rw-(0) | rw-(0) | rw-(0)       | rw-(0)     | rw-(0) | rw-(0) | rw-(0) |

### Table 1-7. TAxCCRn Register Description

| Bit  | Field   | Туре | Reset | Description                                                                                                                                                                                                                 |
|------|---------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | TAxCCR0 | RW   | 0h    | Compare mode: TAxCCRn holds the data for the comparison to the timer value<br>in the Timer_A Register, TAR.<br>Capture mode: The Timer_A Register, TAR, is copied into the TAxCCRn register<br>when a capture is performed. |

# 1.3.5 TAxIV Register

Timer\_Ax Interrupt Vector Register

#### Figure 1-20. TAxIV Register

| 15 | 14 | 13 | 12 | 11    | 10    | 9     | 8  |
|----|----|----|----|-------|-------|-------|----|
|    |    |    | TA | λIV   |       |       |    |
| rO | rO | rO | rO | rO    | rO    | rO    | rO |
| 7  | 6  | 5  | 4  | 3     | 2     | 1     | 0  |
|    |    |    | TA | AIV   |       |       |    |
| rO | rO | rO | rO | r-(0) | r-(0) | r-(0) | rO |

### Table 1-8. TAxIV Register Description

| Bit  | Field | Туре | Reset | Description                                                                                              |
|------|-------|------|-------|----------------------------------------------------------------------------------------------------------|
| 15-0 | TAIV  | R    | 0h    | Timer_A interrupt vector value                                                                           |
|      |       |      |       | 00h = No interrupt pending                                                                               |
|      |       |      |       | 02h = Interrupt Source: Capture/compare 1; Interrupt Flag: TAxCCR1 CCIFG;<br>Interrupt Priority: Highest |
|      |       |      |       | 04h = Interrupt Source: Capture/compare 2; Interrupt Flag: TAxCCR2 CCIFG                                 |
|      |       |      |       | 06h = Interrupt Source: Capture/compare 3; Interrupt Flag: TAxCCR3 CCIFG                                 |
|      |       |      |       | 08h = Interrupt Source: Capture/compare 4; Interrupt Flag: TAxCCR4 CCIFG                                 |
|      |       |      |       | 0Ah = Interrupt Source: Capture/compare 5; Interrupt Flag: TAxCCR5 CCIFG                                 |
|      |       |      |       | 0Ch = Interrupt Source: Capture/compare 6; Interrupt Flag: TAxCCR6 CCIFG                                 |
|      |       |      |       | 0Eh = Interrupt Source: Timer overflow; Interrupt Flag: TAxCTL TAIFG; Interrupt Priority: Lowest         |



Timer\_A Registers

# 1.3.6 TAxEX0 Register

Timer\_Ax Expansion 0 Register

|    |    |          | Figure 1-21 | . TAxEX0 Reg | gister |                       |        |
|----|----|----------|-------------|--------------|--------|-----------------------|--------|
| 15 | 14 | 13       | 12          | 11           | 10     | 9                     | 8      |
|    |    |          | Rese        | erved        |        |                       |        |
| rO | rO | rO       | rO          | rO           | rO     | rO                    | rO     |
| 7  | 6  | 5        | 4           | 3            | 2      | 1                     | 0      |
|    |    | Reserved |             |              |        | TAIDEX <sup>(1)</sup> |        |
| rO | rO | rO       | rO          | rO           | rw-(0) | rw-(0)                | rw-(0) |

<sup>(1)</sup> After programming TAIDEX bits and configuration of the timer, set TACLR bit to ensure proper reset of the timer divider logic.

| Bit  | Field    | Туре | Reset | Description                                                                                                                                                                                                                                                                           |
|------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-3 | Reserved | R    | 0h    | Reserved. Reads as 0.                                                                                                                                                                                                                                                                 |
| 2-0  | TAIDEX   | RW   | Oh    | Input divider expansion. These bits along with the ID bits select the divider for<br>the input clock.<br>000b = Divide by 1<br>001b = Divide by 2<br>010b = Divide by 3<br>011b = Divide by 4<br>100b = Divide by 5<br>101b = Divide by 6<br>110b = Divide by 7<br>111b = Divide by 8 |

#### IMPORTANT NOTICE FOR TI DESIGN INFORMATION AND RESOURCES

Texas Instruments Incorporated ('TI") technical, application or other design advice, services or information, including, but not limited to, reference designs and materials relating to evaluation modules, (collectively, "TI Resources") are intended to assist designers who are developing applications that incorporate TI products; by downloading, accessing or using any particular TI Resource in any way, you (individually or, if you are acting on behalf of a company, your company) agree to use it solely for this purpose and subject to the terms of this Notice.

TI's provision of TI Resources does not expand or otherwise alter TI's applicable published warranties or warranty disclaimers for TI products, and no additional obligations or liabilities arise from TI providing such TI Resources. TI reserves the right to make corrections, enhancements, improvements and other changes to its TI Resources.

You understand and agree that you remain responsible for using your independent analysis, evaluation and judgment in designing your applications and that you have full and exclusive responsibility to assure the safety of your applications and compliance of your applications (and of all TI products used in or for your applications) with all applicable regulations, laws and other applicable requirements. You represent that, with respect to your applications, you have all the necessary expertise to create and implement safeguards that (1) anticipate dangerous consequences of failures, (2) monitor failures and their consequences, and (3) lessen the likelihood of failures that might cause harm and take appropriate actions. You agree that prior to using or distributing any applications. TI has not conducted any testing other than that specifically described in the published documentation for a particular TI Resource.

You are authorized to use, copy and modify any individual TI Resource only in connection with the development of applications that include the TI product(s) identified in such TI Resource. NO OTHER LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE TO ANY OTHER TI INTELLECTUAL PROPERTY RIGHT, AND NO LICENSE TO ANY TECHNOLOGY OR INTELLECTUAL PROPERTY RIGHT OF TI OR ANY THIRD PARTY IS GRANTED HEREIN, including but not limited to any patent right, copyright, mask work right, or other intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information regarding or referencing third-party products or services does not constitute a license to use such products or services, or a warranty or endorsement thereof. Use of TI Resources may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

TI RESOURCES ARE PROVIDED "AS IS" AND WITH ALL FAULTS. TI DISCLAIMS ALL OTHER WARRANTIES OR REPRESENTATIONS, EXPRESS OR IMPLIED, REGARDING TI RESOURCES OR USE THEREOF, INCLUDING BUT NOT LIMITED TO ACCURACY OR COMPLETENESS, TITLE, ANY EPIDEMIC FAILURE WARRANTY AND ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT OF ANY THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

TI SHALL NOT BE LIABLE FOR AND SHALL NOT DEFEND OR INDEMNIFY YOU AGAINST ANY CLAIM, INCLUDING BUT NOT LIMITED TO ANY INFRINGEMENT CLAIM THAT RELATES TO OR IS BASED ON ANY COMBINATION OF PRODUCTS EVEN IF DESCRIBED IN TI RESOURCES OR OTHERWISE. IN NO EVENT SHALL TI BE LIABLE FOR ANY ACTUAL, DIRECT, SPECIAL, COLLATERAL, INDIRECT, PUNITIVE, INCIDENTAL, CONSEQUENTIAL OR EXEMPLARY DAMAGES IN CONNECTION WITH OR ARISING OUT OF TI RESOURCES OR USE THEREOF, AND REGARDLESS OF WHETHER TI HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

You agree to fully indemnify TI and its representatives against any damages, costs, losses, and/or liabilities arising out of your noncompliance with the terms and provisions of this Notice.

This Notice applies to TI Resources. Additional terms apply to the use and purchase of certain types of materials, TI products and services. These include; without limitation, TI's standard terms for semiconductor products <a href="http://www.ti.com/sc/docs/stdterms.htm">http://www.ti.com/sc/docs/stdterms.htm</a>), evaluation modules, and samples (<a href="http://www.ti.com/sc/docs/stdterms.htm">http://www.ti.com/sc/docs/stdterms.htm</a>), evaluation

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2018, Texas Instruments Incorporated