

# Using the MSP430 Timer\_D Module in Hi-Resolution Mode

Damian Szmulewicz

#### **ABSTRACT**

This application report describes the use of the high-resolution feature of the Timer\_D module introduced in MSP430F51x1 and MSP430F51x2 devices. Timer\_D enables applications that require high resolution such as capacitive touch detection [1], PWM DACs [2], advanced LED lighting, and digital controllers for power supplies [3]. This application report provides an advanced description of the use and calibration of Timer\_D in high-resolution mode. For a basic description of Timer\_D and its registers, see the *Timer\_D* chapter from the *MSP430x5xx* and *MSP430x6xx* Family User's Guide (SLAU208). The examples shown in this document refer to the data sheet of the MSP430F5172 microcontroller [4], but the concepts are applicable to all devices with a Timer\_D module. When working with this document, refer to the device-specific data sheet for all specifications.

Project collateral and source code discussed in this document are available for download from <a href="http://www.ti.com/lit/zip/slaa601">http://www.ti.com/lit/zip/slaa601</a>.

#### **Contents** 1 2 3 4 5 7 8 9 **List of Figures** 1 2 3 4 5 6 7 8 9 10 11 12 13 14 **List of Tables** All trademarks are the property of their respective owners.



Introduction www.ti.com

| 2  | Frequency Adjustment Bits for Free-Running Mode                                                                                                           | 5  |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 3  | Table Example for Local Clock Generator Frequency (over recommended ranges of supply voltage and operating free-air temperature – unless otherwise noted) | 5  |
| 4  | Internal connection of ACLK to TD0.2 With CCI2B Selection                                                                                                 | 7  |
| 5  | Timer_D Trimmed Clock Frequencies Sample (over recommended ranges of supply voltage and operating free-air temperature – unless otherwise noted)          | 10 |
| 6  | HRCG Voltage and Temperature Drift Sample Table (over recommended ranges of supply voltage and operating free-air temperature – unless otherwise noted)   | 10 |
| 7  | Effective TDxCL0 Values for Various TDxCL0 Configurations                                                                                                 | 16 |
| 8  | Advantages and Disadvantages of Timer_D Operation Modes                                                                                                   | 22 |
| 9  | Free-running vs. Regulated Mode                                                                                                                           | 22 |
| 10 | Invalid Timer_D Configuations (over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted)                      | 23 |
| 11 | TDCLx Load Events                                                                                                                                         | 23 |
| 12 | Timer_D Power Consumption                                                                                                                                 | 24 |

# 1 Introduction

Timer\_D is the third generation MSP430 timer module. Table 1 summarizes the main differences between Timer\_D and its predecessors Timer\_A and Timer\_B. Timer\_D includes a hi-resolution clock generator that can generate timer clock frequencies up to 256 MHz.

Table 1. Basic Comparison Among MSP430 General-Purpose Timers

| Features                                     | Timer_A                  | Timer_B                  | Timer_D                                            |
|----------------------------------------------|--------------------------|--------------------------|----------------------------------------------------|
| Max Timer Clock Frequency                    | 25 MHz                   | 25 MHz                   | 256 MHz                                            |
| Capture Mode                                 | Single capture mode only | Single capture mode only | Single and dual capture mode                       |
| Dual Edge PWM Control (dead band generation) | X                        | Х                        | Rising, falling or rising and falling edge control |
| Timer Control via External Events            | X                        | X                        | Yes (Timer event control mode)                     |
| Synchronize Multiple Timer Instances         | X                        | X                        | Yes (Timer event control mode)                     |
| Synchronized Loading of Compare Registers    | Х                        | Yes (group latching)     | Yes (group latching)                               |
| LPMx Operation Without External Crystal      | Х                        | Х                        | Yes (in free-running mode)                         |
| Enable Digital Power Factor<br>Correction    | Х                        | Х                        | Yes (shortening TEC events)                        |

This application report focuses on the high-resolution features introduced to MSP430 with Timer\_D. For the timer's functionality in normal mode and for a description of all registers, see *Timer\_D Module* (Chapter Excerpt From MSP430x5xx Family, SLAU208) (SLAU232). In addition, this document is designed to complement, and not replace, the MSP430x5xx and MSP430x6xx Family User's Guide (SLAU208) and device-specific data sheets.



### 2 TIMER\_D High Resolution Mode Overview

Timer\_D is equipped with a high-resolution generation block, as shown in Figure 1, that achieves a maximum frequency of 256 MHz.



Figure 1. Timer\_D High-Resolution Block

The high-resolution feature of Timer\_D is enabled by setting the TDHEN bit in the TDxHCTL0 register. When TDHEN = 0, the timer runs in normal mode and its functionality is similar to Timer\_A and Timer\_B with some enhancements. For more information on the functionality of Timer\_D for TDHEN = 0, see the MSP430x5xx and MSP430x6xx Family User's Guide (SLAU208). When TDHEN = 1, the timer is in high-resolution mode, and it operates in either Regulated or Free-running mode as shown in Figure 2. Regulation is enabled by setting TDHREGEN = 1 in TDxHCTL0 and it is disabled by clearing TDHREGEN = 0 in TDxHCTL0. The following sections describe the functionality of Timer\_D in each of the presented operation modes.



Figure 2. Timer\_D High-Resolution Operation Modes



Free-Running Mode www.ti.com

#### 3 Free-Running Mode

When TDHREGEN = 0, Timer\_D operates in free-running mode

#### 3.1 **Timer Source Clock**

In free-running mode, the Timer\_D clock source selected by TDSSELx is ignored. Instead, a Timer\_D internal local clock generator is used as the source for the Timer D hi-res clock generator. This clock generator is internal to the high-resolution generator as shown in Figure 3 and does not require any input clock source external to the Timer D module to operate. Hence, this oscillator enables the operation of Timer\_D when no other clock source, such as SMCLK, is available. As a result, Timer\_D is operational in LPM0 through LPM4 without the need for an external clock. The current consumption in LPMx is dominated by the Timer\_D power specifications; hence, currents higher than the ones specified for the low-power modes are observed when Timer D is running. The overview of the high-resolution generator is shown in Figure 3.



Figure 3. Free-Running Mode High-Resolution Block

NOTE: It is important to distinguish the internal Timer\_D Clock from the high-resolution local clock. The internal Timer\_D clock is an input to the high-resolution generator. The high-resolution local clock is an output of the high-resolution generator.



#### 3.2 Frequency Adjustments

When operating in free-running mode, the frequency of the timer is determined by the bits shown in Table 2. These bits are configured in software during run time.

Table 2. Frequency Adjustment Bits for Free-Running Mode

| Bits        | Register Name | Description                                                                                                       |
|-------------|---------------|-------------------------------------------------------------------------------------------------------------------|
| TDHMx       | TDxHCTL0      | Timer_D high-resolution clock multiplication factor.                                                              |
| TDHCLKCR    | TDxHCTL1      | Timer_D high-resolution coarse clock range selection bit. Must be set for a source clock > 15 MHz.                |
| TDHCLKRx    | TDxHCTL1      | Bits used to define the coarse clock range of the high-resolution clock generator.                                |
| TDHCLKSRx   | TDxHCTL1      | Timer_D high-resolution clock sub-range selection bits. About ±3% frequency adjustment for each step of TDHCLKSRx |
| TDHCLKTRIMx | TDxHCTL1      | Timer_D high-resolution clock trim selection bits. About ±1.5% frequency adjustment for each step of TDHCLKTRIMx  |

