# AN14617

## Features and Operation Modes of FlexTimer Module on MCX E24x

Rev. 1.0 — 15 July 2025

**Application note** 

#### **Document information**

| Information | Content                                                                                                                                                                                       |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Keywords    | AN14617, MCX E24x, FlexTimer, FTM, PWM                                                                                                                                                        |
| Abstract    | This application note describes the multiple features and operation modes of the FlexTimer (FTM) module on MCX E24x, and code examples and oscilloscope snapshots are provided for reference. |



#### Features and Operation Modes of FlexTimer Module on MCX E24x

#### 1 Introduction

The FlexTimer module (FTM) is an enhanced timer module that supports input capture, output compare, and the generation of PWM signals to control electric motor and power management applications and it is commonly used on many Kinetis MCUs. This application note focuses on the features of the FTM module in the MCX E24x product series, and uses the FRDM-MCXE247 to demonstrate the functionality of the FTM module.

The key features of the FTM module are as follows:

- Each channel can be configured for Input capture, Output compare, or Edge-Aligned PWM (EPWM) mode or Center-Aligned PWM (CPWM) mode.
- Each pair of channels can be combined to generate PWM signals with equal outputs, pairs with complementary outputs, or independent outputs.
- The dead time insertion is available for each complementary pair.
- Quadrature decoder with input filters, relative position counting, and interrupt on position count or capture of position count on external event.
- Software control of PWM outputs, fault inputs for global fault control.

The masking, inverting, polarity and fault control, and hardware dead-time insertion are the main features of the FTM module dedicated for motor-control applications. They provide greater flexibility and they significantly reduce the CPU load. On the other hand, the FTM module retains standard timer functions (such as the input capture or output compare modes) if it is not used for motor control. This makes FTM more flexible, covering a wide range of applications.

#### 2 FTM overview

The FTM module has a single 16-bit counter that is used by the FTM channels for either the input or output modes. Figure 1 shows the block diagram of FTM. There are three possible clock sources that can be selected for the FTM counter: the system clock, the fixed-frequency clock, and the external clock (for a detailed clocking description, see the **Clock Distribution** chapter in the *MCX E24x reference manual*). The selected counterclock signal then passes through a pre-scaler which enables dividing the clock source by up to 128 by setting PS[2:0] in the  $FTM_SC$  register. If the CPWMS bit in the  $FTM_SC$  register is disabled, the FTM counter operates in the up-counting mode. Otherwise, it operates in the up/down-counting mode.

#### Features and Operation Modes of FlexTimer Module on MCX E24x



The current implementation of the MCX E24x device is equipped with up to eight FTMs. Each FTM module has eight channels which work either independently or in pairs (CH0/CH1, CH2/CH3, CH4/CH5, and CH6/CH7). All channels can be configured for the input capture, output compare, or EPWM/CPWM modes. In the EPWM mode, the FTM channel pairs can work in the complementary or/and combine modes. In addition, FTM1 and FTM2 are able to work in the quadrature-decoder mode that enables processing signals from the incremental rotary position sensor (encoder).

## Features and Operation Modes of FlexTimer Module on MCX E24x

Table 1 shows the mode selection of channels.

Table 1. FTM channel mode setting

| DECAPEN | MCOMBINE | COMBINE | CPWMS | MSnB:MSnA | ELSnB:ELSnA        | Mode                                                                                  | Configuration                                                                           |
|---------|----------|---------|-------|-----------|--------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
|         |          |         | 0     | 00        | 01                 | Input<br>capture                                                                      | Capture on rising edge only                                                             |
|         |          |         |       |           | 10                 |                                                                                       | Capture on falling edge only                                                            |
|         |          |         |       |           | 11                 |                                                                                       | Capture on rising or falling edge                                                       |
|         |          |         |       | 01        | 01                 | _                                                                                     | Toggle output on match                                                                  |
|         |          |         |       |           | 10                 | Output<br>compare                                                                     | Clear output on match                                                                   |
|         |          | 0       |       |           | 11                 | Comparo                                                                               | Set output on match                                                                     |
|         |          |         |       | 1X        | 10                 |                                                                                       | High-true pulses (clear output on match)                                                |
| C       | 0        |         |       |           | X1                 | EPWM                                                                                  | Low-true pulses (set output on match)                                                   |
|         |          |         | 1     | xx        | 10                 | CPWM                                                                                  | High-true pulses (clear output on match-up)                                             |
| 0       |          |         |       |           | X1                 |                                                                                       | Low-true pulses (set output on match-up)                                                |
| 1       |          |         | 0     | XX        | 10                 | Combine                                                                               | High-true pulses<br>(set on channel (n) match,<br>and clear on channel (n<br>+1) match) |
|         | 1        | O       |       | X1        | PWM                | Low-true pulses<br>(clear on channel (n)<br>match, and set on channel<br>(n+1) match) |                                                                                         |
|         | 1        | 0       | 0     | xx        | 10                 | Modified<br>combine<br>PWM                                                            | High-true pulses<br>(set on channel (n) match,<br>and clear on channel (n<br>+1) match) |
|         |          |         |       |           | X1                 |                                                                                       | Low-true pulses<br>(clear on channel (n)<br>match, and set on channel<br>(n+1) match)   |
|         |          |         | _     | X0        |                    | Dual -edge                                                                            | One-shot capture mode                                                                   |
| 1       | 0        | 0       | 0     | X1        | See <u>Table 2</u> | capture<br>mode                                                                       | Continuous capture mode                                                                 |

#### Features and Operation Modes of FlexTimer Module on MCX E24x

Table 2. Dual edge capture mode—edge polarity selection

| ELSnB | ELSnA | Channel port enable | Detected edges           |
|-------|-------|---------------------|--------------------------|
| 0     | 0     | Disabled            | No edge                  |
| 0     | 1     | Enabled             | Rising edge              |
| 1     | 0     | Enabled             | Falling edge             |
| 1     | 1     | Enabled             | Rising and falling edges |

In sensor-based motor-control applications, it is necessary to use two FTM modules. The first FTM is used to generate six PWM signals to control the acceleration of the motor and the second FTM module works in the quadrature-decoder mode to determine the position from two 90°-shifted encoder signals, Phase A and Phase B. If the Hall sensors are used instead of the encoder, the second FTM module is configured for the input capture mode and the PWM signals of the first FTM module are controlled according to the Hall sensor logic. For more details, see the *BLDC motor control w/ Hall Effect sensor - Kinetis MCUs* (document AN4376).

## 3 FTM operation modes

This chapter describes the main operation modes of FTM, including:

- Section 3.1 "EPWM mode"
- Section 3.2 "CPWM mode"
- Section 3.3 "Complementary mode and dead-time insertion"
- Section 3.4 "Combine mode"
- Section 3.5 "Single-edge capture mode"
- Section 3.6 "Dual-edge capture mode"
- Section 3.7 "Quadrature decoder mode"

#### 3.1 EPWM mode

In the EPWM mode, the FTM counter counts up from the FTM\_CNTIN value to the FTM\_MOD value. Signals of all FTM channels align at the edge when the FTM counter changes from the MOD value to the CNTIN value.

The EPWM mode is selected when:

- QUADEN = 0
- DECAPEN = 0
- MCOMBINE = 0
- COMBINE = 0
- CPWMS = 0
- MSnB = 1

The EPWM period is determined by MOD – CNTIN + 0x0001 and the pulse width (or the duty cycle) is determined by CnV – CNTIN or MOD – CNTIN – CnV, depending on the control bits <code>ELSnB:ELSnA</code>.

The core code for EPWM mode is as follows:

```
void Edge_Align_PWM_Init()
{
    /* Enable clock for PORTD */
    CLOCK_EnableClock(kCLOCK_PortD);
    /* Enable clock for PORTB */
    CLOCK_EnableClock(kCLOCK_PortB);
    /* Enable clock for FTM0 */
    CLOCK_EnableClock(kCLOCK_Ftm0);
    /* Enable registers updating from write buffers */
    FTM0->MODE = FTM MODE WPDIS MASK | FTM MODE FTMEN_MASK;
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x

```
/* Set PORT pins for FTM0 */
PORTD->PCR[15] = PORT PCR MUX(2); // FTM0, Channel0
PORTD->PCR[16] = PORT PCR MUX(2); // FTM0, Channel1
PORTB->PCR[16] = PORT PCR MUX(2); // FTM0, Channel4
PORTB->PCR[17] = PORT PCR MUX(2); // FTM0, Channel5
^{\prime \star} Enable complement mode and dead-time for pair channel 0/1 and 4/5 ^{\star \prime}
FTM0->COMBINE = FTM COMBINE COMP0 MASK | FTM COMBINE DTEN0 MASK | FTM COMBINE COMP2 MASK | FTM COMBINE DTEN2 MASK;
/* Set Modulo in initialization stage (10kHz PWM frequency @48MHz system clock) */
FTMO->MOD = FTM MOD MOD(4800-1);
   Set CNTIN in initialization stage */
FTM0->CNTIN = FTM CNTIN INIT(0);
   Enable high-true pulses of PWM signals */
FTM0->CONTROLS[0].CnSC = FTM CnSC MSB MASK | FTM CnSC ELSB MASK;
FTMO->CONTROLS[1].CnsC = FTM CnsC MSB MASK | FTM CnsC ELSB MASK;
FTMO->CONTROLS[1].CnsC = FTM CnsC MSB MASK | FTM CnsC ELSB MASK;
FTMO->CONTROLS[4].CnsC = FTM CnsC MSB MASK | FTM CnsC ELSB MASK;
FTMO->CONTROLS[4]. CHOC FIM CHSC MSB MASK | FTM ChSC ELSB MASK;

/* Set channel value in initialization stage */
FTMO->CONTROLS[0].CnV=FTM_CnV_VAL(2400); // 50% duty cycle
FTMO->CONTROLS[4].CnV=FTM_CnV_VAL(1200); // 25% duty cycle
/* Reset FTM counter */
FTM0->CNT = 0;
/* Insert deadtime (1us) */
FTMO->DEADTIME = FTM DEADTIME DTPS(3) | FTM DEADTIME DTVAL(3);
/* Clock selection and enabling PWM generation * ,
FTMO->SC = FTM_SC_CLKS(1) | FTM_SC_PWMENO_MASK | FTM_SC_PWMEN1_MASK | FTM_SC_PWMEN4 MASK
             | FTM_SC_PWMEN5_MASK;
```



Figure 2 shows the EPWM mode signal output:

- The scope channels CH1, CH2, CH3, and CH4 represent FTM0\_CH0, FTM0\_CH1, FTM0\_CH4, and FTM0\_CH5 of the FTM0 module, respectively.
- The first channel pair (FTM0\_CH0/FTM0\_CH1) and the second channel pair (FTM0\_CH4/FTM0\_CH5) work in the complementary mode with 50 % and 25 % duty cycles, respectively. The second channel pair (FTM0\_CH4/FTM0\_CH5) demonstrates the edge alignment.

#### Features and Operation Modes of FlexTimer Module on MCX E24x

#### 3.2 CPWM mode

In the CPWM mode, the FTM counter counts up from FTM\_CNTIN to FTM\_MOD and then counts down from FTM\_MOD to FTM\_CTNIN. Signals of all FTM channels align at the point where the FTM counter reaches the FTM MOD value. The CPWM mode is selected when:

- QUADEN = 0
- DECAPEN = 0
- MCOMBINE = 0
- COMBINE = 0
- CPWMS = 1

The duty cycle of the CPWM is determined as  $2 \times (CnV - CNTIN)$ . The period is determined as  $2 \times (MOD - CNTIN)$ .

The core code for CPWM mode is as follows:

```
void Center Align PWM Init()
  /* Enable clock for PORTD */
  CLOCK EnableClock(kCLOCK PortD);
   * Enable clock for PORTB */
  CLOCK EnableClock(kCLOCK PortB);
  /* Enable clock for FTM0 */
  CLOCK EnableClock(kCLOCK Ftm0);
  /* Enable registers updating from write buffers */
FTMO->MODE = FTM_MODE_WPDIS_MASK | FTM_MODE_FTMEN_MASK;
  /* Set PORT pins for FTM0 */
PORTD->PCR[15] = PORT PCR MUX(2); // FTM0, Channel0
  PORTD->PCR[13] = FORT PCR MUX(2); // FTM0, Channel1
