

### 8.15.3 Limitations

The previous compare value is repeated if the PWM period is shorter than the time it takes for the EasyDMA to retrieve from RAM and update the internal compare registers. This is to ensure a glitch-free operation even for very short PWM periods.

Only SEQ[1] can trigger the [LOOPSDONE](#) event upon completion, not SEQ[0]. This requires looping to be enabled ([LOOP > 0](#)) and SEQ[1].MAXCNT > 0 when sequence playback starts.

### 8.15.4 Pin configuration

The OUT[n] (n=0..3) signals associated with each PWM channel are mapped to physical pins according to the configuration of PSEL.OUT[n] registers. If PSEL.OUT[n].CONNECT is set to Disconnected, the associated PWM module signal will not be connected to any physical pins.

Once PWM has been enabled, the PSEL.OUT[n] registers take effect and PWM generation starts from the IDLEOUT register. PWM can then be started and sequences generated.

To ensure correct behavior in the PWM module, the pins that are used must be configured in the GPIO peripheral in the following way before the PWM module is enabled:

| PWM signal | PWM pin                              | Direction | Output value | Comment                                                          |
|------------|--------------------------------------|-----------|--------------|------------------------------------------------------------------|
| OUT[n]     | As specified in PSEL.OUT[n] (n=0..3) | Output    | 0            | Idle state defined in GPIO OUT register and the IDLEOUT register |

*Table 50: Recommended GPIO configuration before starting PWM generation*

The idle state of a pin is defined by the OUT register in the GPIO module and the IDLEOUT register, to ensure that the pins used by the PWM module are driven correctly. Both OUT register in the GPIO module and the IDLEOUT register should be set with same value for each PWM channel before enabling the PWM module . When PWM is disabled using the ENABLE register the PWM module stops controlling the GPIO pins, and the corresponding pins are then controlled by the GPIO peripheral.

Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior.

### 8.15.5 Registers

#### Instances

| Instance   | Domain | Base address | TrustZone |     |     | Split access | Description                 |
|------------|--------|--------------|-----------|-----|-----|--------------|-----------------------------|
|            |        |              | Map       | Att | DMA |              |                             |
| PWM20 : S  | GLOBAL | 0x500D2000   | US        | S   | SA  | No           | Pulse width modulation unit |
| PWM20 : NS |        | 0x400D2000   |           |     |     |              | PWM20                       |
| PWM21 : S  | GLOBAL | 0x500D3000   | US        | S   | SA  | No           | Pulse width modulation unit |
| PWM21 : NS |        | 0x400D3000   |           |     |     |              | PWM21                       |
| PWM22 : S  | GLOBAL | 0x500D4000   | US        | S   | SA  | No           | Pulse width modulation unit |
| PWM22 : NS |        | 0x400D4000   |           |     |     |              | PWM22                       |