In free-running mode, the frequency of Timer\_D for a respective bit configuration is given in the "Timer\_D, Local Clock Generator Frequency" electrical characteristics table of the device-specific data sheet. Table 3 shows an example of a snippet of the table for MSP430F5172. For frequency information, see the device-specific data sheet. The programmer must ensure that the configuration bit settings selected for the high resolution generator is  $\leq$  256 MHz. Any frequency above 256 MHz can be functional, but it is outside of the device specifications.

Table 3. Table Example for Local Clock Generator Frequency (over recommended ranges of supply voltage and operating free-air temperature – unless otherwise noted)

|                           | Parameter                  | Test Conditions                                                                           | Min | Тур | Max | Unit    |
|---------------------------|----------------------------|-------------------------------------------------------------------------------------------|-----|-----|-----|---------|
| t.                        | HRCG frequency (0, 0, 64)  | TDHREGEN = 0, TDHMx = 0, TDHCLKCR = 1,<br>TDHCLKRx = 0, TDHCLKSRx = 0,<br>TDHCLKTRIM = 64 | 39  | 56  | 73  | MHz     |
| <sup>1</sup> HRCG(0,0,64) |                            | TDHREGEN = 0, TDHMx = 1, TDHCLKCR = 1,<br>TDHCLKRx = 0, TDHCLKSRx = 0,<br>TDHCLKTRIM = 64 | 78  | 112 | 146 |         |
| t .                       | HRCG frequency (0, 7, 64)  | TDHREGEN = 0, TDHMx = 0, TDHCLKCR = 1,<br>TDHCLKRx = 0, TDHCLKSRx = 7,<br>TDHCLKTRIM = 64 | 46  | 66  | 86  | MHz     |
| f <sub>HRCG(0,7,64)</sub> | TINGS frequency (0, 7, 04) | TDHREGEN = 0, TDHMx = 1, TDHCLKCR = 1, TDHCLKRx = 0, TDHCLKSRx = 7, TDHCLKTRIM = 64       | 92  | 132 | 172 | IVII IZ |

Note that for each bit combination in Table 3, a wide range of frequency is presented. For instance, if the application needs Timer\_D to run at 56 MHz, then the first configuration from Table 3 is a good starting point since it shows a typical frequency of 56 MHz; however the actual frequency of the timer will be anywhere between 39 MHz and 73 MHz. This accuracy may not be acceptable in some applications, and it is a result of variations on operating voltage, temperature and variations in the process of the silicon. Thus, calibration is required to achieve the desired frequency in free-running mode. Section 3.3 describes a technique to calibrate the timer to overcome this problem.



Free-Running Mode www.ti.com

# 3.3 Frequency Calibration Technique for Timer\_D

This section presents one technique for calibrating Timer\_D to a desired frequency. Given its temperature and voltage dependence and device variations, calibration is required in most applications using Timer\_D in free-running mode.

First, it is important to understand the steps required to change the frequency once the timer is running. These steps are presented in the MSP430x5xx and MSP430x6xx Family User's Guide (SLAU208) and repeated here for convenience:

- 1. Increment TDHCLKTRIMx by 1 until TDHCLKTRIMx = 64 is reached. If the clock range must be changed, proceed to Step 1a for a higher clock range or to Step 1b for a lower clock range.
  - (a) If the clock range, TDHCLKRx, must be changed to a higher clock range, then the TDHCLKSRx must be brought to TDHCLKSRx = 31 by incrementing by 1.
  - (b) If the clock range, TDHCLKRx, must be changed to a lower clock range, then the TDHCLKSRx must be brought to TDHCLKSRx = 0 by decrementing by 1.
- 2. Change the clock range, TDHCLKRx, after step 1a or 1b. Increment or decrement by 1 at a time.
- 3. Increment or decrement TDHCLKSRx by 1 until the desired clock frequency is reached to an accuracy of approximately ±3%.
- 4. Increment or decrement TDHCLKTRIMx by 1 until the desired clock frequency is reached to an accuracy of approximately ±1.5%.
- 5. Further changes to track the frequency because of changes in the environment can be typically done by changing only the TDHCLTRIMx values.

In order to calibrate the timer at run time, feedback from the timer output is required. One way to obtain this required feedback is to use a slower clock, such as ACLK running at  $f_{SLOW}$  Hz, and the input capture feature of Timer\_D. By capturing the edges of the slow timer running at a known frequency, and obtaining the difference (TDR<sub>2</sub>- TDR<sub>1</sub>) in Timer\_D counts between slower timer edges as shown in Figure 4, the actual frequency of Timer\_D can be determined; hence, providing system feedback for calibration. Note that the accuracy of calibration will be given by the accuracy of  $f_{SLOW}$ . Since  $f_{SLOW}$  is known, the expected Timer\_D count difference for the elapsed time between ACLK edges can be calculated; consequently, evaluating the actual number of TDR<sub>2</sub>- TDR<sub>1</sub>, and adjusting TDxHCTL1 until the expected count value is achieved results in a calibrated timer.



Figure 4. Timer D Calibration Using ACLK



Timer\_D is initialized to the desired range shown in Table 3. In this example, ACLK running at 32768Hz is then sourced to the input capture pin of Timer\_D. In the MSP430F5172, this connection can be made in software without the use of any external pins, since TD0.2 is internally connected through a multiplexer (see Figure 5) to ACLK when the input CCI2B is selected as shown in Table 4. For Timer\_D signal connections, see the device-specific data-sheet.



Figure 5. CCIx Multiplexer for Signal Connections

Table 4. Internal connection of ACLK to TD0.2 With CCI2B Selection

| Input Pin Number | Device Input Signal | Module Input Signal |
|------------------|---------------------|---------------------|
| ACLK (Internal)  | TD0.2               | CCI2B               |

Timer\_D is initialized to run in continuous mode to minimize the probability of getting a timer overflow during calibration. Timer\_D counts from 0 to 0xFFFF, or 65535<sub>10</sub>, in t<sub>overflow</sub> seconds:

$$t_{overflow} = \frac{1}{f_{desired}} * 65535 \cdot \text{seconds}$$
 (1)

Where  $f_{desired}$  is the desired final frequency of Timer\_D. Figure 6 shows Timer\_D counting in increments of  $\frac{1}{f_{desired}}$ .



Figure 6. Counts vs.  $t_{\text{TIMERD}}$  for Timer D. Each Count Takes  $^{\textit{f}}$  desired Seconds

The input capture feature of Timer\_D is selected to trigger an interrupt on both edges of ACLK. The time between edges,  ${}^{t}ACLK_{1/2}$ , is 1/2 the period of ACLK as shown in Figure 7.



Free-Running Mode www.ti.com



Figure 7. ACLK Timing Waveform

The expected Timer\_D counts between ACLK edges, *Expected Count*<sub>TIMERD</sub>, can be calculated from  $f_{desired}$  and  $t_{ACLK}$ :

Expected Count<sub>TIMERD</sub> = 
$$^{t}$$
ACLK<sub>1/2</sub> \*  $^{f}$ desired (2)

Similarly, the actual number of counts between ACLK edges is:

$$Actual Count_{TIMERD} = {}^{t}ACLK_{1/2} * {}^{f}actual$$
(3)