PORTB->PCR[16] = PORT PCR MUX(2); // FTM0, Channel1
PORTB->PCR[16] = PORT PCR MUX(2); // FTM0, Channel5
PORTB->PCR[17] = PORT PCR MUX(2); // FTM0, Channel5
  /* Select up-down counter for Center-Align PWM */
  FTM0->SC = FTM_SC_CPWMS_MASK;
  /* Complement mode and dead-time enable for channel0 and channel1 */
  FTM0->COMBINE = FTM_COMBINE_COMP0_MASK | FTM_COMBINE_DTEN0_MASK;
  /* Complement mode and dead-time enable for channel4 and channel5 */
  FTM0->COMBINE |= FTM_COMBINE_COMP2_MASK | FTM_COMBINE_DTEN2_MASK; /* Set Modulo (10kHz PWM frequency @48MHz system clock) */
  FTMO->MOD = FTM_MOD_MOD(2400-1);
  /* Set CNTIN */
  FTMO->CNTIN = FTM CNTIN INIT(0);
  /* High-true pulses of PWM signals */
  FTM0->CONTROLS[0].CnSC = FTM CnSC ELSB MASK;
  FTMO->CONTROLS[1].CnSC = FTM CnSC ELSB MASK;
  FTM0->CONTROLS[4].CnsC = FTM_CnsC_ELSB_MASK;
FTM0->CONTROLS[5].CnsC = FTM_CnsC_ELSB_MASK;
  /* Set Channel Value */
  FTM0->CONTROLS[0].CnV=FTM CnV VAL(1200); // 50% duty cycle
  FTMO->CONTROLS[4].CnV=FTM CnV VAL(600); // 25% duty cycle
  /* FTM counter reset */
  FTMO -> CNT = 0;
  /* Insert deadtime (1us) */
  FTMO->DEADTIME = FTM DEADTIME DTPS(3) | FTM DEADTIME DTVAL(3);
  /* Clock selection and enabling PWM generation *,
  FTMO->SC |= FTM SC CLKS(1) | FTM SC PWMEN0 MASK | FTM SC PWMEN1 MASK | FTM SC PWMEN4 MASK
               | FTM SC PWMEN5 MASK;
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x



Figure 3 shows the CPWM mode signal output:

- The scope channels CH1, CH2, CH3, and CH4 represent FTM0\_CH0, FTM0\_CH1, FTM0\_CH4, and FTM0\_CH5 of the FTM0 module, respectively.
- The first channel pair (FTM0\_CH0/FTM0\_CH1) and the second channel pair (FTM0\_CH4/FTM0\_CH5) work in the complementary mode with 50 % and 25 % duty cycles, respectively. The second channel pair (FTM0\_CH4/FTM0\_CH5) demonstrates the center alignment.

**Note:** The up/down-counting mode is dedicated for generating the CPWM. The up-counting mode can be used as well. However, the FTM channels must be configured to work in the combine mode. For more information, see Section 3.4.

#### 3.3 Complementary mode and dead-time insertion

The FTM module supports the complementary mode. If the complementary mode is enabled by the COMP bit in the FTM\_COMBINE register, the output signal is generated by the even FTM channel only. The odd output signal is generated by the complementary logic as a complement to the even FTM channel. The complementary signal generation can be set individually for each pair of the FTM outputs.

To avoid short-circuit, the dead time must be inserted into the complementary signals. The dead-time insertion is provided by the dead-time logic, following the complementary logic. This feature can be enabled by the DTEN bit in the FTMxCOMBINEm register. The dead-time logic delays every rising edge by a time set in the FTM\_DEADTIME register. The dead time consists of two parts. The first two most significant bits DTPS[1:0] define the pre-scaler of the system clock. The bits DTVAL[5:0] define the duty-cycle value using the pre-scaled clock.

The complementary mode and dead-time insertion are applied to the EPWM and CPWM modes, described in the previous sections. Figure 4 shows the enlarged view of previous EPWM. A dead time of 1 µs is inserted into the PWM signal.

#### Features and Operation Modes of FlexTimer Module on MCX E24x



#### 3.4 Combine mode

The combine mode provides a higher flexibility because the PWM channel (n) output is generated by combining the even channel (n) and the adjacent odd channel (n+1). This implies that the even and odd channels must work in the complementary mode.

The combine mode enables generating the EPWM and CPWM using only the up-counter, the asymmetrical PWM, or the phase-shifted PWM. The phase-shifted PWM generation is commonly used in phase-shifted full-bridge converters and motor-control applications, where the 3-phase stator currents are reconstructed from the current sensed by a single shunt resistor placed in the DC-link and the actual combination of the power supply inverter switches. For more details, see the 3-phase Sensorless BLDC Motor Control Reference Design Using Kinetis KEA128 (document DRM151).

The combine mode is selected when:

- QUADEN = 0
- DECAPEN = 0
- MCOMBINE = 0
- COMBINE = 1
- CPWMS = 0

To generate a phase-shifted PWM with high-true pulses, set the control bits as ELSnB: ELSnA = 1:0. The core code for Phase-shifted PWM mode is as follows:

```
void Phase_Shifted_PWM()
{
    /* Enable clock for PORTD */
    CLOCK_EnableClock(kCLOCK_PortD);
    /* Enable clock for PORTB */
    CLOCK_EnableClock(kCLOCK_PortB);
    /* Enable clock for FTM0 */
    CLOCK_EnableClock(kCLOCK_Ftm0);
    /* Enable registers updating from write buffers */
    FTM0->MODE = FTM_MODE_WPDIS_MASK | FTM_MODE_FTMEN_MASK;
    /* Set PORT pins for FTM0 */
    PORTD->PCR[15] = PORT_PCR_MUX(2); // FTM0, Channel0
```

AN14617

All information provided in this document is subject to legal disclaimers.

© 2025 NXP B.V. All rights reserved.

#### Features and Operation Modes of FlexTimer Module on MCX E24x

```
PORTD->PCR[16] = PORT_PCR_MUX(2); // FTM0, Channel1
PORTB->PCR[17] = PORT_PCR_MUX(2); // FTM0, Channel4
PORTB->PCR[17] = PORT_PCR_MUX(2); // FTM0, Channel5
/* Enable combine, complementary mode and dead-time for channel pair CH0/CH1 and CH4/CH5*/
FTM0->COMBINE = FTM_COMBINE_COMBINEO_MASK | FTM_COMBINE_COMPO_MASK | FTM_COMBINE_DTENO_MASK | FTM_COMBINE_DTENO_MASK | FTM_COMBINE_DTENO_MASK | FTM_COMBINE_DTENO_MASK | FTM_COMBINE_DTENO_MASK;
FTM0->CONTROLS[0].CnSC=FTM_CnSC_ELSB_MASK; // Select high-true pulses
FTM0->CONTROLS[1].CnSC=FTM_CnSC_ELSB_MASK; // Select high-true pulses
FTM0->CONTROLS[4].CnSC=FTM_CnSC_ELSB_MASK; // Select high-true pulses
FTM0->CONTROLS[5].CnSC=FTM_CnSC_ELSB_MASK; // Select high-true pulses
/* Set Modulo (10kHz PWM frequency @48MHz system clock) */
FTM0->MOD = FTM_MOD_MOD(4800-1); // Set modulo
FTM0->CONTROLS[0].CnV=FTM_CnV_VAL(1200); // Set channel Value
FTM0->CONTROLS[1].CnV=FTM_CnV_VAL(2400); // Set channel Value
FTM0->CONTROLS[1].CnV=FTM_CnV_VAL(4400); // Set channel Value
FTM0->CONTROLS[5].CnV=FTM_CnV_VAL(4400); // Set channel Value
FTM0->CNTROLS[6].CnV=FTM_CnV_VAL(4400); // Set channel Va
```

The resulting behavior of the code example is as shown in Figure 5.



Figure 5 shows the phase-shifted PWM mode signal output:

- The scope channels CH1, CH2, CH3, and CH4 represent the FTM0 module channels FTM0\_CH0, FTM0\_CH1, FTM0\_CH4, and FTM0\_CH5, respectively.
- The first channel pair (FTM0\_CH0/FTM0\_CH1) and the second channel pair (FTM0\_CH4/FTM0\_CH5) both work in the complementary mode with a 50 % duty cycle. The second channel pair (FTM0\_CH4/FTM0\_CH5) is phase-shifted by 90° to the first channel pair (FTM0\_CH0/FTM0\_CH1).

<u>Figure 5</u> shows the flexibility of the PWM generation because the 50 % duty cycle can be edge-aligned, centeraligned, or variously shifted according to the specific application requirements.

Features and Operation Modes of FlexTimer Module on MCX E24x

## 3.5 Single-edge capture mode

The FTM capture mode is used mostly to determine the pulse width or the period of the tested signal. Another option of the FTM capture mode is to detect the rising/falling edge of an external signal and to generate an interrupt to notify that an external event appeared. The FTM capture mode is also used in BLDC motor-control applications, where the Hall sensors are used to detect the position of the rotor and to compute the rotor speed, so that the speed loop can be established. The Hall sensors are connected to the channels of the independent FTM (FTM\_CHx). The FTM can then detect both the falling and rising edges of the Hall sensor signals and generate a capture interrupt. In the capture-interrupt routine, the duty cycles of the PWM signals are then modified according to the Hall sensor logic. The single-edge capture mode is selected when:

- DECAPEN = 0
- MCOMBINE = 0
- COMBINE = 0
- CPWMS = 0
- MSnB:MSnA = 0:0
- ELSnB:ELSnA ≠ 0:0

To measure either the pulse width or the period of the tested signal, select the input channel of the FTM module  $FTM\_CHx$  and select the edge-sensitive input by the control bits ELSnB:ELSnA. When the selected edge occurs on the channel input, the current value of the FTM counter is captured in the CnV register and a channel interrupt is generated (if CH(n)IE = 1). In the interrupt routine, save the value of the CnV register into a variable and make a difference between the current value and the saved value from the previous interrupt routine. If the selected capture mode is sensitive either on the rising edge (ELSnB:ELSnA = 0:1) or on the falling edge (ELSnB:ELSnA = 1:0), the difference is equal to the signal period. If the selected capture mode is sensitive on both edges (ELSnB:ELSnA = 1:1), the difference is equal to the pulse width of the tested signal.

This example shows the input capture mode of FTM0 that measures the time period of the input signal through the FTM0 CH0 channel.

```
void FTM0_Single_Edge_Capture_Mode()
  /* Enable clock for PORTD */
  CLOCK EnableClock(kCLOCK PortD);
  /* Enable clock for FTM0 */
  CLOCK EnableClock(kCLOCK_Ftm0);
  /* Set PORT pins for FTM\overline{0} */
  PORTD->PCR[15] = PORT PCR MUX(2); // Set PTD15 for FTM0 - Channel0
  EnableIRQ(FTM0 Ch0 Ch1 IRQn); // Enable interrupt
  /* Input capture mode sensitive on rising edge to measure period of tested signal */
FTMO->CONTROLS[0].CnsC = FTM_CnsC_ELSA_MASK | FTM_CnsC_CHIE_MASK;
  /* Reset counter */
  FTMO -> CNT = 0;
  /* Select clock */
  FTMO->SC = FTM SC CLKS(1);
void FTM1 PWM Output()
  /* Enable clock for PORTA */
  CLOCK EnableClock(kCLOCK PortA);
  /* Enable clock for FTM1^-*/
  CLOCK EnableClock (kCLOCK Ftm1);
  /* Enable registers updating from write buffers */
  FTM1->MODE = FTM MODE WPDIS MASK | FTM MODE FTMEN MASK;
  /* Set PORT pins for FTM1 */
  PORTA->PCR[16] = PORT PCR MUX(2); // FTM1, Channel3
  /* Set Modulo in initialization stage (10kHz PWM frequency @48MHz system clock) */
  FTM1->MOD = FTM MOD MOD(4800-1);
  /* Set CNTIN in initialization stage */
  FTM1->CNTIN = FTM CNTIN_INIT(0);
  /* Enable high-true pulses of PWM signals */
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x

```
FTM1->CONTROLS[3].CnSC = FTM_CnSC_MSB_MASK | FTM_CnSC_ELSB_MASK;
/* Set channel value in initialization stage */
FTM1->CONTROLS[3].CnV=FTM_CnV_VAL(2400); // 50% duty cycle

/* Reset counter */
FTM1->CNT = 0;
/* Select clock */
FTM1->SC = FTM_SC_CLKS(1) | FTM_SC_PWMEN3_MASK;
}

void FTM0_Ch0_Ch1_IRQHandler()
{
  FTM0_CH0_period = FTM0->CONTROLS[0].CnV - temp; // Period calculation temp = FTM0->CONTROLS[0].CnV; // Save COV value into the variable FTM0->CONTROLS[0].CnSC &= ~FTM_CnSC_CHF_MASK; // clear channel flag
}
```