Actual  $Count_{TIMERD}$  is proportional to the output frequency of the timer; hence, it provides feedback to the system and can be used for calibration. If the actual frequency of Timer\_D,  $f_{actual}$ , is higher than  $f_{desired}$ , then  $Actual\ Count_{TIMERD}$  will be higher than  $Expected\ Count_{TIMERD}$  and the Timer\_D frequency is lowered by adjusting the TDHCLKTRIMx bits down. Similarly, if the actual frequency of Timer\_D,  $f_{actual}$ , is lower than  $f_{desired}$ , then  $Actual\ Count_{TIMERD}$  will be lower than  $Expected\ Count_{TIMERD}$  and the Timer\_D frequency is increased by adjusting the TDHCLKTRIMx bits up.

In this example, the interrupt service routine of Timer\_D, TIMER0\_D1\_VECTOR, contains the TDCCR2 CCIFG vector, which is serviced at every captured edge of  $f_{SLOW}$ . When a capture is performed the following occurs in the presented order:

- The timer value is copied from TDR into the Timer\_D Capture/Compare Register (TDCCRx).
- The TDCCRx register is copied into the Timer\_D Compare Latch Register (TDCLx).
- The interrupt flag (CCIFG) is set.
- The Timer Capture Overflow bit is set in case of a timer capture overflow condition.

Hence, the register TD0CL2 contains the count value of Timer\_D at the capture event. If the value of TD0CL2 is  $TD0CL2_1$  at event capture number N, and the value of TD0CL2 is  $TD0CL2_2$  at event capture number N+1, then:

$$Actual Count_{TIMERD} = TD0CL2_2 - TD0CL2_1$$
(4)

The goal is to adjust TDHCLKTRIMx until  $Actual\ Count_{TIMERD} = Expected\ Count_{TIMERD}$ . Care must be taken or this condition may result in an infinite loop. An infinite event can occur when increasing TDHCLKTRIMx by 1 count makes  $Actual\ Count_{TIMERD} > Expected\ Count_{TIMERD}$  and decreasing TDHCLKTRIMx by 1 count makes  $Actual\ Count_{TIMERD} < Expected\ Count_{TIMERD}$ . This condition is possible because adjusting TDHCLKTRIMx changes the timer frequency by approximately 1.5%. To prevent this problem a tolerance around  $Expected\ Count_{TIMERD}$  should be allowed:

Expected Count<sub>TIMERD</sub> = Expected Count<sub>TIMERD</sub> ± Range (prevent infinite calibration loop)

The allowed range depends on the accuracy required and varies for all applications. The best accuracy that can be achieved shows a minimum value of 1.5%, since each step of TDHCLKTRIMx changes the frequency by 1.5%. The accuracy is a multiple of 1.5%. For instance, if the required accuracy is 2%, then the range must be set for 1.5%. If the required accuracy is 3.8%, then the range must be set for an accuracy of 3%. Figure 8 shows the software flowchart for calibrating Timer\_D. An example is presented in Table 5.

The frequency required by the timer calibration routine depends strictly on the end application and its environmental conditions. For instance, an application expected to undergo rapid changes of temperature should calibrate more often than a system located in a more stable environment.



**NOTE:** System clock must be fast enough to allow enough time between capture interrupts to enter, execute and exit the Timer\_D ISR. The required time may depend on several factors including compiler, optimization settings, and so forth.



Figure 8. Software Flowchart for Timer\_D Calibration



Free-Running Mode www.ti.com

#### 3.4 Tag-Length-Value (TLV) Calibration Constants

There are factory pre-programmed values stored in the TLV structure of the Flash memory for the TDHCLKRx, TDHSRx, and TDHCLKTRIMx bits of TDHCTL1 for specific frequencies in free-running mode. To use the calibrated settings, the register setting is copied into the corresponding registers. In addition to these settings, a clock multiplication factor and coarse clock range selection must be applied to the TDHMx and TDHCLKCR bits of the TDxHCTL1 register. Frequency calibration is currently provided for 64 MHz, 128 MHz, 200 MHz and 256 MHz. Table 5 shows an example of a table from an MSP430F51xx device as an example. For more information on the calibration constants, see the device-specific data sheet.

Table 5. Timer\_D Trimmed Clock Frequencies Sample (over recommended ranges of supply voltage and operating free-air temperature – unless otherwise noted)

|                           | Parameter                                                      | Test Conditions                                   | Min  | Тур | Max  | Unit |
|---------------------------|----------------------------------------------------------------|---------------------------------------------------|------|-----|------|------|
|                           | Frequency tolerance during trimming                            |                                                   | -0.5 |     | +0.5 | %    |
| f <sub>TRIM(64MHz)</sub>  | TDHMx = 0, TDHREGEN = 0, TDHCLKCR = 0, TDHxCTL1 = TDHxCTL1_64  | T <sub>A</sub> = 25°C,<br>V <sub>CC</sub> = 1.8 V | 63   | 64  | 65   | MHz  |
| f <sub>TRIM(128MHz)</sub> | TDHMx = 0, TDHREGEN = 0, TDHCLKCR = 1, TDHxCTL1 = TDHxCTL1_128 | $T_A = 25^{\circ}C,$ $V_{CC} = 2.0 \text{ V}$     | 126  | 128 | 130  | MHz  |
| f <sub>TRIM(200MHz)</sub> | TDHMx = 0, TDHREGEN = 0, TDHCLKCR = 1, TDHxCTL1 = TDHxCTL1_200 | T <sub>A</sub> = 25°C,<br>V <sub>CC</sub> = 2.4 V | 197  | 200 | 203  | MHz  |
| f <sub>TRIM(256MHz)</sub> | TDHMx = 1, TDHREGEN = 0, TDHCLKCR = 1, TDHxCTL1 = TDHxCTL1_256 | $T_A = 25^{\circ}C,$ $V_{CC} = 2.2 \text{ V}$     | 250  | 256 | 262  | MHz  |

A high-resolution clock generator (HRCG) voltage and temperature drift is provided in the device-specific data sheet. A sample of the table is shown in Table 6. For MSP430F51xx, see the device-specific data sheet.

Table 6. HRCG Voltage and Temperature Drift Sample Table (over recommended ranges of supply voltage and operating free-air temperature – unless otherwise noted)

|                          | Parameter                        | Test Conditions                                | Min | Тур | Max   | Unit |
|--------------------------|----------------------------------|------------------------------------------------|-----|-----|-------|------|
|                          | HRCG frequency temperature drift | f <sub>HRCG</sub> = 8 MHz, TDHREGEN = 0        |     |     | ±0.17 | %/°C |
| df /dT                   |                                  | f <sub>HRCG</sub> = 16 MHz, TDHREGEN = 0       |     |     | ±0.16 | %/°C |
| df <sub>HRCG</sub> /dT   |                                  | f <sub>HRCG</sub> = 25 MHz, TDHREGEN = 0       |     |     | ±0.16 | %/°C |
|                          |                                  | f <sub>HRCG</sub> = 8/16/25 MHz, TDHREGEN = 1  |     | 0   |       | %/°C |
| 4t /4//CC                | HRCG frequency voltage drift     | $f_{HRCG} = 8/16/25 \text{ MHz}, TDHREGEN = 0$ | 0   |     | 5     | %/°V |
| df <sub>HRCG</sub> /dVCC |                                  | f <sub>HRCG</sub> = 8/16/25 MHz, TDHREGEN = 1  |     | 0   |       | %/°V |

The tolerance of the values stored in the TLV structure for Timer\_D is given by a combination of the values shown in Table 5 and Table 6. For instance, when using the factory calibrated frequency for 256 MHz on this particular device at 3.2 V is given by:

Calibration Constant Range = Range at 2.2 V + 5% = 250 to 262 MHz  $\pm 5\%$  = 237 to 275 MHz

since there is a 5% frequency drift per volt. Note that the above range does not include temperature variations.

For some applications, this tolerance is not acceptable and the technique for auto-calibration should be employed. The TLV constants may be used to initialize Timer\_D to the target frequency and then the calibration routine may be run to obtain the desired frequency.



#### 3.5 Software Snippet for Calibrating Timer D

To summarize, Timer\_D is configured as a 16-bit timer sourced from the Internal Timer\_D Clock, high resolution, enhanced accuracy, in continuous mode and with input capture functionality with interrupts enabled on the rising and falling edges of ACLK routed internally to TD0.2. The TLV constant for 256 MHz is used as the initial value of the TD0HCTL1 register. The initialization of Timer\_D for calibration is shown below. The addresses of TLV constants are given in the device-specific data sheet. In this example, the constant for 256 MHz is stored at address 0x1A36.

```
#define CALTDH0CTL1_256
                           *((unsigned int *)0x1A36)
   TD0HCTL1 = CALTDH0CTL1_256; // Get the 256 Mhz TimerD TLV Data
   TDOCTLO = CNTL_0 // 16-bit timer
            + ID_0 // Divide by 1
+ MC_0; // Halt timer until init is complete
                              // Divide by 1
   TD0CTL1 |= TDCLKM_1; // TD0 clock = Hi-res local clock
// FREE RUNNING MODE (TDHREGEN = 0)
   TD0HCTL0 = TDHFW
                               // Fast wake-up mode.
                            // Set divider to 1
// Multiply by 16
           + TDHD_0
            + TDHM_1
            + TDHEAEN
                            // Enhance accuracy
            + TDHEN;
                               // Enable Hi-Res
   TD0CTL2 &= ~TDCAPM2;
                               // Channel 2 single capture mode
   TD0CCTL2 = CAP
                               // Capture mode
           + CM_1
+ CCIE
                               // Rising and falling edge
                              // Enable local interrupt for Timer TD0.2
            + CCIS 1;
                               // Use ACLK running at 32768 Hz as input
```

Code example with the calibration routine is provided with this document at <a href="http://www.ti.com/lit/zip/slaa601">http://www.ti.com/lit/zip/slaa601</a>.

#### 3.6 Frequency Calibration Technique for Timer\_D: An Example

This section presents an example for calibrating Timer\_D. Given the following application requirements:

```
f_{desired} = 256 \ MHz
f_{SLOW} = 32768 \ Hz \ (from ACLK)
Accuracy = f_{desired} \pm 2\%
Then,
t_{ACLK} = \frac{1}{2 * f_{SLOW}} = \frac{1}{2 * 32768} = 0.015258789 \ ms
Expected \ Count_{TIMERD} = t_{ACLK} \ * f_{desired} = 0.015258789 \ ms * 256 \ MHz = 3906
```

Note that even though the application requires an accuracy of 2.2%, the range must be calculated for 1.5%. The next accuracy steps would be 3%, 4.5%, 6% and so on. 58 is the total number of counts that will ensure the frequency to be within 1.5% of the desired frequency

# 3.7 Frequency Calibration Accuracy

Range = Expected Count<sub>TIMERD</sub>  $\pm 1.5\% = 3906 \pm 58$ 

The presented calibration technique presents two sources of error:

- Tolerance of f<sub>SLOW</sub>
- ±1.5% of the desired frequency given by each step of TDHCLKTRIMx.

The tolerance of  $f_{SLOW}$  is given by the tolerance of the source clock. For instance, if ACLK is used and sourced from REFO, the tolerance is  $\pm 3.5\%$  across the full voltage and temperature range as specified in the MSP430F51xx data sheet. Using an external low-frequency crystal yields a lower tolerance and a better Timer\_D clock accuracy.

(6)



Free-Running Mode www.ti.com

#### 3.8 Frequency Calibration Accuracy Lab Test

The robustness of the self-calibration firmware over varying temperatures and voltages was tested in the lab. Testing was done at 85°C, 20°C, and -40°C for the device running on a 3.0 V and 2.5 V power supply. Seven MSP430 devices were programmed to auto-calibrate Timer\_D to 256 MHz. It has been observed that frequency is proportional to temperature. A dampening effect is also observed on the frequency when the voltage of the power supply driving the device is decreased. The following data and test procedures observe the effectiveness of the self-calibration system. A soaking time of 7 minutes was used to ensure temperature equilibrium before measurements were taken.

#### 3.8.1 Equipment

- MSP-TS430RSB40 target board with programmed MSP430F5172
- Thermostream and proper insulation materials for testing
- · Power supply used to vary voltage driving the device
- · Alligator clips or wires
- · Oscilloscope probes for frequency reading

#### 3.8.2 Connections

- Timer D output to Oscilloscope
- V<sub>CC</sub> and GND from power supply



Figure 9 shows the test flowchart for the Timer D calibration.



Figure 9. Timer\_D Calibration Test Flowchart



Regulated Mode www.ti.com

Collected data was then analyzed. The deviation from baseline (256 MHz) was found and shown in Figure 10.



Figure 10. Test Results With calibration ON

Results show a percentage variation of less than 1% from 256 MHz over the temperature and voltage operating range of the MSP430F51x2. Calibration was performed at a reset event. In the test setup, a reset was issued after the temperature and voltage was varied.

For comparison purposes, Figure 11 show the data collected at 2.5 V and 3 V, respectively, for a temperature sweep without the Timer\_D calibration routine.



Figure 11. Test Results With calibration OFF

Results show a percentage variation of over 5% from 256 MHz over the temperature and voltage operating range of the MSP430F51x2 with the Timer\_D calibration set to OFF.

#### 4 Regulated Mode

When TDDREGEN = 1, Timer\_D operates in regulated mode.

#### 4.1 Timer Source Clock

In regulated mode, the Timer\_D clock source is selected by TDSSELx. The input clock is fed to the high-resolution generator and its output sources the 16-bit timer TDR register through the TDCLKMx multiplexer as shown in Figure 12.





Figure 12. Regulated Mode High-Resolution Block

Note that whether Timer D is in free-running or regulated mode, TDCLKMx must be selected as the high-resolution local clock (TDCLKMx = 01b). Programmers may be incorrectly inclined to select the external clock source for TDCLKMx, since an external clock is used to generate the high-resolution clock of the Timer\_D module. The external source clock sources the high-resolution generator, but the Timer\_D clocking mode selector is the high-resolution local clock just as in the case of free-running mode; otherwise, the high resolution generator is bypassed.

#### 4.2 Frequency Adjustments

When operating in regulated mode, the frequency of the timer is determined by the frequency of the source clock and the timer configuration bit setting in TDHCLKCR, TDHMx and TDHDx. In contrast to the free-running mode, TDHCLKRx, TDHCLKSRx, and TDHCLKTRIMx are modified automatically by hardware in the regulated mode. Timer\_D accuracy is controlled by the accuracy of the input source clock, and no auto-calibration is required. The programmer must ensure that the frequency generated by the high-resolution generator is  $\leq$  256 MHz. For instance, for a 25 MHz source clock, a multiplier of 16 is not valid, since it drives the timer to operate outside of its operation specifications and its operation is not ensured.

#### 4.3 Software Snippet for Initializing Timer D in Regulated Mode

The following code snippet shows how to initialize Timer\_D in high-resolution, regulated mode. An input clock of 16 MHz is assumed on SMCLK.