Figure 6 shows the single edge capture mode signal output:

- The scope channel CH1 represents the tested signal that is input to the FTM0\_CH0 channel (generated from FTM1 CH3).
- Every time a rising edge occurs, the capture interrupt is generated and the period of the signal is calculated and printed through UART, as shown in Figure 7. The period of the tested signal is 100 µs.

```
Single Edge Capture Mode Running...

FTM1_CH3 (J2-6) -> FTM0_CH0 (J3-15)

FTM1_CH3 (J2-6) -> SCOPE_CH1

Period:100.0 us

Period:100.0 us

Period:100.0 us

Figure 7. Period of tested signal printed through UART
```

Features and Operation Modes of FlexTimer Module on MCX E24x

#### 3.6 Dual-edge capture mode

The dual-edge capture mode uses two FTM channels that enable measuring the positive-polarity or negative-polarity pulse width of the signals. In this mode, the signals must be input through the even FTM channels, while the odd channels are ignored.

The dual-edge capture mode is selected when DECAPEN = 1. The dual-edge capture mode of the FTM can work either in the one-shot capture mode or the continuous capture mode. The one-shot capture mode is selected when MS(n)A = 0. The edges are captured if the DECAP bit is enabled. For every new measurement, CH(n)F and CH(n+1)F must be cleared and the DECAP bit must be set again. The continuous capture mode is selected when MS(n)A = 1. In this mode, the edges are captured continuously if the DECAP bit is set. For each new measurement, it is necessary to clear the CH(n)F and CH(n+1)F bits.

To measure the positive-polarity pulse width of the tested signal (either in the one-shot mode or in the continuous modes), configure channel (n) to capture the rising edge (ELS(n)B:ELS(n)A = 1:0) and channel (n +1) to capture the falling edge (ELS(n+1)B:ELS(n+1)A = 0:1). When a second falling edge of the tested signal is detected, CH (n+1) F is set, the DECAP bit is cleared, and an interrupt is generated (if CH(n+1)IE=1). In the interrupt routine, make a subtraction of the values saved in the C (n+1) V and C (n) V registers to determine the positive-polarity pulse width of the tested signal and clear the CH (n+1) F bit.

If the application requires to measure the negative-polarity pulse width of the tested signal, configure channel (n) to capture the falling edge (ELS(n)B:ELS(n)A=0:1) and channel (n+1) to capture the rising edge (ELS(n+1)B:ELS(n+1)A=1:0). To determine the period of the tested signal, channel (n) and channel (n+1) must be sensitive on the same edges.

This example shows the dual-edge capture mode of the FTM0 module that is used to determine the positive pulse width of the input signals.

```
void FTMO Dual Edge Capture Mode()
  /* Enable clock for PORTD */
  CLOCK EnableClock (kCLOCK PortD);
  /* Enable clock for FTM0 */
  CLOCK EnableClock (kCLOCK Ftm0);
  /* Set PORTD pins for FT\overline{\text{M}}0 */
  PORTD->PCR[15] = PORT_PCR_MUX(2); // FTM0, Channel0
EnableIRQ(FTM0 Ch0 Ch1 IRQn); // Enable interrupt
     Enable dual-edge capture mode */
  FTM0->COMBINE = FTM COMBINE DECAPENO MASK | FTM COMBINE DECAPO MASK;
  /* Select positive polarity pulse width measurement and enable continuous mode for FTMO_CHO */FTMO->CONTROLS[0].CnSC = FTM_CnSC_MSA_MASK | FTM_CnSC_ELSA_MASK;
  FTMO->CONTROLS[1].CnsC = FTM_CnsC_ELSB_MASK | FTM_CnsC_CHIE_MASK; /* Reset counter */
  FTMO -> CNT = 0;
  /* Select clock */
  FTMO->SC = FTM_SC_CLKS(1);
void FTM1 PWM Output()
  /* Enable clock for PORTA */
  CLOCK EnableClock(kCLOCK_PortA);
  /* Enable clock for FTM1
  CLOCK EnableClock(kCLOCK Ftm1);
  /* Enable registers updating from write buffers */
  FTM1->MODE = FTM_MODE_WPDIS_MASK | FTM_MODE_FTMEN_MASK;
  /* Set PORT pins for FTM1 */
  PORTA->PCR[16] = PORT PCR MUX(2); // FTM1, Channel3
  /* Set Modulo in initialization stage (10kHz PWM frequency 048MHz system clock) */
  FTM1->MOD = FTM MOD MOD(4800-1);
  /* Set CNTIN in initialization stage */
  FTM1->CNTIN = FTM CNTIN INIT(0);
  /* Enable high-true pulses of PWM signals */
  FTM1->CONTROLS[3].CnSC = FTM CnSC MSB MASK | FTM CnSC ELSB MASK;
  /* Set channel value in initialization stage *
  FTM1->CONTROLS[3].CnV=FTM_CnV_VAL(2400); // 50% duty cycle
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x

```
/* Reset counter */
FTM1->CNT = 0;
/* Select clock */
FTM1->SC = FTM_SC_CLKS(1) | FTM_SC_PWMEN3_MASK;
}

void FTM0_Ch0_Ch1_IRQHandler()
{
    CH0_edge0 = FTM0->CONTROLS[0].CnV; // record COV value into the variable
    CH0_edge1 = FTM0->CONTROLS[1].CnV; // record C1V value into the variable
    FTM0_CH0_pulse_width = CH0_edge1 - CH0_edge0; // pulse width calculation of FTM0_CH0 signal
    FTM0->CONTROLS[1].CnSC &= ~FTM_CnSC_CHF_MASK; // clear FTM0_CH1 capture flag
}
```



Figure 8 shows the dual edge capture mode signal output:

- The scope channel CH1 represents the tested signal that is input to the FTM0\_CH0 channel (generated from FTM1 CH3).
- The pulse width of the signal is calculated and printed through UART, as shown in <u>Figure 9</u>. The pulse width of the tested signal is 50 µs.

```
Dual Edge Capture Mode Running...

FTM1_CH3 (J2-6) -> FTM0_CH0 (J3-15)

FTM1_CH3 (J2-6) -> SCOPE_CH1

Pulse Width:50.0 us

Pulse Width:50.0 us

Pulse Width:50.0 us
```

Figure 9. Positive-polarity pulse width of tested signal printed through UART

Features and Operation Modes of FlexTimer Module on MCX E24x

#### 3.7 Quadrature decoder mode

The quadrature decoder mode of the FTM module is used to decode the signals from the incremental encoder sensor which is commonly used in motor-control applications for the position measurement. The incremental encoders are based on the optical technology.

The encoder has three output signals. The Phase A and Phase B signals consist of a series of pulses which are phase-shifted by 90° (therefore the term "quadrature" is used). The third signal (called "Index") provides the absolute position information. In the motion control, it is used to check the pulse-counting consistency. After each revolution, the value of the counted pulses is captured and compared to the defined value. If a difference is detected, the control algorithm must perform the position offset compensation.

The current implementation of the MCX E24x device is equipped with up to eight FTM modules. While all FTMs can be configured to generate PWM signals to control electric motors, only the FTM1 and FTM2 modules can work in the quadrature decoder mode to measure the rotor position. They have dedicated pins for the Phase A and Phase B signals.

The quadrature encoder mode is selected when QUADEN = 1. There are two sub-modes that can be used in the quadrature encoder mode: the count and direction encoding mode and the Phase A and Phase B encoding mode. The count and direction encoding mode is enabled when QUADMODE = 1. In this mode, the Phase B input indicates the counting direction and the Phase A input defines the counting rate.

To process the Phase A and Phase B signals from the encoder sensor, enable the Phase A and Phase B encoding mode (QUADMODE = 0). In this mode, the Phase A and Phase B signals indicate the counting direction and the counting rate. If the Phase B signal lags the Phase A signal, the FTM counter increments after every detected rising/falling edge of both signals. If the Phase B signal leads the Phase A signal, the FTM counter decrements after every detected rising/falling edge of both signals and the QUADIR bit in the FTM QDCTRL register indicates the counting direction.

This code example demonstrates the functionality of the quadrature decoder mode with the activated Phase A and Phase B encoding sub-mode. FTM0 is used to generate PWM signals to simulate encoder signals and FTM1 to implement the quadrature decoder function.

```
void FTM1 Quadrature Decoder Mode()
   /* Enable clock for PORTB *
  CLOCK EnableClock (kCLOCK PortB);
  /* Enable clock for PORTC*/
  CLOCK EnableClock(kCLOCK PortC);
     Enable clock for PORTE*/
  CLOCK EnableClock(kCLOCK PortE);
  /* Enable clock for FTM1*/
CLOCK EnableClock(kCLOCK Ftm1);
  /* Set PORT pins for FTM1 */
PORTC->PCR[7] = PORT_PCR_MUX(6); // Set PTC7 for FTM1 - Phase A input
PORTB->PCR[2] = PORT_PCR_MUX(4); // Set PTB2 for FTM1 - Phase B input
PORTE->PCR[7] = PORT_PCR_MUX(1); // Set PTE7 for GPIO (FTM1 overflow flag)
  /* GPIO Initialize */
  gpio_pin_config_t gpio_config =
    kGPIO DigitalOutput,
   0
  GPIO_PinInit(GPIOE, 7, &gpio_config); // PTE7 init
  EnableIRQ(FTM1 Ovf Reload IRQn); // Enable FTM1 overflow interrupt
  /* Encoder simulation with totally 10 rising/falling edges */
  FTM1->MOD = FTM MOD MOD(10);
  FTM1->CNTIN = FTM_CNTIN_INIT(0);
  FTM1->QDCTRL= FTM QDCTRL QUADEN MASK;
  FTM1->CNT = 0;
   /* Select clock */
  FTM1->SC = FTM SC CLKS(1) | FTM SC TOIE MASK;
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x

```
void FTMO Encoder Output()
    /* Enable clock for PORTD */
   CLOCK EnableClock(kCLOCK PortD);
   /* Enable clock for PORTB */
   CLOCK EnableClock (kCLOCK PortB);
   /* Enable clock for FTM0 */
   CLOCK EnableClock(kCLOCK Ftm0);
   /* Enable registers updating from write buffers */
   FTMO->MODE = FTM MODE WPDIS MASK | FTM MODE FTMEN MASK;
   /* Set PORT pins for FTM0 */
PORTD->PCR[15] = PORT PCR MUX(2); // FTM0, Channel0
PORTD->PCR[16] = PORT PCR MUX(2); // FTM0, Channel1
   PORTB->PCR[16] = PORT_PCR_MUX(2); // FTM0, Channel4
PORTB->PCR[17] = PORT_PCR_MUX(2); // FTM0, Channel5
   /* Enable combine, complementary mode for channel pair CHO/CH1 and CH4/CH5 */
FTMO->COMBINE = FTM_COMBINE_COMBINEO MASK | FTM_COMBINE_COMPO MASK
                             FTM_COMBINE_COMBINE2_MASK | FTM_COMBINE_COMP2_MASK;
  FTMO->CONTROLS[0].CNSC=FTM_CNSC_ELSB_MASK; // Select high-true pulses
FTMO->CONTROLS[1].CNSC=FTM_CNSC_ELSB_MASK; // Select high-true pulses
FTMO->CONTROLS[4].CNSC=FTM_CNSC_ELSB_MASK; // Select high-true pulses
FTMO->CONTROLS[5].CNSC=FTM_CNSC_ELSB_MASK; // Select high-true pulses
FTMO->CONTROLS[5].CNSC=FTM_CNSC_ELSB_MASK; // Select high-true pulses
   /* Set Modulo (10kHz PWM frequency @48MHz system clock) */
   FTMO->MOD = FTM_MOD_MOD(4800-1); // Set modulo
  FTMO->CONTROLS[0].CnV=FTM_CnV_VAL(1200); // Set channel Value FTMO->CONTROLS[1].CnV=FTM_CnV_VAL(3600); // Set channel Value FTMO->CONTROLS[4].CnV=FTM_CnV_VAL(2400); // Set channel Value FTMO->CONTROLS[5].CnV=FTM_CnV_VAL(4800); // Set channel Value
   FTM0->CNT = 0; // Counter reset
   FTM0->SC |= FTM_SC_CLKS(1) | FTM_SC_PWMEN0_MASK | FTM_SC_PWMEN1_MASK | FTM_SC_PWMEN4_MASK | FTM_SC_PWMEN5_MASK; 7/ Select clock and enable PWM
void FTM1 Ovf Reload IRQHandler()
   GPIO_PortToggle(GPIOE, 1 << 7); // Show interrupt</pre>
   FTM1->SC &= ~FTM SC TOF MASK;
                                                         // Clear flag
```



Figure 10 shows the Quadrature decoder mode signal output:

#### Features and Operation Modes of FlexTimer Module on MCX E24x

- The scope channels CH1 and CH2 display the encoder signals Phase A and Phase B that are input to the FTM1 module (generated from FTM0\_CH0 and FTM0\_CH4). The scope channel CH3 represents the FTM1 counter overflow interrupt generated every time the FTM counter reaches the value of the MODULO register (every time 10 rising/falling edges of the Phase A and Phase B signals are detected).
- When the FTM1 timer overflow occurs, the TOF bit and TOFDIR are set because the Phase B signal lags the Phase A signal.

## 4 FTM features

#### 4.1 Masking, inverting, and software-controlling features

The masking and software-controlling features force the FTM channels' output to the inactive/required state, keeping a constant logic to the channels' output. These FTM functions can turn the power devices on/off via software. The inverting feature swaps the signals between the FTM channel pairs.

The masking feature is used in BLDC motor-control applications. A 3-phase BLDC motor is normally supplied by a 3-phase power inverter equipped with either six MOSFETs or six IGBTs (Insulated-Gate Bipolar Transistors). A commonly used control technique for BLDC motors is the 6-step commutation method. In this control technique, two phases are energized and the third one is disconnected. Therefore, both power devices of the corresponding inverter branch must be turned off. The masking feature of the FTM module can be implemented in this application to fulfill such function. Each FTM channel has a corresponding bit in the FTM\_OUTMASK register. Any write to the OUTMASK register just latches the value in its write buffer. The output logic of the FTM channels can then be updated immediately after writing into the FTM\_OUTMASK register while the FTM clock is disabled (at each rising edge of the FTM input clock when FTM\_SYNC[SYNCHOM] = 0) or updated by the software or hardware synchronization, enabling the SWOM bit or the HWOM bit in the FTM\_SYNCONF register (see Section 4.3). When the FTM\_CHx channel is masked, its output logic is kept high/low, according to the bit enabled in the FTM\_POL register.

The software-controlling feature forces the output of the FTM channels to the software-defined values by setting or clearing the CHxOC bits in the FTM\_SWOCTRL register. If the CHxOC bits are cleared, the output of the FTM channels remains driven by the PWM or another source. If the CHxOC bits are set, the output of the corresponding FTM channel is affected by the software. The CHxOCV bit in the FTM\_SWOCTRL register controls the logic of the individual FTM channel. The output of the FTM\_CHx channel is high when CHxOCV = 1. Otherwise, it is 0.

The inverting function is commonly used in DC motor-control applications. The DC motor is supplied by the H-bridge and one channel pair (FTM0\_CH0/CH1, for example) is connected to one branch while the other channel pair (FTM0\_CH2/CH3, for example) is connected to another branch. Both channel pairs work in the complementary mode. Such an application requires that the diagonal power devices turn on/off at the same time, which means that the FTM0\_CH0 and FTM0\_CH3 must have the same timing. To guarantee such a condition, the FTM0\_CH1 and FTM0\_CH3 must work in the inverting mode. The INVMEN bit in the FTM\_INVCTRL register enables inverting the corresponding channel pair. The value written in the FTM\_INVCTRL register can be updated from the buffer in the same way as the FTM\_OUTMASK register.

The masking function is demonstrated in Section 4.3.3.

#### 4.2 Fault control feature

The fault control of the FTM module plays an important role in motor-control applications because it provides an opportunity to protect the power devices and the whole electrical drive system in critical moments, when undesirable behaviors such as over-temperature, over-voltage, or over-current occur. In such a case, the fault signal can be generated via a sensor or a special circuit. The fault control is able to stop all PWM channels when a fault signal is detected on the input of the FTM fault pin/pins. An interrupt can be generated after receiving the fault signal and the undesirable behavior can be mitigated.

#### Features and Operation Modes of FlexTimer Module on MCX E24x

When a fault signal appears, the outputs of the FTM channels are disabled and kept at a safe logic defined in the  $FTM\_POL$  register. For example, if POL0 = 1 and a fault is present, the  $FTM\_CH0$  is disabled and forced to a high logic. On the contrary, if POL0 = 0 and a fault is present, the  $FTM\_CH0$  is disabled, but forced to a low logic.

FTM has multiple channels. However, FTM can't disable the specific channels by the means of specific fault signals. One fault signal is generated as a result of the OR operation of all entering fault signals. Whether the FTM channel can be disabled by the fault signal or not depends on the FAULTENX bit in the FTM\_COMBINE register. The resulting fault signal can disable all FTM channels or disable only the even channels (FTM\_CH0/CH2/CH4/CH6). The selection depends on the FAULTM bit field in the FTM\_MODE register.

There are two ways of recovering the output of the PWM channels: the automatic fault clearing set by FAULTM[1:0] = 1:1 and the manual fault clearing when FAULTM[1:0] = 0:1 or 1:0. The PWM signals are recovered from the safety state in the next PWM cycle without any software intervention when the automatic fault-clearing mode is selected. To recover the PWM signals in the manual clearing mode, clear the FAULTF bit in the FTM MODE register and then enable the PWM in the next PWM cycle.

In the following code example, initiate the two FTM modules to demonstrate the fault-control feature. While FTM0 is configured to generate the CPWM, FTM1 is used to generate the fault signal that affects the output of the FTM0 channels externally through the fault pin FTM0 FLT3.

```
void CPWM and Fault Control()
    /* Enable clock for PORTD */
    CLOCK EnableClock(kCLOCK PortD);
    /* Enable clock for PORTB */
    CLOCK EnableClock(kCLOCK PortB);
    /* Enable clock for FTMO */
    CLOCK_EnableClock(kCLOCK_Ftm0);
    /* Enable registers upda\overline{	ext{t}}ing from write buffers */
    FTMO->MODE = FTM MODE WPDIS MASK | FTM MODE FTMEN MASK;
     /* Set PORT pins for FTM0 *\overline{/}
    PORTD->PCR[15] = PORT_PCR_MUX(2); // FTM0, Channel0
PORTD->PCR[16] = PORT_PCR_MUX(2); // FTM0, Channel1
PORTB->PCR[16] = PORT_PCR_MUX(2); // FTM0, Channel4
PORTB->PCR[17] = PORT_PCR_MUX(2); // FTM0, Channel5
                                   = PORT_PCR_MUX(2); // FTM0_FLT3
    PORTD->PCR[4]
    /* Enable combine, complementary mode and dead-time for pair channel 0/1 and 4/5 */
    FTM0->COMBINE = FTM_COMBINE_COMBINEO MASK|FTM_COMBINE_COMPO_MASK|FTM_COMBINE_DTENO_MASK
| FTM_COMBINE_FAULTENO_MASK|FTM_COMBINECOMBINEO MASK|FTM_COMBINECOMBINEO MASK|FTM_COMBINECOMBINEO MASK|FTM_COMBINEO MASK|F
                                      FTM COMBINE DTEN2 MASK|FTM COMBINE FAULTEN2 MASK;
    /* Set Modulo (10kHz PWM frequency @48MHz system clock) */
    FTMO->MOD = FTM MOD MOD(4800-1);
     /* Set CNTIN */
    FTMO->CNTIN = FTM_CNTIN_INIT(0);
     /* High-true pulses of PWM signals */
    FTM0->CONTROLS[0].CnSC = FTM CnSC ELSB MASK;
    FTMO->CONTROLS[1].CnSC = FTM CnSC ELSB MASK;
    FTM0->CONTROLS[4].CnSC = FTM CnSC ELSB MASK;
    FTMO->CONTROLS[5].CnSC = FTM CnSC ELSB MASK;
    /* Set Channel Value */
    FTM0->CONTROLS[0].CnV=FTM CnV VAL(1200);
    FTM0->CONTROLS[1].CnV=FTM CnV VAL(3600);
    FTM0->CONTROLS[4].CnV=FTM_CnV_VAL(2400);
    FTM0->CONTROLS[5].CnV=FTM CnV VAL(4800);
     /* FTM counter reset */
    FTMO -> CNT = 0;
          Insert deadtime (lus) */
    FTMO->DEADTIME = FTM DEADTIME DTPS(3) |
    FTM DEADTIME DTVAL(3);
          Set PTD4 pin as a fault input FTM0 FLT3 */
    FTMO->FLTCTRL = FTM FLTCTRL FAULT3EN MASK;
    /* Enable fault control for all channels and select automatic fault clearing mode */
    FTM0->MODE |= FTM MODE FAULTM(3);
    /* Safe value is set as a low after fault input is detected */
    FTMO->POL = (~FTM_POL_POL0_MASK) & (~FTM_POL_POL1_MASK) & (~FTM_POL_POL4_MASK) &
   (~FTM POL POL5 MAS\overline{K});
      * A 1 at the fault input indicates the fault */
    FTM0->FLTPOL &= ~FTM FLTPOL FLT3POL MASK;
    /* Select clock and enable PWM */
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x

```
FTMO->SC = FTM SC CLKS(1) | FTM SC PWMENO MASK | FTM SC PWMEN1 MASK | FTM SC PWMEN4 MASK
            | FTM SC PWMEN5 MASK;
void FTM1 PWM Output()
  /* Enable clock for PORTA */
  CLOCK EnableClock(kCLOCK PortA);
   * Enable clock for FTM1 */
  CLOCK EnableClock (kCLOCK Ftm1);
  /* Enable registers updating from write buffers */
  FTM1->MODE = FTM MODE WPDIS MASK | FTM MODE FTMEN MASK;
  /* Set PORT pins for FTM1 *7
PORTA->PCR[16] = PORT_PCR_MUX(2); // FTM1, Channel3
  /st Set Modulo in initialization stage (1.2kHz PWM frequency @48MHz system clock) st/
  FTM1->MOD = FTM_MOD_MOD(40000-1);
  /* Set CNTIN in initialization stage */
  FTM1->CNTIN = FTM_CNTIN_INIT(0);
  /* Enable high-true pulses of PWM signals */
  FTM1->CONTROLS[3].CnSC = FTM_CnSC_MSB_MASK | FTM_CnSC_ELSB_MASK;