```
TD0CTL0 = TDSSEL_2
                      // Use SMCLK - 16 MHz assumed
        + CNTL_0
                      // 16-bit timer
        + ID_0
                      // Divide by 1
        + MC_0;
                      // Halt timer until init is complete
TD0CTL1 |= TDCLKM_1; // TD0 clock = Hi-res local clock
TD0HCTL0 = TDHFW
                      // Fast wake-up mode.
        + TDHD_0
                      // Set divider to 1
                      // Multiply by 16. 16 MHz x 16 = 256 MHz
        + TDHM_1
        + TDHREGEN
                      // Regulated Mode
        + TDHEAEN
                      // Enhance accuracy
         + TDHEN;
                      // Enable Hi-Res
```

#### 5 TIMER D High-Resolution PWM Generation

When generating a pulse-width modulated signal in high-resolution mode, some special considerations must be kept in mind. This section describes these considerations as well the limitations in PWM generation of the Timer\_D module.



A PWM signal is described by two parameters: frequency and duty cycle. The frequency of the PWM is determined by the following components:

- Timer Frequency
- Value in TDxCCR0
- Timer Length: 8, 10, 12 or 16 bits given by CNTLx bits
- Timer Mode: Up, down, continuous or up/down given by MCx bits

The PWM duty cycle is controlled by the value of TDxCCRn. For basics on PWM generation, see *Timer\_D Module (Chapter Excerpt From MSP430x5xx and MSP430x6xx Family User's Guide, SLAU208)* (SLUA323).

**NOTE:** UP/DOWN mode cannot be used in hi-resolution mode. Unexpected behavior is observed.

#### 5.1 PWM Period Resolution

One of the most important characteristics to be considered when using the compare latch TDxCL0 as a period register under high-resolution mode is that the four LSB of the TDxCL0 in the 16x case (TDHM = 1) or the three LSB in the 8x case (TDHM = 0) are ignored and replaced by 1s. Table 7 shows effective TDxCL0 values for various TDxCL0 configurations. The "TDxCLO value" is the actual number loaded to the TDxCL0 register. The "effective TDxCL0" value is the number the hardware evaluates for the frequency of the PWM signal.

Table 7. Effective TDxCL0 Values for Various TDxCL0 Configurations (1)

| TDxCL0 Value (decimal) | TDxCL0 Value (binary) | Multiplier | Effective TDxCL0 Value (binary) | Effective TDxCL0 Value |
|------------------------|-----------------------|------------|---------------------------------|------------------------|
| 1                      | 00001                 | x16        | 01111                           | 15                     |
|                        | 00 <b>001</b>         | x8         | 00111                           | 7                      |
| 9                      | 01000                 | x16        | 01111                           | 15                     |
|                        | 01 <b>000</b>         | x8         | 01 <b>111</b>                   | 15                     |
| 15                     | 01111                 | x16        | 01111                           | 15                     |
|                        | 01 <b>111</b>         | x8         | 01 <b>111</b>                   | 15                     |
| 17                     | 10001                 | x16        | 11111                           | 31                     |
|                        | 10 <b>001</b>         | x8         | 10 <b>111</b>                   | 23                     |
| 26                     | 11010                 | x16        | 11111                           | 31                     |
|                        | 11 <b>010</b>         | x8         | 11 <b>111</b>                   | 31                     |

<sup>(1)</sup> Bits highlighted in bold are ignored and replaced by 1s.

What does this mean in terms of PWM period resolution? The PWM period event is indicated when the TDIFG flag is set. TDIFG is set at different events for each of the timer mode control:

- Up Mode: TDIFG is set when the timer counts from TDxCL0 to 0
- $\bullet$  Continuous Mode: TDIFG is set when the timer counts from  $\mathsf{TDR}_{\mathsf{max}}$  to 0
- Up/Down Mode: TDIFG is set when the timer counts down from 1 to 0

Thus, the period of a PWM signal depends on the timer mode control:

Up Mode:

$$\begin{aligned} & \textit{PWM}_{\textit{period}_{\textit{up}}} = \frac{2*(\textit{TDxCL0}_{\textit{effective}} + 1)}{\textit{FrequencyTIMERD}} \left( \text{Toggle Mode} \right) \\ & \textit{PWM}_{\textit{period}_{\textit{up}}} = \frac{\textit{TDxCL0}_{\textit{effective}} + 1}{\textit{FrequencyTIMERD}} \left( \text{Set/Reset and Reset/Set Modes} \right) \end{aligned}$$

(7)



#### Continuous Mode:

$$PWM_{period_{cont}} = \frac{2 * (TDR_{max} + 1)}{Frequency_{TIMERD}} \text{ (Toggle Mode)}$$

$$PWM_{period_{cont}} = \frac{TDR_{max} + 1}{Frequency_{TIMERD}} \text{ (Set/Reset and Reset/Set Modes)}$$
(8)

• Up/Down:

$$PWM_{period_{CONt}} = \frac{4 * (TDR_{max} + 1)}{Frequency_{TIMERD}}$$
(Toggle Mode)
$$PWM_{period_{CONt}} = \frac{2 * (TDR_{max} + 1)}{Frequency_{TIMERD}}$$
(Set/Reset and Reset/Set Modes)
(9)

In the high-resolution regulated mode with 16x multiplier selected, the 4 LSB of TDxCL0 are ignored, thus each period step is every  $2^4$  counts of TDxCL0. Similarly, in the high-resolution regulated mode with 8x multiplier selected, each period step is every  $2^3$  counts of TDxCL0. Since the ignored bits are replaced by 1s, a factor of 16 and a factor of 8 is added to the TDHMx = 1 case and the TDHMx = 0 case respectively. For up mode in a non-toggle output configuration, the PWM period granularity that can be achieved is:

$$Steps\_PWM_{period}_{x16} = \frac{TDxCL0_{effective} + 1}{Frequency_{TIMERD}} = \frac{16 + n * 2^4}{Frequency_{TIMERD}}$$

$$Steps\_PWM_{period}_{x8} = \frac{TDxCL0_{effective} + 1}{Frequency_{TIMERD}} = \frac{8 + n * 2^3}{Frequency_{TIMERD}}$$
where n is an integer > 0 (10)

To illustrate this behavior, consider the following example:

Given,

$$Frequency_{TIMERD} = 256 \text{ MHz}$$

$$TDxCL0 = 0 \text{ to } 64$$
(11)

For the x16 case, there are  $\frac{64-0}{2^4}-1=3$  non-zero steps for TDxCL0 from 0 to 64. Similarly, for the x8

case, there are 2<sup>3</sup> non-zero steps for TDxCL0 from 0 to 64. The -1 factor comes from the fact that the first step for TDxCL0 from 0 to 15 in the 16x case and for TDxCL0 from 0 to 7, results in either 0% or 100% (0Hz effective frequency) duty cycle due to high-resolution mode limitations. For more information, see Section 5.3.

The non-zero PWM period steps are:

$$StepspWM_{period_{X16}} = \left(\frac{16 + n * 2^{4}}{256 \times 10^{6}}\right)^{for} n = 1,2,3$$

$$= 125 \text{ ns, } 187.5 \text{ ns and } 250 \text{ ns}$$

$$= 8 \text{ MHz, } 5.33 \text{ MHz, } 4 \text{ MHz}$$

$$StepspWM_{period_{X8}} = \left(\frac{8 + n * 2^{3}}{256 \times 10^{6}}\right)^{for} n = 1,2,3,4,5,6,7$$

$$= 62.5 \text{ ns, } 93.75 \text{ ns, } 125 \text{ ns, } 156.25 \text{ ns, } 187.5 \text{ ns, } 218.75 \text{ ns and } 250 \text{ ns}$$

$$(12)$$

In the regulated mode, software does not control the TDHCLKRx, TDHCLKSRx, or TDHCLKTRIMx and the frequency resolution is strictly limited by TDxCL0 for a fixed source clock as shown in the above example.

In free-running mode, software control of TDHCLKTRIMx allows the adjustment of Frequency<sub>TIMERD</sub> by  $\pm 1.5\%$ , which in turn results in a PWM<sub>period</sub> resolution of 1.5% as shown in the following example. Given,

Frequency TIMERD = 256 MHz TDxCL0 = 27 TDHM = 1Timer Mode = Up (14)



Since TDHM = 1, the 4 LSB of TDxCL0 are ignored and replaced by 1s. So  $27_{10}$ = 11011<sub>2</sub> results in an effective TDxCL0 value of  $31_{10}$  = 11111<sub>2</sub>.

For this example, the timer is configured in up mode, with an effective TDxCL0 value of 31. TDIFG is set when the timer counts from 31 to 0, so the PWM frequency is given by:

$$PWM_{period} = \frac{TDxCL0_{effective} + 1}{FrequencyTIMERD} - \frac{31+1}{256 \times 10^6} = 8MHz$$
(15)

Adjusting Frequency<sub>TIMERD</sub> by -1.5%:

$$Frequency_{TIMERD\_adjusted} = 256 \text{ MHz} - 256 \text{ MHz} * 1.5\% = 252.16 \text{ MHz}$$

$$(16)$$

and,

$$PWM_{period\_adjusted} = \frac{TDxCL0_{effective} + 1}{FrequencyTIMERD} \frac{31 + 1}{252.16 \times 10^6} = 7.88 \text{ MHz}$$
(17)

Therefore, in free-running mode a higher PWM period resolution can be achieved in comparison to regulated mode.

# 5.2 PWM Frequency Limits

This section discusses the maximum and minimum achievable PWM frequencies with Timer\_D in high-resolution mode.

The minimum PWM frequency is achieved in 16-bit length, up/down mode with a toggled output and it is given by:

$$PWM_{frequency_{MIN}} = \frac{Frequency_{TIMERD}}{4*(0xFFFF+1)}$$
(18)

The maximum PWM frequency is limited by the following parameters:

- High-resolution mode (free-running or regulated)
- Required duty cycle of the signal
- Chosen output mode (OUTMODx).

Duty cycle limitations can be found in the MSP430x5xx and MSP430x6xx Family User's Guide (SLAU208). To illustrate calculations of maximum PWM frequency, an example is provided with this document.

Consider the following requirement:

Duty Cycle = 50% OUTMODE = Any

The maximum PWM frequency is achieved when the frequency of Timer\_D is at its maximum (256 MHz), and it is limited by the following illegal conditions:

TDHMx = 0:  $TDxCLn \le 0x0007$ TDHMx = 1:  $TDxCLn \le 0x000F$ 

$$TDxCLn \ge TDxCL0 - 0x0008 \tag{20}$$

For 50% duty cycle,  ${}^{TDxCLn} = \frac{1}{2}({}^{TDxCL0}_{effective} + 1)$ . With a 16 MHz SMCLK as a source clock to the system, TDHMx must be 1 to obtain a Timer\_D frequency of 256 MHz. The smaller the value of TDxCL0, the higher the frequency of the PWM signals, so the goal is to make TDxCL0 as small as possible. The low limit for Timer\_D Capture/Compare Latch Register (TDxCLn) is given by TDxCLn  $\leq$  0x000F since TDHMx is 1. TDxCL0 must be twice the value of TDxCLn - 1 for a 50% duty cycle.

Thus,

$$TDxCLn_{MIN} = 16$$

$$TDxCL0_{effective} = 2 * TDxCLn_{MIN} - 1 = 31$$
 (21)

Up mode provides the highest PWM frequency, so:

$$PWM_{frequency_{MAX}} = \frac{Frequency_{TIMERD}}{TDxCL0_{effective_{MIN}} + 1} = \frac{256 \times 10^6}{32} = 8 \text{ MHz (for TDHM = 1)}$$
(22)



Now, the same example is repeated for:

Hi-res Mode = Regulated with SMCLK = 25 MHz

For an input clock of 25 MHz, TDHMx must be 0 so the Timer\_D frequency is  $\leq$  256 MHz. The illegal condition  $TDHMx = 0:TDxCLn \leq 0x0007$  sets the minimum value of  $TDxCLn_{MIN}$ :

$$TDxCLn_{MIN} = 8 (23)$$

and,

$$TDxCL0_{effective} = 2 * TDxCLn_{MIN} - 1 = 15$$
(24)

so, for Up mode,

$$PWM_{frequency_{MAX}} = \frac{Frequency_{TIMERD}}{TDxCL0e_{effective_{MIN}} + 1} = \frac{25 MHz * 8}{16} = 12.5 MHz (for TDHM = 0)$$
(25)

Note from the last two examples that with a multiplier of 8, a PWM frequency higher than that achieved with a multiplier of 16 can be generated. This fact may sound counter-intuitive at first and it is due to the characteristics of TDxCL0 for each of the two multipliers.

Finally, the same example in free-running mode is worth investigating:

In order to obtain the maximum PWM frequency, it would be ideal to achieve a Timer\_D frequency of 256 MHz with TDHMx = 0. As shown in the previous example, when TDHMx = 0,  $TDxCLn_{MIN} = 8$ . The Timer\_D Local Clock Generator Frequency table in the device-specific data sheet shows how to achieve different frequency ranges for Timer\_D. As an example, the data sheet for MSP430F5172 is used. The following combination achieves a minimum frequency of 212 MHz in all devices with TDHMx = 0:

| TDHREGEN = 0, TDHMx = 0, TDHCLKCR = 1, | 212 | 303 | 394 | MHZ |
|----------------------------------------|-----|-----|-----|-----|
| TDHCLKRx = 2, DHCLKSRx = 31,           |     |     |     |     |
| TDHCLKTRIM = 64                        |     |     |     |     |

Note that the system must be calibrated in software so the Timer\_D frequency does not exceeds 256 MHz. TLV constants may also be used for this example. With this configuration, the following is true:

$$TDxCLn_{MIN} = 8$$
 since  $TDHMx = 0$ 

$$TDxCL0effective_{MIN} = 2 * TDxCLn_{MIN} - 1 = 15$$
 (for 50% duty cycle)

$$PWM_{frequency_{MAX}} = \frac{Frequency_{TIMERD}}{TDxCL0_{effective_{MIN}} + 1} = \frac{256 \text{ MHz}}{15 + 1} = 16 \text{ MHz}$$

Hence, the absolute maximum PWM frequency is 16 MHz for 50% duty cycle. This is also true in regulated mode with an input clock source clock of 32 MHz. Hence, an external crystal is required in regulated mode to obtain a 16 MHz PWM signal, while no crystal is needed in free-running mode. Note that in normal operation (non hi-res), the maximum frequency is 25 MHz/2 = 12.5 MHz; however the

period and duty cycle resolution in normal mode is drastically reduced.

### 5.3 PWM Duty Cycle Resolution

The important characteristic of TDxCL0 regarding the four LSB of the TDxCL0 in the 16x case (TDHM = 1) or the three LSB in the 8x case (TDHM = 0) is not a characteristic of TDxCLn registers. Thus, the resolution of the duty cycle for a fixed PWM frequency is given by:

$$PWN_{DutyCycle_{resolution}} = 1/Frequency_{TIMERD}$$
 (27)

The maximum PWM duty cycle resolution for both, regulated and free-running mode, is obtained for  $Frequency_{TIMERD_{MAX}} = {}^{256\,MHz}$ :

$$PWN_{Duty}Cycle_{resolution} = \frac{1}{FrequencyTIMERDMAX} = 4 \text{ ns}$$
(28)

(26)



The limitations on duty cycle for a PWM signal were presented above and given by:

TDHMx = 0:  $TDxCLn \le 0x0007$  TDHMx = 0:  $TDxCLn \le 0x0007$  $TDxCLn \ge TDxCL0 - 0x0008$ 

(29)

# 5.4 Generating Variable Out-of-Phase PWM Signals

Multiple TDxCLn registers can be used to generate multiple variable-frequency-fixed-duty-cycle PWM signals with variable relative phases. The number of TDxCLn registers required to generate M PWMs with variable relative phases is M+1, since TDxCL0 is always used to set the period of all PWM outputs.

Variable-phase-shift PMW pair generation is also achievable with Timer\_A and Timer\_B; however, the phase shift resolution of Timer\_D is much higher. The generation of two 50%-duty cycle PWM signals with a relative phase shift from 0° to 180° is possible with a maximum resolution of 4ns, since  $PWN_{DutyCycle_{resolution}} = 4 \text{ ns}$ 

The period of the PWM output is determined by the value of TDxCL0. For two PWM signals with relative phase shift to be generated TDxCL1 and TDxCL2 can be used. The relative shift is achieved by maintaining one of the TDxCLn values constant and varying the other TDxCLn value. Figure 13 shows an example that keeps TDxCL1 constant and varies TDxCL2 to generate a relative phase shift between TDx.1 and TDx.2. The OUTMODx of TDx.1 and TDx.2 must be set to toggle mode; otherwise, changing TDxCLn results in a duty cycle change instead of a relative phase shift.



Figure 13. Generating Two PWM Signals With Relative Phases

A limitation exists when using Timer\_D to generate more than one PWM output with relative phase shifts. The described application works well for PWM frequencies in the kHz range. As the output frequency increases (by decreasing TDxCL0), a top-level routing issue becomes apparent. It is shown in the device-specific data sheet that there are pins that are preferred and others that are more relaxed. This fact results in a small shift between two outputs that theoretically are configured to be in phase (0° phase shift).

To illustrate this behavior, consider the following example:

Timer Mode: Free running,Up
Output Mode: Toggle on TD0.0 and TD0.1
CCR0 value = 47
CCR1 value = 47



This configuration should yield two PWM signals, on TD0.0 and TD0.1, that are is phase. However, a small phase shift is observed as shown in Figure 14.



Figure 14. Generated Waveforms TD0.0 in blue and TD0.1 in Green

#### 6 Choosing an Operation Mode

One of the main challenges when using Timer\_D is to determine which operation mode fits the applications needs best. Three options are available:

- Normal Mode (non hi-res)
- High-Resolution Mode Free Running
- High-Resolution Mode Regulated

Selecting an operation mode depends on several factors including timer clock resolution and accuracy requirements, hardware and software resources available and overall final application. This section is meant to aid designers in selecting the most efficient operation mode when working with Timer\_D. It is impossible to present all scenarios; hence, a general analysis is introduced.

Suppose a PWM signal is required. Usually the designer knows the following requirements:

- PWM frequency and duty cycle
- Minimum tolerance
- · Minimum resolution
- Hardware resources available



The first mode to consider should be the basic (non hi-res) since it is the easiest one to configure, it is the most power efficient in active mode and it requires the least memory resources for configuration. If the

basic resolution  $\left(\frac{1}{source\ clock}\right)$  and maximum PWM frequency  $\left(\frac{source\ clock}{2}\right)$  are good enough for the final application, then evading the high-resolution mode may be the most efficient way to achieve the PWM signal.

When a higher resolution is required, two options are available. Regulated mode is easier to configure in software since TDHCLKRx, TDHCLKSRx, and RDHCLKTRIMx are hardware controlled and no software-based calibration is needed, but the target frequency is harder to achieve since the period resolution is controlled by TDxCL0. Regulated mode may be a good option for applications with relaxed tolerances. Free-running mode is the most complex from a software perspective, but provides the best resolution and the most flexibility. Free-running also enables the timer (and, hence, the PWM) to be ON in any low power mode. For applications that lack an external crystal and require a minimum tolerance of ±1.5%, free-running mode may be the best option. Table 8 highlights the advantages and disadvantages of all operation modes.

Table 8. Advantages and Disadvantages of Timer\_D Operation Modes

| Operation Mode   | Advantages                                                               | Disadvantages                                               |
|------------------|--------------------------------------------------------------------------|-------------------------------------------------------------|
| Basic            | Easiest configuration                                                    | Lowest resolution (1/source clock)                          |
|                  | No calibration required – tolerance set by source clock                  | External crystal required to run timer in LPMx              |
|                  | Easy to migrate to Timer_A and Timer_B                                   | Maximum PWM frequency = source clock/2                      |
| Hi-Res Free-     | No clock source required external to Timer_D module                      | Timer_D local clock is highly dependent on voltage,         |
| Running          | Maximum frequency is independent of system frequency                     | temperature and varies across devices                       |
|                  | Better PWM period resolution through TDHCLKRx, TDHCLKSRx,and RDHCLKTRIMx | Frequency calibration may be required in software           |
|                  | Use of TLV constants                                                     | Complex software configuration                              |
|                  | Runs in LPMx without external crystal                                    |                                                             |
|                  | Higher maximum PWM frequency (16 MHz)                                    |                                                             |
| Hi-Res Regulated | Easy software configuration                                              | Clock source required external to Timer_D module            |
|                  |                                                                          | PWM period resolution limited by TDxCL0 resolution          |
|                  | No software calibration required – tolerance set by source clock         | 32 MHZ external crystal needed to achieve 16 MHz PWM signal |
|                  |                                                                          | External crystal required to run timer in LPMx              |

# 7 TIMER\_D High-Resolution – Summary

Table 9. Free-running vs. Regulated Mode

|                       | Free-Running Mode                                                                     | Regulated Mode                                             |
|-----------------------|---------------------------------------------------------------------------------------|------------------------------------------------------------|
| Clock Source          | Internal to Timer_D module                                                            | External to Timer_D module                                 |
| Frequency Control     | High granularity with software control of TDHMx, TDHCLKRx, TDHCLKSRx, and RDHCLKTRIMx | Input clock times multiplier (8 or 16). TDHMx control only |
| Calibration required? | Yes                                                                                   | No                                                         |



www.ti.com FAQ

#### 8 FAQ

This section covers the most common questions regarding the high-resolution mode of Timer\_D.

# Q1) In Regulated mode, how can I set TDHCLKRx, TDHCLKSRx, and TDHCLKTRIMx bits in software?

A1) The hi-resolution generator of the Timer\_D can be used in either free-running or regulated mode. The TDCALEN bit enables selection between these two modes. With TDCALEN = 1, regulated mode of the hi-resolution clock generator is used and the TDHCLKRx, TDHCLKSRx, and TDHCLKTRIMx bits are controlled by hardware to automatically reach the target frequency and cannot be modified in software.