/* Set channel value in initialization stage */
  FTM1->CONTROLS[3].CnV=FTM_CnV_VAL(20000); // 50% duty cycle
  /* Reset counter */
  FTM1->CNT = 0;
  /* Select clock */
  FTM1->SC = FTM SC CLKS(1) | FTM SC PWMEN3 MASK;
}
```

The resulting behavior of the code example is as shown in Figure 11.



Figure 11 shows the fault control of CPWM signal output:

- The scope channels CH1, CH2, and CH3 represent the FTM0 module channels FTM0\_CH0, FTM0\_CH1, and FTM0\_CH4, respectively. Channel CH4 shows the external fault signal (generated from FTM1\_CH3) whose frequency is about one eighth of the FTM0 frequency.
- FTM0\_CH0 and FTM0\_CH1 work in the complementary and combine mode, same as FTM0\_CH4 and FTM0\_CH5.

#### Features and Operation Modes of FlexTimer Module on MCX E24x

• When a rising edge is detected on the FTM0\_FLT3 fault input pin (generated from FTM1\_CH3), all FTM0 channels are forced to the safe (low) logic. Figure 11 also shows that all FTM0 channels are recovered at the next counter cycle, when the fault input signal is 0.

#### 4.3 Updating FTM registers

In motor-control or switched-mode power supply applications, the PWM duty cycle controls the voltage applied on the load. To control the PWM duty cycle, set the appropriate values in the <code>FTM\_CnV</code> and <code>FTM\_CNTIN</code> registers. Some applications require to change the period of the PWM as well. The period is controlled by the value in the <code>FTM\_MOD</code> register.

The FTM\_CnV, FTM\_CNTIN, and FTM\_MOD are double-buffered registers which means that a write to these registers just latches their values into their write buffers. The double-buffered registers of the FTM module are the Channel (n) Value (FTM\_CnV), Counter Initial Value (FTM\_CNTIN), Modulo (FTM\_MOD), Half Cycle Register (FTM\_HCR), Output Mask (OUTMASK), Software Output Control (SWOCTRL), and Inverting Control register (INVCTRL). The double-buffered registers can be updated with their buffered values according to the updating scheme chosen. The current implementation on the MCX E24x device enables using the half or full cycle reload strategy, software or hardware PWM synchronization, or it is possible to bypass the buffers. Table 3 summarizes all double-buffered registers and their updating methods.

Table 3. Updating double-buffered FTM register

| Update technique                                   | Double-buffered FTM registers         | Note                                                                                                                                                                                   |  |
|----------------------------------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Initialization stage<br>CLKS[1:0] = 0:0            | CnV, CNTIN, MOD, HCR                  | The registers are loaded immediately.                                                                                                                                                  |  |
| TPM compatibility<br>CLKS[1:0] ≠ 0:0,<br>FTMEN = 0 | CnV, CNTIN, MOD, HCR                  | The CNTIN register is loaded immediately and the CnV, MOD, and HCR registers at the end of the FTM counter period.  The CnV register is loaded immediately in the output compare mode. |  |
| Software                                           | CnV, CNTIN, MOD, HCR<br>(SWWRBUF = 1) | The registers are updated by the software trigger-enabling SWSYNC bit.  If SWRSTCNT = 1, the software trigger resets the FTM counter reset.                                            |  |
| synchronization<br>CLKS[1:0] ≠ 0:0,<br>FTMEN=1,    | SWOCTRL<br>(SWOC = 1, SWSOC = 1)      |                                                                                                                                                                                        |  |
| SYNCMODE = 1                                       | OUTMASK<br>(SYNCHOM = 1, SWOM = 1)    | The registers are updated by the software trigger-enabling SWSYNC bit.                                                                                                                 |  |
|                                                    | INVCTRL<br>(INVC = 1, SWINVC = 1)     |                                                                                                                                                                                        |  |
| Hardware synchronization                           | CnV, CNTIN, MOD, HCR<br>(HWWRBUF = 1) |                                                                                                                                                                                        |  |
| CLKS[1:0] ≠ 0:0,<br>FTMEN=1,<br>SYNCMODE = 1       | SWOCTRL<br>(SWOC = 1, HWSOC = 1)      | The registers are updated when TRIGn = 1 and the hardware trigger is detected at the trigger (n) input signal.                                                                         |  |
|                                                    | OUTMASK<br>(SYNCHOM = 1, HWOM = 1)    | If HWTRIGMODE = 1, the hardware trigger clears the TRIGn bit.                                                                                                                          |  |
|                                                    | INVCTRL<br>(INVC = 1, HWINVC = 1)     |                                                                                                                                                                                        |  |
| Half and full cycle reload strategy                | CnV, CNTIN, MOD, HCR                  | In the up-counting mode, the synchronization points are when the FTM counter changes from MOD to CNTIN, enable CNTMIN, or CNTMAX bit.                                                  |  |

#### Features and Operation Modes of FlexTimer Module on MCX E24x

Table 3. Updating double-buffered FTM register...continued

| Update technique            | Double-buffered FTM registers | Note                                                |
|-----------------------------|-------------------------------|-----------------------------------------------------|
| CLKS[1:0] ≠ 0:0,<br>FTMEN=1 |                               | For the up/down-counting mode, see <u>Table 4</u> . |

Table 4. Reload opportunities in up/down-counting mode

| FTM_SYNC bits             | Reload opportunities selected                                                      |  |  |  |
|---------------------------|------------------------------------------------------------------------------------|--|--|--|
| CNTMIN = 0 and CNTMAX = 0 | When the counter turns from up to down (compatibility mode).                       |  |  |  |
| CNTMIN = 1 and CNTMAX = 0 | When the counter turns from down to up.                                            |  |  |  |
| CNTMIN = 0 and CNTMAX = 1 | When the counter turns from up to down.                                            |  |  |  |
| CNTMIN = 1 and CNTMAX = 1 | When the counter turns from down to up and when the counter turns from up to down. |  |  |  |

The configuration steps of the updating methods are discussed in detail in the following sections.

#### 4.3.1 Updating FTM registers in initialization stage

In the initialization stage, when the FTM module is disabled (CLKS[1:0] = 0:0), the FTM registers are updated immediately after writing to the FTM\_CnV, FTM\_CNTIN, and FTM\_MOD registers. After the initialization step, the FTM module starts to generate the PWM by setting CLKS[1:0]  $\neq$  0:0 and enabling the PWMENn bits in the FTM SC register.

#### 4.3.2 Half- and full-cycle reload strategies

To change the PWM duty cycle or the PWM time period while the FTM counter is running, it is possible to apply the half- and full-cycle reload strategies. This feature enables updating the FTM registers with the content of their buffers, depending on the chosen reload opportunity, by setting the LDOK bit in the FTM\_PWMLOAD register. When a reload opportunity occurs, the RF bit in the FTM\_SC register is set and the reload-opportunity interrupt is generated if RIE = 1. In the interrupt routine, the FTM registers can be changed and updated simultaneously.

If the up-counting mode is selected to generate the EPWM, the half and full cycle reload opportunities can update the FTM registers according to these steps:

- 1. Initialize FTM0 to generate the EPWM and enable the FTMEN bit in the FTM\_MODE register and the RIE bit in the FTM\_SC register.
- 2. Enable the HCSEL bit in the FTM\_PWMLOAD register and adjust the value in the FTM\_HCR register to MOD/2 for the half-cycle reload opportunity and HCSEL = 0 for the full-cycle reload opportunity.
- 3. In the interrupt routine, change the value of the FTM registers to update the values from their buffers and clear the RF bit in the FTM SC register.

A different scenario must be considered when the up/down-counting mode is selected to generate the CPWM:

- 1. Initialize FTM0 to generate the CPWM and enable the FTMEN bit in the FTM\_MODE register and the RIE bit in the FTM\_SC register.
- 2. Enable the CNTMIN and CNTMAX bits in the FTM\_SYNC register for the half-cycle reload opportunity and the CNTMIN = CNTMAX = 0 for the full-cycle reload opportunity.
- 3. In the interrupt routine, change the value of the FTM registers to update the values from their buffers and clear the RF bit in the FTM SC register.

#### Features and Operation Modes of FlexTimer Module on MCX E24x

The following code example shows a part of the FTM0 initialization for the CPWM and the half-cycle reload opportunity interrupt routine, where the values COV and C2V of the channels are modified according to the variable flag.

```
void Half and Full Cycle Reload()
  /* Enable clock for PORTD */
  CLOCK EnableClock (kCLOCK PortD);
  /* Enable clock for PORTB */
  CLOCK EnableClock(kCLOCK_PortB);
  /* Enable clock for FTMO */
  CLOCK EnableClock(kCLOCK Ftm0);
  /* Enable registers updating from write buffers */
  FTMO->MODE = FTM_MODE_WPDIS_MASK | FTM_MODE_FTMEN_MASK; /* Set PORT pins for FTMO */
  PORTD->PCR[15] = PORT_PCR_MUX(2); // FTM0, Channel0
PORTD->PCR[16] = PORT_PCR_MUX(2); // FTM0, Channel1
PORTB->PCR[16] = PORT_PCR_MUX(2); // FTM0, Channel4
PORTB->PCR[17] = PORT_PCR_MUX(2); // FTM0, Channel5
  /* Select up-down counter for Center-Aligned PWM */
  FTM0->SC = FTM SC CPWMS MASK;
  /* Complementary mode, sync and dead-time enable for channel0 and channel1 */
FTMO->COMBINE = FTM_COMBINE_SYNCENO_MASK | FTM_COMBINE_COMPO_MASK | FTM_COMBINE_DTENO_MASK;
  /* Complementary mode, sync and dead-time enable for channel\overline{4} and channel5 */
  FTMO->COMBINE |= FTM_COMBINE_SYNCEN2_MASK | FTM_COMBINE_COMP2_MASK | FTM_COMBINE_DTEN2_MASK;
  /* Set Modulo (10kHz PWM frequency @48MHz system clock) */
  FTMO->MOD = FTM MOD MOD(2400-1);
  /* Set CNTIN */
FTMO->CNTIN = FTM_CNTIN_INIT(0);
  /* High-true pulses of PWM signals */
  FTM0->CONTROLS[0].CnsC = FTM_CnsC_ELSB_MASK;
FTM0->CONTROLS[1].CnsC = FTM_CnsC_ELSB_MASK;
  FTMO->CONTROLS[4].CnSC = FTM CnSC ELSB MASK;
  FTMO->CONTROLS[5].CnSC = FTM CnSC ELSB MASK;
  /* Set Channel Value */
  FTM0->CONTROLS[0].CnV=FTM_CnV_VAL(2400);
  FTM0->CONTROLS[4].CnV=FTM_CnV_VAL(1200);
  /* FTM counter reset */
  FTMO -> CNT = 0;
  /* Enable clock for PORTE */
  CLOCK EnableClock(kCLOCK PortE);
  PORTE->PCR[7] = PORT PCR MUX(1); // PTE7 set as reload flag
  /* GPIO Initialize */
  gpio pin config t gpio config =
     kGPIO DigitalOutput,
  GPIO PinInit(GPIOE, 7, &gpio config);
  EnableIRQ(FTM0 Ovf Reload IRQn);
  if(g hf reload) // half cycle reload enable flag
     /* Enable half cycle reload */
    FTMO->SYNC = FTM_SYNC_CNTMAX_MASK | FTM SYNC CNTMIN MASK;
  // else: full cycle reload enable
  /* Select clock, enable reload opportunity interrupt and enable PWM generation */
FTMO->SC |= FTM_SC_CLKS(1) | FTM_SC_PWMEN0_MASK | FTM_SC_PWMEN1_MASK | FTM_SC_PWMEN4_MASK
               | FTM_SC_PWMEN5_MASK | FTM_SC_RIE_MASK;
void FTM0_Ovf_Reload_IRQHandler()
  FTMO->PWMLOAD |= FTM PWMLOAD LDOK MASK; // Set LDOK bit
  if(g_reload_flag) // reload_flag
    FTM0->CONTROLS[0].CnV=FTM_CnV_VAL(2400); // 50%
    FTMO->CONTROLS[4].CnV=FTM CnV VAL(1200); // 25%
  else
    FTM0->CONTROLS[0].CnV=FTM CnV VAL(1200); // 25%
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x

```
FTM0->CONTROLS[4].CnV=FTM_CnV_VAL(2400); // 50%
}
g_reload_flag = !g_reload_flag;
GPIO_PortToggle(GPIOE, 1 << 7);
FTM0->SC &= ~FTM_SC_RF_MASK; // Clear Timer Flag
}
```

<u>Figure 12</u> and <u>Figure 13</u> demonstrate the half- and full-cycle reload strategy of the FTM registers performing the CPWM.





Figure 12 and Figure 13 show the CPWM half- and full-cycle reload signal output:

14617 All information provided in this document is subject to legal disclaimers.

© 2025 NXP B.V. All rights reserved.

#### Features and Operation Modes of FlexTimer Module on MCX E24x

- The scope channels CH1, CH2, and CH3 represent the FTM0\_CH0, FTM0\_CH1, and FTM0\_CH4 of the FTM0 module, respectively. CH4 is used to show the reload opportunity of the FTM0 registers that occurs every half/full-cycle of the up-down counter.
- The FTM0 CH0 and FTM0 CH1 work in the complementary mode, same as the FTM0 CH4 and FTM0 CH5.
- In the first reload opportunity, the 100 % and 50 % duty cycles are applied to the complementary channel pairs FTM0\_CH0/CH1 and FTM0\_CH4/CH5, respectively. At the next reload opportunity, the C0V and C4V registers are updated from their new buffed values, therefore the duty cycles of FTM0\_CH0/CH1 and FTM0\_CH4/CH5 are changed to 50 % and 100 %, respectively.

### 4.3.3 Updating FTM registers by software trigger - Software synchronization

All double-buffered FTM registers can be updated by the software synchronization, enabling the SWSYNC bit in the FTM\_SYNC register (as shown in <u>Table 3</u>). The update can take place immediately or at the next loading point selected, according to the boundary cycle and the loading points of the selected counting mode.

In the up-counting mode, the boundary cycle is defined as when the counter wraps to its initial value (CNTIN). When in the up/down-counting mode, the boundary cycle is defined as when the counter turns from the down-counting to the up-counting and from the up-counting to the down-counting. In the up-counting mode, the loading points are enabled if one of the CNTMIN or CTMAX bits is 1.

If the SWRSTCNT bit is set in the FTM\_SYNCONF register, the FTM counter restarts from the FTM\_CNTIN and the FTM registers are updated immediately. If the SWRSTCNT bit is cleared, the FTM counter remains counting and the FTM registers are updated at the next loading point.

Perform the following steps to configure the FTM module to generate the CPWM and use the software synchronization to update the FTM CnV and FTM OUTMASK registers:

- 1. Initialize FTM0 to generate the CPWM and enable the FTMEN bit in the FTM\_MODE register and the RIE bit in the FTM\_SC register.
- 2. Enable the SYNCMODE, SWWRBUF, and SWOM bits in the SYNCONF register to select the software synchronization of the CnV and OUTMASK registers.
- 3. Enable the software trigger by FTM\_SYNC[SWSYNC] = 1 and wait for the next loading point.
- 4. In the reload opportunity interrupt routine, change the value of the CnV and OUTMASK registers and enable the software trigger by SWSYNC.

The following code example shows a part of the FTM0 initialization for the CPWM and demonstrates the software synchronization for updating the FTM\_CnV and FTM\_OUTMASK registers.

```
void FTM0_CPWM_SoftSync()
  /* Enable clock for PORTD */
  CLOCK EnableClock(kCLOCK PortD);
  /* Enable clock for PORTB */
  CLOCK EnableClock (kCLOCK PortB);
   ^{\prime *} Enable clock for FTMO ^{*}/
  CLOCK EnableClock(kCLOCK Ftm0);
  /* Enable registers updating from write buffers */
  FTMO->MODE = FTM MODE WPDIS MASK | FTM MODE FTMEN MASK;
   /* Set PORT pins for \overline{	t FTM0} *\overline{	t /}
  PORTD->PCR[15] = PORT_PCR_MUX(2); // FTM0, Channel0
  PORTD->PCR[16] = PORT PCR MUX(2); // FTM0, Channel1
PORTB->PCR[16] = PORT PCR MUX(2); // FTM0, Channel4
  PORTB->PCR[17] = PORT_PCR_MUX(2); // FTM0, Channel5
   /* Select up-down counter for Center-Align PWM ^{\star} /
  FTM0->SC = FTM SC CPWMS MASK;
  /* Complementary mode, sync and dead-time enable for channel0 and channel1 */
FTMO->COMBINE |= FTM_COMBINE_SYNCENO_MASK | FTM_COMBINE_COMPO_MASK | FTM_COMBINE_DTENO_MASK;
  /* Complementary mode, sync and dead-time enable for channel4 and channel5 */
FTMO->COMBINE |= FTM_COMBINE_SYNCEN2_MASK | FTM_COMBINE_COMP2_MASK | FTM_COMBINE_DTEN2_MASK;
   * Set Modulo (10kHz PWM frequency @48MHz system clock)
  FTMO->MOD = FTM MOD MOD(2400-1);
  /* Set CNTIN */
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x

```
FTM0->CNTIN = FTM CNTIN INIT(0);
  /* High-true pulses of PWM signals */
FTMO->CONTROLS[0].CnsC = FTM CnsC ELSB MASK;
FTMO->CONTROLS[1].CnsC = FTM_CnsC_ELSB_MASK;
FTMO->CONTROLS[4].CnsC = FTM_CnsC_ELSB_MASK;
  FTMO->CONTROLS[5].CnSC = FTM CnSC ELSB MASK;
  /* Set Channel Value */
FTMO->CONTROLS[0].CnV=FTM_CnV_VAL(1200); // 50%
   FTM0->CONTROLS[4].CnV=FTM_CnV_VAL(600); // 25%
      FTM counter reset */
   FTMO -> CNT = 0;
   /* Enable clock for PORTE */
  CLOCK_EnableClock(kCLOCK PortE);
   PORTE->PCR[7] = PORT_PCR_MUX(1); // PTE7 set as reload flag
   /* GPIO Initialize */
   gpio_pin_config_t gpio_config =
   kGPIO DigitalOutput,
   0
   };
  GPIO_PinInit(GPIOE, 7, &gpio_config); // GPIO init
EnableIRQ(FTMO_Ovf_Reload_IRQn); // Enable interrupt
  /* Select clock, enable reload opportunity interrupt */
FTMO->SC |= FTM_SC_CLKS(1) | FTM_SC_RIE_MASK;
/* Enable reload opportunity interrupt when FTM counter reach CNTMAX value */
FTMO->SYNC |= FTM_SYNC_SYNCHOM_MASK | FTM_SYNC_CNTMAX_MASK;
   /* Allow each fourth reload opportunity interrupt */
   FTM0->CONF = FTM CONF LDFQ(3);
   /* Enable software synchronization */
   FTMO->SYNCONF = FTM_SYNCONF_SYNCMODE_MASK | FTM_SYNCONF_SWWRBUF_MASK | FTM_SYNCONF_SWOM_MASK;
   /* Enable PWM generation */
   FTMO->SC |= FTM_SC_PWMEN0_MASK | FTM_SC_PWMEN1_MASK | FTM_SC_PWMEN4_MASK | FTM_SC_PWMEN5_MASK;
void FTM0 Ovf Reload IRQHandler()
   static bool flag = false;
   if(g reload flag)
     /* Enable FTM0 CH0/FTM0 CH1 mask */
    FTMO->OUTMASK = FTM OUTMASK CHOOM MASK | FTM OUTMASK CHIOM MASK;
    FTMO->CONTROLS[0].CnV=FTM_CnV_VAL(600); // 25%
FTMO->CONTROLS[4].CnV=FTM_CnV_VAL(600); // 25%
    if(flag)
     /* Set FTM0_CH0/FTM0_CH1 output polarity to high */
FTM0->POL = FTM_POL_POL0_MASK | FTM_POL_POL1_MASK;
    else
      /* Set FTM0 CH0/FTM0 CH1 output polarity to low */
     FTMO->POL &= (~FTM POL POLO MASK) & (~FTM POL POL1 MASK);
    flag = !flag;
   else
   .
/* Set FTM0 CH0/FTM0 CH1 output polarity to low */
   /* Set FTMU_CHO/FTMU_CHI Output polarity to low */
FTMO->POL &= (~FTM_POL_POL0_MASK) & (~FTM_POL_POL1_MASK);
/* Disable FTMO_CHO/FTMO_CHI mask */
FTMO->OUTMASK &= (~FTM_OUTMASK_CHOOM_MASK) & (~FTM_OUTMASK_CHIOM_MASK);
FTMO->CONTROLS[0].CnV=FTM_CnV_VAL(1200); // 50%
FTMO->CONTROLS[4].CnV=FTM_CnV_VAL(1200); // 50%
  g reload_flag = !g_reload_flag;
  GPIO_PortToggle(GPIOE, 1 << 7); // Toggle PTE7 to show reload opportunities FTMO->SYNC |= FTM_SYNC_SWSYNC_MASK; // Software sync
  FTMO->SC &= ~FTM_SC_RF_MASK; 7/ Clear Timer Flag
}
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x



Figure 14 shows the software synchronization of CPWM signal output:

- The scope channels CH1, CH2, and CH3 represent FTM0\_CH0, FTM0\_CH1, and FTM0\_CH4 of the FTM0 module, respectively. Channel CH4 is used to show the software trigger which occurs every fourth PWM period.
- FTM0 CH0 and FTM0 CH1 work in the complementary mode, same as FTM0 CH4 and FTM0 CH5.
- The duty cycles of channel pairs FTM0\_CH0/FTM0\_CH1 and FTM0\_CH4/FTM0\_CH5 change from 50 % to 25 % (and vice-versa), depending on the software trigger events that update the C0V and C4V registers. Moreover, the first complementary channel pair FTM0\_CH0/FTM0\_CH1 shows the masking feature.

#### 4.3.4 Updating FTM registers by hardware trigger - Hardware synchronization

The hardware synchronization is another way of updating the FTM registers when the counter is running. In this case, the interrupt routine is not necessary because the FTM registers can be changed at any time during the code execution and their values are updated when a hardware trigger occurs. The CPU load can be significantly reduced this way.

Three hardware trigger signal inputs of the FTM module can be selected depending on the enabled <code>TRIGn</code> bit in the <code>FTM\_SYNC</code> register. If <code>TRIGO</code> is set, the hardware trigger source comes from many other modules, such as LPIT and CMP (and other) through a flexible <code>TRIGMUX</code> module. By setting the <code>TRIG1</code> bit in the <code>FTM\_SYNC</code> register, a hardware trigger is generated according to the <code>FTMOSYNCBIT</code> bit in the <code>SIM\_FTMOPT1</code> register. In this section, the third option is demonstrated by enabling the <code>TRIG2</code> bit. In this case, the <code>FTMx\_FLTO</code> fault pin is chosen as the hardware trigger input for the FTM hardware synchronization.

- 1. Initialize FTM0 to generate the CPWM and enable the FTMEN bit in the FTM\_MODE register.
- 2. Enable the SYNCMODE and HWWRBUF bits in the FTMO\_SYNCONF register to select the hardware synchronization.
- 3. Enable the TRIG2 bit in the FTM0\_SYNC register to select the FTM0\_FLT0 fault pin as the hardware trigger input for the FTM0 hardware synchronization.
- 4. Initialize the FTM1 module to generate a periodic signal for the FTM0 hardware trigger input. To better demonstrate the FTM0 hardware synchronization, the frequency of FTM1 must be lower than the frequency of FTM0.

#### Features and Operation Modes of FlexTimer Module on MCX E24x

5. Generate a reload opportunity interrupt by enabling the RIE bit in the FTM1\_SC register and change the values in the C0V and C4V registers. Wait for a hardware trigger event that updates the values from the buffers

The core code for hardware synchronization is as follows:

```
void FTM0 CPWM HardSync()
  /* Enable clock for PORTD */
  CLOCK EnableClock (kCLOCK PortD);
  /* Enable clock for PORTB *
  CLOCK EnableClock (kCLOCK PortB);
  ^{\prime *} Enable clock for PORTA ^{*} /
  CLOCK EnableClock (kCLOCK PortA);
   ^{\prime *} Enable clock for FTM0 ^{*} ,
  CLOCK EnableClock(kCLOCK Ftm0);
  /* Enable registers updating from write buffers */
  FTMO->MODE = FTM MODE WPDIS MASK | FTM MODE FTMEN MASK;
   ^{\prime}* Set PORT pins for FTM0 *^{\prime}
  PORTD->PCR[15] = PORT PCR MUX(2); // FTM0, Channel0
  PORTD->PCR[16] = PORT_PCR_MUX(2); // FTM0, Channel1
PORTB->PCR[16] = PORT_PCR_MUX(2); // FTM0, Channel4
  PORTB->PCR[17] = PORT_PCR_MUX(2); // FTM0, Channel5
PORTA->PCR[14] = PORT_PCR_MUX(2); // FTM0 FLT0
/* Set PTA14 pin as a fault input FTM0_FLT0 */
  FTMO->FLTCTRL = FTM FLTCTRL FAULTOEN MASK;
     Select up-down counter for Center-Align PWM */
  FTM0->SC = FTM SC CPWMS MASK;
  /* Complementary mode, sync and dead-time enable for channel0 and channel1 */
FTMO->COMBINE |= FTM COMBINE SYNCENO MASK | FTM COMBINE COMPO MASK | FTM COMBINE DTENO MASK;
  /* Complementary mode, sync and dead-time enable for channel4 and channel5 */
FTMO->COMBINE |= FTM_COMBINE_SYNCEN2_MASK | FTM_COMBINE_COMP2_MASK | FTM_COMBINE_DTEN2_MASK;
/* Set Modulo (10kHz PWM frequency @48MHz system clock) */
  FTMO->MOD = FTM MOD MOD(2400-1);
  /* Set CNTIN *
  FTMO->CNTIN = FTM CNTIN INIT(0);
  /* High-true pulses of PWM signals */
FTM0->CONTROLS[0].CnSC = FTM_CnSC_ELSB_MASK;
  FTMO->CONTROLS[1].CnsC = FTM_CnsC_ELSB_MASK;
FTMO->CONTROLS[4].CnsC = FTM_CnsC_ELSB_MASK;
  FTMO->CONTROLS[5].CnsC = FTM_CnsC_ELSB_MASK;
/* Set Channel Value */
  FTM0->CONTROLS[0].CnV=FTM_CnV_VAL(1200); // 50% FTM0->CONTROLS[4].CnV=FTM_CnV_VAL(600); // 25%
   /* FTM counter reset */
  FTMO -> CNT = 0;
  /* Select and enable clock */
  FTMO->SC |= FTM_SC_CLKS(1);
/* Enable hardware synchronization */
  FTMO->SYNCONF = FTM_SYNCONF_SYNCMODE_MASK | FTM_SYNCONF_HWWRBUF_MASK;
  /* Enable FTM counter reset after hardware trigger */
  FTMO->SYNCONF |= FTM_SYNCONF_HWRSTCNT_MASK | FTM_SYNCONF_HWTRIGMODE_MASK;
  FTMO -> SYNC = FTM SYNC TRIG2 MASK;
   ^{\prime *} Enable PWM generation ^*
  FTMO->SC |= FTM SC PWMENO MASK | FTM SC PWMEN1 MASK | FTM SC PWMEN4 MASK | FTM SC PWMEN5 MASK;
void FTM1 CPWM SyncOut()
  /* Enable clock for PORTA */
  CLOCK EnableClock(kCLOCK PortA);
   ^{\prime} * Enable clock for FTM1 *,
  CLOCK EnableClock(kCLOCK Ftm1);
  /* Enable registers updating from write buffers */
  FTM1->MODE = FTM MODE WPDIS MASK | FTM MODE FTMEN MASK;
  /* Set PORT pins for FTM1 */
  PORTA->PCR[16] = PORT PCR MUX(2); // FTM1, Channel3
  FTM1->SC=FTM SC CPWMS MASK; // Select up-down counter for Center-Align PWM
  /* Set Modulo in initialization stage (2kHz PWM frequency @48MHz system clock) */
  FTM1->MOD = FTM MOD MOD(12000-1);
  /* Set CNTIN in initialization stage */
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x

```
FTM1->CNTIN = FTM CNTIN INIT(0);
  /* Enable high-true pulses of PWM signals */