#### Q2) What is the maximum frequency of Timer\_D?

A2) The maximum frequency of Timer\_D is 256 MHz. In regulated mode, for an input clock above 16 MHz the maximum multiplier is x8 to ensure the frequency limitation is not exceeded. In free-running mode, software must ensure the configuration of the timer maintains the frequency with an upper limit of 256 MHz. Due to the variations and the desire to meet at least 256 MHz under all circumstances the design must cover a wide range of frequency trimming. Consequently, some parameters lead to >1 GHz in some devices as shown in Table 10. Any frequency configuration that yields a Timer\_D frequency above 256 MHz is provided for documentation purposes only and the programmer must ensure the maximum frequency of 256 MHz specification is met to ensure all parts of the system to operate properly.

Table 10. Invalid Timer\_D Configuations (over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted)

|                 | Parameter              | Test Conditions                                                                             | Min | Тур | Max  | Unit |
|-----------------|------------------------|---------------------------------------------------------------------------------------------|-----|-----|------|------|
| £               | HRCG frequency (2, 31, | TDHREGEN = 0, TDHMx = 0, TDHCLKCR = 1,<br>TDHCLKRx = 2, TDHCLKSRx = 31,<br>TDHCLKTRIM = 128 | 290 | 413 | 537  | MHz  |
| IHRCG(2,31,128) | 128)                   | TDHREGEN = 0, TDHMx = 1, TDHCLKCR = 1, TDHCLKRx = 2, TDHCLKSRx = 31, TDHCLKTRIM = 128       | 580 | 826 | 1074 | MHz  |