FTM1->CONTROLS[3].CnsC = FTM_CnsC_MSB_MASK | FTM_CnsC_ELSB_MASK;
/* Set channel value in initialization stage */
  FTM1->CONTROLS[3].CnV=FTM CnV VAL(6000); // 50% duty cycle
  /* Reset counter */
  FTM1->CNT = 0;
  /* Select clock */
  FTM1->SC = FTM SC CLKS(1) | FTM SC PWMEN3_MASK | FTM_SC_RIE_MASK;
  FTM1->SYNC = FTM SYNC_CNTMAX_MASK;
  EnableIRQ(FTM1 Ovf Reload IRQn); // Enable interrupt
void FTM1 Ovf Reload IRQHandler()
  if(g_reload_flag)
   FTM0->CONTROLS[0].CnV=FTM_CnV_VAL(1200); // 50%
   FTMO->CONTROLS[4].CnV=FTM CnV VAL(600); // 25%
  else
   FTM0->CONTROLS[0].CnV=FTM_CnV_VAL(600); // 25%
FTM0->CONTROLS[4].CnV=FTM_CnV_VAL(1200); // 50%
  ,
g_reload_flag = !g_reload flag;
FTM1->SC &= ~FTM_SC_RF_MASK; // Clear Reload Flag bit
```

Figure 15 shows the resulting behavior of the code example.



Figure 15 shows the hardware synchronization of CPWM signal output.

- The scope channels CH1, CH2, and CH3 represent the FTM0 module channels FTM0\_CH0, FTM0\_CH1, and FTM0\_CH4, respectively. Channel CH4 shows the hardware trigger generated from FTM1\_CH3.
- FTM0 CH0 and FTM0 CH1 work in the complementary mode, same as FTM0 CH4 and FTM0 CH5.
- After receiving the first hardware trigger, the duty cycles of the channel pair FTM0\_CH0/FTM0\_CH1 and the channel pair FTM0\_CH4/FTM0\_CH5 change from 25 % to 50 % and from 50 % to 25 %, respectively.

#### Features and Operation Modes of FlexTimer Module on MCX E24x

The next hardware trigger updates the new values of the COV and C4V registers and the duty cycle of the corresponding channel pair changes back to the previous value.

#### 4.4 Updating FTM registers

There are multiple FTMs on the chip, but the multiple FTM modules are independent. If the application requires more PWM channels than what one FTM can provide, multiple FTM modules can be used, but they must be synchronized. The synchronization of two (or more) FTM modules means that their counters have the same values at any instant time.

The MCX E24x device provides the GTB mechanism to synchronize multiple FTMs. The GTB is a synchronous signal generated by the master FTM that launches the counter of all FTMs used. These two conditions must be met when using the GTB function: each FTM must have the same clock source and each FTM must start at the same time.

To enable the GTB feature, perform these steps for each participating FTM module:

- 1. Stop the FTM counter (write 00b to SC[CLKS]).
- 2. Program the FTM to the intended configuration. The FTM counter mode must be consistent across all participating modules.
- 3. Write 1 to CONF[GTBEEN] and write 0 to CONF[GTBEOUT] at the same time.
- 4. Select the intended FTM counter clock source in SC[CLKS]. The clock source must be consistent across all participating modules.
- 5. Reset the FTM counter (write any value to the CNT register).

The following example shows the synchronization of two generating FMTs - FTM0 and FTM3. The duty cycles of both PWMs are adjusted to very low values to better demonstrate the functionality of the GTB mechanism.

```
void CPWM and Global Time Base()
   /* Enable clock for PORTD *
  CLOCK EnableClock (kCLOCK PortD);
   ^{\prime *} Enable clock for PORTB ^{*}.
  CLOCK EnableClock(kCLOCK PortB);
    ^{\star} Enable clock for FTM0
  CLOCK EnableClock (kCLOCK Ftm0);
    * Enable clock for FTM3
  CLOCK EnableClock(kCLOCK Ftm3);
    * Enable registers updating from write buffers *,
  FTMO->MODE = FTM MODE WPDIS MASK | FTM MODE FTMEN MASK;
  FTM3->MODE = FTM MODE WPDIS MASK | FTM MODE FTMEN MASK;
   /* Set PORT pins for FTM0 & FTM3 */
  PORTD->PCR[15] = PORT_PCR_MUX(2); // Set PTD15 for FTM0 - Channel0
PORTD->PCR[16] = PORT_PCR_MUX(2); // Set PTD16 for FTM0 - Channel1
PORTB->PCR[8] = PORT_PCR_MUX(2); // Set PTB8 for FTM3 - Channel0
PORTB->PCR[9] = PORT_PCR_MUX(2); // Set PTB9 for FTM3 - Channel1
     Select up-down counter for Center-Align PWM */
  FTMO->SC = FTM SC CPWMS MASK;
  FTM3->SC = FTM_SC_CPWMS_MASK;
/* Enable complementary mode for channels pair n=1 */
  FTM0->COMBINE = FTM_COMBINE_COMP0_MASK;
  FTM3->COMBINE = FTM COMBINE COMPO MASK;
  /* Set Modulo (10kHz PWM frequency @48MHz system clock) */
FTMO->MOD = FTM MOD MOD(2400-1);
  FTM3->MOD = FTM_MOD_MOD(2400-1);
  /* Set CNTIN */
  FTMO->CNTIN = FTM_CNTIN_INIT(0);
FTM3->CNTIN = FTM_CNTIN_INIT(0);
  /* High-true pulses of PWM signals */
  FTM0->CONTROLS[0].CnSC = FTM CnSC ELSB MASK;
  FTMO->CONTROLS[1].CnsC = FTM_CnsC_ELSB_MASK;
  FTM3->CONTROLS[0].CnsC = FTM_CnsC_ELSB_MASK;
FTM3->CONTROLS[1].CnsC = FTM_CnsC_ELSB_MASK;
  /* Set Channel Value - 1% duty cycle */
  FTM0->CONTROLS[0].CnV=FTM_CnV_VAL(24);
  FTM3->CONTROLS[0].CnV=FTM CnV VAL(24);
```

## Features and Operation Modes of FlexTimer Module on MCX E24x

```
/* FTM counter reset */
FTM0->CNT = 0;
FTM3->CNT = 0;
/* Enable global time base to control FTM0 and FTM3 */
FTM0->CONF = FTM_CONF_GTBEEN_MASK;
FTM3->CONF = FTM_CONF_GTBEEN_MASK;
/* Select clock */
FTM0->SC |= FTM_SC_CLKS(1);
FTM3->SC |= FTM_SC_CLKS(1);
/* Synchronization signal for FTM0 and FTM3 */
FTM0->CONF |= FTM_CONF_GTBEOUT_MASK;
/* Enable PWM generation */
FTM0->SC |= FTM_SC_PWMEN0_MASK | FTM_SC_PWMEN1_MASK;
FTM3->SC |= FTM_SC_PWMEN0_MASK | FTM_SC_PWMEN1_MASK;
```



Figure 16. CPWM with no GTB activated

#### Features and Operation Modes of FlexTimer Module on MCX E24x



Figure 16 and Figure 17 show the CPWM outputs of FTM0 and FTM3 with no GTB activated and with the GTB activated:

- The scope channels CH1, CH2, CH3, and CH4 represent the FTM0\_CH0, FTM0\_CH1, FTM3\_CH0, and FTM3\_CH1, respectively.
- FTM0 CH0 and FTM0 CH1 work in the complementary mode, same as FTM3 CH0 and FTM3 CH1.
- The time base of the scope is adjusted so that a 1 % duty cycle of channels FTM0 and FTM3 can be clearly seen on the scope display. If the global time base is not activated, the up-down counters of the FTMs used are not perfectly aligned to each other, neither are their channel signals (see Figure 16). Such a problem is handled by applying the GTB function to the FTM modules (see Figure 17).

**Note:** The GTB feature does not provide a continuous synchronization of the FTM counters, meaning that the FTM counters may lose the synchronization during the FTM operation. The GTB feature only enables the FTM counters to start their operation synchronously.

#### 4.5 ADC triggering by FTM and PDB modules

In motor-control applications and switched-mode power supply applications, it is necessary to measure the currents at the center of the PWM signal. The power devices do not switch at this instant time, so the voltage drop sensed on the shunt resistor is stable.

All FTM modules of the MCX E24x device have up to eight channels. Six channels are enough to generate the PWM signals necessary to control commonly used 3-phase motors. The remaining two channels of the FTM module can then be used to control the instant of the ADC conversions.

The triggering signal of the FTM module can be selected in the FTM\_EXTTRIG register. All FTM channels can be used to trigger the ADC module. For example, if CH0 is set in the FTM\_EXTTRIG register, the FTM counter counts until it reaches the value written in the COV register. Currently, CHO generates a signal that triggers the ADC module on every FTM counter period. If the INITTRIG bit is set in the FTM\_EXTTRIG register, the trigger signal is generated every time the FTM counter reaches the value of the CNTIN register.

The default and suggested hardware triggering scheme for the ADC module is through the Programmable Delay Block (PDB). The current implementation of the MCX E24x device is equipped with two ADC modules

#### Features and Operation Modes of FlexTimer Module on MCX E24x

and two PDB modules that work in pairs. This means that PDB0 is linked with ADC0 and PDB1 is linked with ADC1. Each PDB module can be triggered either by software or hardware. The FTM module is one of the trigger sources that can be enabled through the TRGMUX registers TRGMUX PDB0 and TRGMUX PDB1.

To generate the CPWM and to trigger ADC0 by FTM0 through PDB0, perform these steps:

- 1. Initialize the FTM0 module to generate the CPWM and enable the INITTRIGEN bit in the FTM0\_EXTTRIG register to generate a hardware trigger for the ADC0 module.
- 2. Configure the TRGMUX module to trigger ADC0 by FTM0 through the PDB0 module by writing  $0 \times 16$  to the SEL0 bit field in the TRGMUX PDB0 register.
- 3. Delay the FTM0 initialization trigger by the PDB0 block to trigger ADC0 at the center of the PWM cycle by writing appropriate values into the PDB0 MOD and PDB0 CH0DLY0 registers.
- 4. Initialize the ADC0 module and enable the ADTRG bit in the ADC0\_SC2 register to trigger ADC0 by the FTM0 module.

The following code example demonstrates the configuration of the FTM0, PDB0, and ADC0 modules, where FTM0 is used to generate the CPWM and to trigger ADC0 through the PDB0 module.

```
void FTMO Init For ADC Triggering()
  /* Enable clock for PORTD */
  CLOCK EnableClock(kCLOCK PortD);
  /* Enable clock for PORTB */
  CLOCK EnableClock(kCLOCK PortB);
  /* Enable clock for PORTC */
  CLOCK EnableClock (kCLOCK PortC);
  /* Enable clock for FTM0 */
  CLOCK EnableClock(kCLOCK Ftm0);
  /* Enable registers updating from write buffers */
  FTMO->MODE = FTM_MODE_WPDIS_MASK | FTM_MODE_FTMEN_MASK;
  PORTD->PCR[16] = PORT_PCR_MUX(2); // Set PTD16 for FTM0 - Channel1