#### Q3) If the value of TDCCRx is changed in software, when does the value get loaded into TDCLx?

A3) The compare latch, TDCLx, holds the data for the comparison with the timer counter value in compare mode. TDCLx is a capture and compared register that is accessible to the user software. The buffered compare latch gives you control over when a compare period updates. Compare data is written to each TDCCRx and automatically transferred to TDCLx. The timing of the transfer from TDCCRx to TDCLx is user selectable by setting the CLLDx bits:

**Table 11. TDCLx Load Events** 

| CLLDx | Description                                                                                                                                                                                                                                     |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00    | New data is transferred from TDCCrx to TDCLx immediately when TDCCRx is written to.                                                                                                                                                             |
| 01    | New data is transferred from TDCCrx to TDCLx immediately when TDCCRx counts to 0.                                                                                                                                                               |
| 10    | New data is transferred from TDCCrx to TDCLx immediately when TDCCRx <i>counts</i> to 0 for up and continuous modes. New data is transferred to or from TDCCRx to TDCLx when TDxR <i>counts</i> to the old TDCL0 or to 0 for up and down modes. |
| 11    | New data is transferred from TDCCrx to TDCLx when TDxR counts to the old TDCLx value.                                                                                                                                                           |



References www.ti.com

# Q4) What is the power consumption of Timer\_D is Active and LPMx modes?