PORTC->PCR[7] = PORT_PCR_MUX(1); // Set PTC7 as GPIO, ADC interrupt flag
PORTB->PCR[2] = PORT_PCR_MUX(1); // Set PTB2 as GPIO, PDB interrupt flag
  /* GPIO Initialize */
  gpio pin config t gpio config =
   kGPIO DigitalOutput,
   0
  GPIO_PinInit(GPIOC, 7, &gpio_config); // PTC7 init
GPIO_PinInit(GPIOB, 2, &gpio_config); // PTB2 init
  /* Select up-down counter for Center-Align PWM */
  FTM0->SC = FTM SC CPWMS MASK;
  /* Enable sync, complementary mode and dead-time for channels pair CHO/CH1 */
FTMO->COMBINE = FTM_COMBINE_SYNCENO_MASK | FTM_COMBINE_COMPO_MASK | FTM_COMBINE_DTENO_MASK;
  /* Set Modulo (10kHz PWM frequency @48MHz system clock) */
  FTMO->MOD = FTM MOD MOD(2400-1);
   * Set CNTIN */
  FTMO->CNTIN = FTM CNTIN INIT(0);
  /* High-true pulses of PWM signals */
FTM0->CONTROLS[0].CnSC = FTM_CnSC_ELSB_MASK;
FTM0->CONTROLS[1].CnSC = FTM_CnSC_ELSB_MASK;
  /* Set Channel Value */
  FTMO->CONTROLS[0].CnV=FTM CnV VAL(1200); // 50% duty cycle
  /* FTM counter reset */
  FTMO->CNT = 0;
     Insert deadtime (1us) */
  FTM0->DEADTIME = FTM DEADTIME_DTPS(3) |
  FTM_DEADTIME_DTVAL(3);
  /* Enable trigger generation when FTM counter = CNTIN */
  FTMO->EXTTRIG = FTM_EXTTRIG_INITTRIGEN_MASK;
  /* Enable clock and PWM *,
  FTM0->SC |= FTM SC CLKS(1) | FTM SC PWMEN0 MASK | FTM SC PWMEN1 MASK;
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x

```
void PDB0 Init For ADC Triggering()
   /* Enable clock for PDB0 */
  CLOCK EnableClock(kCLOCK Pdb0);
   /* Enable interrupt PDB0 */
  EnableIRQ(PDB0 IRQn);
  \label{eq:pdb0-mod} \begin{array}{ll} \mbox{PDB0->MOD} = 4800; \mbox{ // Set Modulo} \\ \mbox{PDB0->CH[0].C1} = \mbox{PDB}\mbox{ C1\_TOS(1)} \mbox{ | PDB\_C1\_EN(1); // Select and enable Channel0} \\ \end{array}
  PDBO->CH[0].DLY[0] = 2400; // Set delay
PDBO->IDLY = 0; // Set interrupt delay
  PDBO->SC |= PDB SC PRESCALER(0) | PDB SC MULT(0); // Select clock prescaler and mult factor
  /* Select trigger input source and enable interrupt */
PDBO->SC |= PDB_SC_TRGSEL(0) | PDB_SC_PDBIE_MASK;
/* Enable PDB and update PDB registers */
  PDB0->SC |= PDB_SC_PDBEN_MASK | PDB_SC_LDOK_MASK;
void TRGMUX_Init_For_ADC_Triggering()
   /* Set FTM as a trigger source for PDB0 */
  TRGMUX->TRGCFG[TRGMUX PDB0 INDEX] = TRGMUX TRGCFG SEL0(kTRGMUX SourceFtm0InitTrg);
void ADCO Init For ADC Triggering()
   /* Disable clock for ADC0 */
  CLOCK_DisableClock(kCLOCK_Adc0);
   /st Enable clock for ADC0 st/
  CLOCK_EnableClock(kCLOCK_Adc0);
   /* Set divide ratio to 1 and select 8-bit conversion */
  ADC0->CFG1 = ADC CFG1 ADIV(0) | ADC CFG1 MODE(0) | ADC CFG1 ADICLK(0);
   /* Select hardware trigger */
  ADC0->SC2 = ADC_SC2_ADTRG_MASK;
   /* Select channel 1\overline{2} as an input and enable conversion complete interrupt */
  ADCO->SC1[0] = ADC SC1 AIEN MASK | ADC SC1 ADCH(12);
   /* Enable interrupt for ADC\overline{0} */
  EnableIRQ(ADC0_IRQn);
void ADC0 IRQHandler()
  GPIO PortToggle (GPIOC, 1 << 7); // Toggle PTC7 to show ADC interrupt g_ADC_rseult = ADC0->R[0]; // Read ADC result register
void PDB0 IRQHandler()
  GPIO_PortToggle (GPIOB, 1 << 2); // Toggle PTB2 to show PDB interrupt PDBO->SC &= ~PDB_SC_PDBIF_MASK; // Clear PDB interrupt flag
}
```

#### Features and Operation Modes of FlexTimer Module on MCX E24x



Figure 18 shows the ADC triggering by FTM and PDB modules signal output:

- The scope channels CH1 and CH2 represent the FTM0 channels FTM0\_CH0 and FTM0\_CH1, respectively. The scope channels CH3 and CH4 demonstrate the interconnection between the FTM0, PDB0, and ADC0 modules. While channel CH3 represents the PTB2 pin toggling in the PDB0 interrupt routine every time the FTM0 counter reaches the value of the CNTIN register, channel CH4 displays the PTC7 pin toggling in the ADC0 interrupt routine every time the ADC0 conversion is completed (COCO = 1).
- The channel pair FTM0 CH0/FTM0 CH1 works in the complementary mode.
- The FTM0 trigger signal is delayed by the PDB0 module, so that the ADC0 conversion occurs at the center of the PWM signal.

Features and Operation Modes of FlexTimer Module on MCX E24x

#### 5 Note about the source code in the document

The example code shown in this document has the following copyright and BSD-3-Clause license:

Copyright 2025 NXP Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

- 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials must be provided with the distribution.
- 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

## 6 Revision history

Table 5 summarizes the revisions to this document.

Table 5. Revision history

| Document ID  | Release date | Description            |
|--------------|--------------|------------------------|
| AN14617 v1.0 | 15 July 2025 | Initial public release |

#### Features and Operation Modes of FlexTimer Module on MCX E24x

## **Legal information**

#### **Definitions**

**Draft** — A draft status on a document indicates that the content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included in a draft version of a document and shall have no liability for the consequences of use of such information.

#### **Disclaimers**

Limited warranty and liability — Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. NXP Semiconductors takes no responsibility for the content in this document if provided by an information source outside of NXP Semiconductors.

In no event shall NXP Semiconductors be liable for any indirect, incidental, punitive, special or consequential damages (including - without limitation - lost profits, lost savings, business interruption, costs related to the removal or replacement of any products or rework charges) whether or not such damages are based on tort (including negligence), warranty, breach of contract or any other legal theory.

Notwithstanding any damages that customer might incur for any reason whatsoever, NXP Semiconductors' aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the Terms and conditions of commercial sale of NXP Semiconductors.

Right to make changes — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof.

Suitability for use — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in life support, life-critical or safety-critical systems or equipment, nor in applications where failure or malfunction of an NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors and its suppliers accept no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk.

**Applications** — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer's sole responsibility to determine whether the NXP Semiconductors product is suitable and fit for the customer's applications and products planned, as well as for the planned application and use of customer's third party customer(s). Customers should provide appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP Semiconductors does not accept any liability related to any default, damage, costs or problem which is based on any weakness or default in the customer's applications or products, or the application or use by customer's third party customer(s). Customer is responsible for doing all necessary testing for the customer's applications and products using NXP Semiconductors products in order to avoid a default of the applications and the products or of the application or use by customer's third party customer(s). NXP does not accept any liability in this respect.

Terms and conditions of commercial sale — NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at https://www.nxp.com/profile/terms, unless otherwise agreed in a valid written individual agreement. In case an individual agreement is concluded only the terms and conditions of the respective agreement shall apply. NXP Semiconductors hereby expressly objects to applying the customer's general terms and conditions with regard to the purchase of NXP Semiconductors products by customer.

**Export control** — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from competent authorities.

Suitability for use in non-automotive qualified products — Unless this document expressly states that this specific NXP Semiconductors product is automotive qualified, the product is not suitable for automotive use. It is neither qualified nor tested in accordance with automotive testing or application requirements. NXP Semiconductors accepts no liability for inclusion and/or use of non-automotive qualified products in automotive equipment or applications.

In the event that customer uses the product for design-in and use in automotive applications to automotive specifications and standards, customer (a) shall use the product without NXP Semiconductors' warranty of the product for such automotive applications, use and specifications, and (b) whenever customer uses the product for automotive applications beyond NXP Semiconductors' specifications such use shall be solely at customer's own risk, and (c) customer fully indemnifies NXP Semiconductors for any liability, damages or failed product claims resulting from customer design and use of the product for automotive applications beyond NXP Semiconductors' standard warranty and NXP Semiconductors' product specifications.

**HTML publications** — An HTML version, if available, of this document is provided as a courtesy. Definitive information is contained in the applicable document in PDF format. If there is a discrepancy between the HTML document and the PDF document, the PDF document has priority.

**Translations** — A non-English (translated) version of a document, including the legal information in that document, is for reference only. The English version shall prevail in case of any discrepancy between the translated and English versions.

Security — Customer understands that all NXP products may be subject to unidentified vulnerabilities or may support established security standards or specifications with known limitations. Customer is responsible for the design and operation of its applications and products throughout their lifecycles to reduce the effect of these vulnerabilities on customer's applications and products. Customer's responsibility also extends to other open and/or proprietary technologies supported by NXP products for use in customer's applications. NXP accepts no liability for any vulnerability. Customer should regularly check security updates from NXP and follow up appropriately. Customer shall select products with security features that best meet rules, regulations, and standards of the intended application and make the ultimate design decisions regarding its products and is solely responsible for compliance with all legal, regulatory, and security related requirements concerning its products, regardless of any information or support that may be provided by NXP.

NXP has a Product Security Incident Response Team (PSIRT) (reachable at <a href="PSIRT@nxp.com">PSIRT@nxp.com</a>) that manages the investigation, reporting, and solution release to security vulnerabilities of NXP products.

 $\ensuremath{\mathsf{NXP}}\xspace \ensuremath{\mathsf{B.V.}}\xspace - \ensuremath{\mathsf{NXP}}\xspace \ensuremath{\mathsf{B.V.}}\xspace$  is not an operating company and it does not distribute or sell products.

#### **Trademarks**

Notice: All referenced brands, product names, service names, and trademarks are the property of their respective owners.

NXP — wordmark and logo are trademarks of NXP B.V.

Kinetis - is a trademark of NXP B.V.

AN14617

All information provided in this document is subject to legal disclaimers.

© 2025 NXP B.V. All rights reserved.

Features and Operation Modes of FlexTimer Module on MCX E24x

 $\mbox{\bf Microsoft}$  ,  $\mbox{\bf Azure}$  , and  $\mbox{\bf ThreadX}$  — are trademarks of the Microsoft group of companies.

## Features and Operation Modes of FlexTimer Module on MCX E24x

## **Contents**

| 1     | Introduction                                 | 2  |
|-------|----------------------------------------------|----|
| 2     | FTM overview                                 |    |
| 3     | FTM operation modes                          |    |
| 3.1   | EPWM mode                                    | 5  |
| 3.2   | CPWM mode                                    | 7  |
| 3.3   | Complementary mode and dead-time             |    |
|       | insertion                                    | 8  |
| 3.4   | Combine mode                                 | g  |
| 3.5   | Single-edge capture mode                     |    |
| 3.6   | Dual-edge capture mode                       | 13 |
| 3.7   | Quadrature decoder mode                      | 15 |
| 4     | FTM features                                 | 17 |
| 4.1   | Masking, inverting, and software-controlling |    |
|       | features                                     |    |
| 4.2   | Fault control feature                        | 17 |
| 4.3   | Updating FTM registers                       | 20 |
| 4.3.1 | Updating FTM registers in initialization     |    |
|       | stage                                        | 21 |
| 4.3.2 | Half- and full-cycle reload strategies       | 21 |
| 4.3.3 | Updating FTM registers by software trigger   |    |
|       | - Software synchronization                   | 24 |
| 4.3.4 | Updating FTM registers by hardware trigger   |    |
|       | - Hardware synchronization                   | 26 |
| 4.4   | Updating FTM registers                       |    |
| 4.5   | ADC triggering by FTM and PDB modules        | 31 |
| 5     | Note about the source code in the            |    |
|       | document                                     | 35 |
| 6     | Revision history                             |    |
|       | Legal information                            | 36 |

Please be aware that important notices concerning this document and the product(s) described herein, have been included in section 'Legal information'.