The power consumption for Timer\_D in free-running mode at 3 V was measured and results were summarized in Table 12.

Table 12. Timer\_D Power Consumption (1)

| Condition           | Active (µA) | LPM0 (µA) | LPM1 (μA) | LPM2 (µA) | LPM3 (µA) | LPM4 (μA) |
|---------------------|-------------|-----------|-----------|-----------|-----------|-----------|
| Timer_D OFF         | 160         | 83        | 81        | 9         | 4         | 1         |
| Timer_D ON, PWM OFF | 733         | 656       | 654       | 610       | 608       | 605       |
| Timer_D ON, PWM ON  | 1279        | 1033      | 1031      | 984       | 981       | 978       |

<sup>(1)</sup> Power numbers are independent of Timer\_D frequency.

#### 9 References

- Two-Dimensional Capacitive-Touch Implementation Using the High-Resolution Timer\_D of the MSP430F5132 (SLAA418)
- 2. PWM DAC Using MSP430 High-Resolution Timer (SLAA497)
- 3. Intelligent LED lighting control with the ultra-low-power MSP430F51x2 microcontrollers (SLAY024)
- 4. MSP430F51x1, MSP430F51x2 Mixed Signal Microcontroller Data Sheet (SLAS619)
- Timer\_D Module (Chapter Excerpt From MSP430x5xx and MSP430x6xx Family User's Guide, SLAU208) (SLUA323)
- 6. MSP430x5xx and MSP430x6xx Family User's Guide (SLAU208)

#### IMPORTANT NOTICE

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, enhancements, improvements and other changes to its semiconductor products and services per JESD46, latest issue, and to discontinue any product or service per JESD48, latest issue. Buyers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All semiconductor products (also referred to herein as "components") are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its components to the specifications applicable at the time of sale, in accordance with the warranty in TI's terms and conditions of sale of semiconductor products. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by applicable law, testing of all parameters of each component is not necessarily performed.

TI assumes no liability for applications assistance or the design of Buyers' products. Buyers are responsible for their products and applications using TI components. To minimize the risks associated with Buyers' products and applications, Buyers should provide adequate design and operating safeguards.

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 relating to any combination, machine, or process in which TI components or services are used. Information published by TI regarding third-party products or services does not constitute a license to use such products or services or a warranty or endorsement thereof. Use of such information 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.

Reproduction of significant portions of TI 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. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

Resale of TI components or services with statements different from or beyond the parameters stated by TI for that component or service voids all express and any implied warranties for the associated TI component or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

Buyer acknowledges and agrees that it is solely responsible for compliance with all legal, regulatory and safety-related requirements concerning its products, and any use of TI components in its applications, notwithstanding any applications-related information or support that may be provided by TI. Buyer represents and agrees that it has all the necessary expertise to create and implement safeguards which anticipate dangerous consequences of failures, monitor failures and their consequences, lessen the likelihood of failures that might cause harm and take appropriate remedial actions. Buyer will fully indemnify TI and its representatives against any damages arising out of the use of any TI components in safety-critical applications.

In some cases, TI components may be promoted specifically to facilitate safety-related applications. With such components, TI's goal is to help enable customers to design and create their own end-product solutions that meet applicable functional safety standards and requirements. Nonetheless, such components are subject to these terms.

No TI components are authorized for use in FDA Class III (or similar life-critical medical equipment) unless authorized officers of the parties have executed a special agreement specifically governing such use.

Only those TI components which TI has specifically designated as military grade or "enhanced plastic" are designed and intended for use in military/aerospace applications or environments. Buyer acknowledges and agrees that any military or aerospace use of TI components which have *not* been so designated is solely at the Buyer's risk, and that Buyer is solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI has specifically designated certain components as meeting ISO/TS16949 requirements, mainly for automotive use. In any case of use of non-designated products, TI will not be responsible for any failure to meet ISO/TS16949.

Products Applications

Audio www.ti.com/audio Automotive and Transportation www.ti.com/automotive Communications and Telecom **Amplifiers** amplifier.ti.com www.ti.com/communications **Data Converters** dataconverter.ti.com Computers and Peripherals www.ti.com/computers **DLP® Products** www.dlp.com Consumer Electronics www.ti.com/consumer-apps

DSP **Energy and Lighting** dsp.ti.com www.ti.com/energy Clocks and Timers www.ti.com/clocks Industrial www.ti.com/industrial Interface interface.ti.com Medical www.ti.com/medical logic.ti.com Logic Security www.ti.com/security

Power Mgmt power.ti.com Space, Avionics and Defense www.ti.com/space-avionics-defense

Microcontrollers <u>microcontroller.ti.com</u> Video and Imaging <u>www.ti.com/video</u>

RFID www.ti-rfid.com

OMAP Applications Processors <u>www.ti.com/omap</u> TI E2E Community <u>e2e.ti.com</u>

Wireless Connectivity <u>www.ti.com/wirelessconnectivity</u>