

# AN4640 Application note

# Peripherals interconnections on STM32F405/7xx, STM32F415/7xx, STM32F42xxx, STM32F43xxx, STM32F446xx and STM32F469/479xx

### Introduction

This application note describes how peripherals of the microcontrollers listed in *Table 1* can communicate autonomously without any intervention from the CPU via a network known as Peripherals interconnect matrix.

This feature enhances the CPU real-time performance, while at the same time substantially reducing its power consumption.

The document begins with the description of the Peripherals interconnect matrix features, then it provides an overview of the peripherals configuration and their interconnections. An example is presented and described in detail.

This application note has to be read in conjunction with reference manuals RM0090, RM0386 and RM0390, all available at www.st.com/stm32.

| Туре             | Product lines |
|------------------|---------------|
|                  | STM32F405/415 |
|                  | STM32F407/417 |
| Microcontrolloro | STM32F427/437 |
| Microcontrollers | STM32F429/439 |
|                  | STM32F446     |
|                  | STM32F469/479 |

#### Table 1. Applicable devices

# Contents

| 1 | Mod  | ule ove   | rview                                |
|---|------|-----------|--------------------------------------|
| 2 | Peri | pherals   | interconnect matrix                  |
|   | 2.1  | Timers    | s block                              |
|   |      | 2.1.1     | From TIM to TIM9                     |
|   |      | 2.1.2     | From TIM to ADC                      |
|   |      | 2.1.3     | From TIM to DAC                      |
|   |      | 2.1.4     | From TIM to DMA                      |
|   | 2.2  | Analog    | g block                              |
|   |      | 2.2.1     | From ADC to ADC                      |
|   |      | 2.2.2     | From Temperature sensor to ADC1 11   |
|   |      | 2.2.3     | From Analog block to DMA 11          |
|   | 2.3  | Clocks    | s block                              |
|   |      | 2.3.1     | From CSS to TIM                      |
|   |      | 2.3.2     | From LSE, LSI, RTC to TIM 11         |
|   | 2.4  | Syster    | n block                              |
|   |      | 2.4.1     | From VBAT, VREFIN to ADC             |
|   |      | 2.4.2     | From EXTI to Analog block            |
|   | 2.5  | Comm      | nunication interfaces block 12       |
|   |      | 2.5.1     | From SPDIFRX to TIM                  |
|   |      | 2.5.2     | From USB block to TIM                |
|   |      | 2.5.3     | From ETH block to TIM                |
|   |      | 2.5.4     | From Communication interfaces to DMA |
|   | 2.6  | DMA k     | block                                |
| 3 | Арр  | lication  | example                              |
|   | 3.1  | Hardw     | are description                      |
|   | 3.2  | Softwa    | are description                      |
| 4 | Con  | clusion   |                                      |
| 5 | Revi | ision his | story                                |



# List of tables

| Table 1. | Applicable devices                                                    | 1 |
|----------|-----------------------------------------------------------------------|---|
| Table 2. | Peripherals interconnect matrix for products listed in <i>Table 1</i> | 7 |
| Table 3. | Peripherals interconnect configuration detail                         | 3 |
| Table 4. | Document revision history                                             | 3 |



# List of figures

| 0         | Interconnection of STM32F405/7xx, STM32F415/7xx, STM32F42xxx, STM32F43xxx, STM32F446xxand STM32F469/479xx peripherals |
|-----------|-----------------------------------------------------------------------------------------------------------------------|
| Figure 2. | Master / Slave timer overview                                                                                         |
| Figure 3. | Master TIM / Slave ADC overview                                                                                       |
| Figure 4. | Master TIM / Slave DAC overview                                                                                       |
| Figure 5. | SOF connectivity                                                                                                      |
| Figure 6. | PTP trigger output to TIM2 ITR1 connection                                                                            |
| Figure 7. | Application overview                                                                                                  |



# 1 Module overview

Several peripherals can have direct connections between them, as a matter of fact they can be configured to send or respond to event signals that can be internally routed, directly with other peripherals in the device.

The STM32F4 autonomous peripherals include:

- Timers: can be internally connected to each other, or can be connected to DMA and to the Analog block.
- Analog block: can receive event from timers or can generate event to DMA.
- Clocks: can produce event to Timers.
- System block: can send event to Analog block.
- Communication interfaces block: can generate event to timers or to DMA.



An overview of peripheral interconnections for STM32F4 is shown in Figure 1.



# 2 Peripherals interconnect matrix

Peripherals in STM32F4 are interconnected by a network named Peripherals interconnect matrix, that makes it possible to directly connect one peripheral to another without waking up the CPU. Depending on peripherals, these interconnections can operate in Run, Sleep and Stop modes.

Peripherals that respond to events are called Users, those that send events are called Generators. Both types are listed in *Table 2*.

|        |          |     | Users |        |      |      |      |      |      |       |       |      |      |        |     |   |     |   |  |
|--------|----------|-----|-------|--------|------|------|------|------|------|-------|-------|------|------|--------|-----|---|-----|---|--|
|        |          |     |       | Timers |      |      |      |      |      |       |       |      |      | Analog |     |   |     |   |  |
|        | Generat  | ore | TIM1  | TIM2   | TIM3 | TIM4 | TIM5 | TIM8 | TIM9 | TIM11 | TIM12 | DMA1 | DMA2 |        | ADC |   | DAC |   |  |
|        | senerati | 015 | ТІ    | ΤII    | ΤII  | ΤII  | TII  | ΤII  | ΤII  | TIN   | ΠT    | MD   | ΜQ   | 1      | 2   | 3 | 1   | 2 |  |
|        | TII      | M1  | -     | Х      | Х    | Х    | -    | Х    | -    | -     | -     | -    | Х    | Х      | Х   | Х | -   | - |  |
|        | TII      | M2  | Х     | -      | Х    | Х    | Х    | Х    | Х    | -     | -     | Х    | -    | Х      | Х   | Х | Х   | Х |  |
|        | TII      | М3  | Х     | Х      | -    | Х    | Х    | -    | Х    | -     | -     | Х    | -    | Х      | Х   | Х | -   | - |  |
|        | TII      | M4  | Х     | Х      | Х    | -    | Х    | Х    | -    | I     | Х     | Х    | -    | Х      | Х   | Х | Х   | Х |  |
|        | TII      | M5  | Х     | -      | Х    | -    | -    | Х    | -    | I     | Х     | Х    | 1    | Х      | Х   | Х | Х   | Х |  |
| Timers | S TIM    | M6  | -     | -      | -    | -    | -    | -    | -    | I     | -     | Х    | -    | -      | -   | - | Х   | Х |  |
| Tim    | TII      | M7  | -     | -      | -    | -    | -    | -    | -    | I     | -     | Х    | 1    | -      | -   | - | Х   | Х |  |
|        | ТІІ      | M8  | -     | Х      | -    | Х    | Х    | -    | -    | -     | -     | -    | Х    | Х      | Х   | Х | Х   | Х |  |
|        | TIN      | 110 | -     | -      | -    | -    | -    | -    | Х    | -     | -     | -    | -    | -      | -   | - | -   | - |  |
|        | TIN      | /11 | -     | -      | -    | -    | -    | -    | Х    | -     | -     | -    | -    | -      | -   | - | -   | - |  |
|        | TIN      | 113 | -     | -      | -    | -    | -    | -    | -    | -     | Х     | -    | -    | -      | -   | - | -   | - |  |
|        | TIN      | 114 | -     | -      | -    | -    | -    | -    | -    | -     | Х     | -    | -    | -      | -   | - | -   | - |  |
|        |          | 1   | -     | -      | -    | -    | -    | Х    | -    | -     | -     | -    | Х    | -      | Х   | Х | -   | - |  |
|        | ADC      | 2   | -     | -      | -    | -    | -    | -    | -    | -     | -     | -    | Х    | -      | -   | - | -   | - |  |
| Analog |          | 3   | -     | -      | -    | -    | -    | -    | -    | -     | -     | -    | Х    | -      | -   | - | -   | - |  |
| Aná    | DAC      | 1   | -     | -      | -    | -    | -    | -    | -    | -     | -     | Х    | -    | -      | -   | - | -   | - |  |
|        | DAG      | 2   | -     | -      | -    | -    | -    | -    | -    | -     | -     | Х    | -    | -      | -   | - | -   | - |  |
|        | VSE      | NSE | -     | -      | -    | -    | -    | -    | -    | -     | -     | -    | -    | Х      | -   | - | -   | - |  |
|        | L        | SI  | -     | -      | -    | -    | Х    | -    | -    | -     | -     | -    | -    | -      | -   | - | -   | - |  |
| Clocks | LS       | SE  | -     | -      | -    | -    | Х    | -    | -    | -     | -     | -    | -    | -      | -   | - | -   | - |  |
| Clo    | R        | ГС  | -     | -      | -    | -    | Х    | -    | -    | Х     | -     | -    | -    | -      | -   | - | -   | - |  |
|        | CS       | SS  | Х     | -      | -    | -    | -    | Х    | -    | -     | -     | -    | -    | -      | -   | - | -   | - |  |

 Table 2. Peripherals interconnect matrix for products listed in Table 1



|                          |                        | Users               |      |      |      |      |      |             |       |       |      |      |        |     |   |   |   |  |
|--------------------------|------------------------|---------------------|------|------|------|------|------|-------------|-------|-------|------|------|--------|-----|---|---|---|--|
|                          |                        | Timers              |      |      |      |      |      |             |       |       |      | ΛA   | Analog |     |   |   |   |  |
|                          | Generators             | 2 7 7 0 8 2 7 3 2 7 |      |      |      |      |      |             |       | A1    | A2   |      | ADC    | DAC |   |   |   |  |
|                          | benerators             | TIM1                | TIM2 | TIM3 | TIM4 | TIM5 | TIM8 | <b>EMIT</b> | TIM11 | TIM12 | DMA1 | DMA2 | 1      | 2   | 3 | 1 | 2 |  |
|                          | OTG FS                 | -                   | Х    | -    | -    | -    | -    | -           | -     | -     | -    | -    | -      | -   | - | - | - |  |
|                          | OTG HS                 | -                   | Х    | -    | -    | -    | -    | -           | -     | -     | -    | -    | -      | -   | - | - | - |  |
|                          | SPI1                   | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
|                          | SPI2                   | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
|                          | SPI3                   | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
|                          | SPI4 <sup>(1)</sup>    | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
|                          | SPI5 <sup>(2)</sup>    | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
|                          | SPI6 <sup>(2)</sup>    | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
|                          | CRYP <sup>(3)</sup>    | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
|                          | HASH <sup>(3)</sup>    | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
|                          | ETH <sup>(3)</sup>     | -                   | Х    | -    | -    | -    | -    | -           | -     | -     | -    | -    | -      | -   | - | - | - |  |
|                          | SPDIFRX <sup>(4)</sup> | -                   | -    | -    | -    | -    | -    | -           | Х     | -     | Х    | -    | -      | -   | - | - | - |  |
| ses                      | QSPI <sup>(5)</sup>    | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
| erfac                    | I2C1                   | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
| inte                     | I2C2                   | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
| tion                     | I2C3                   | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
| nica                     | I2CFMP <sup>(4)</sup>  | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
| Communication interfaces | I2S2 <sup>(3)</sup>    | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
| Con                      | I2S3 <sup>(3)</sup>    | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
|                          | SAI1 <sup>(1)</sup>    | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
|                          | SAI2 <sup>(4)</sup>    | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
|                          | USART1                 | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
|                          | USART2                 | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
|                          | USART3                 | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
|                          | USART6                 | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
|                          | UART4                  | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
|                          | UART5                  | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
|                          | UART7 <sup>(2)</sup>   | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
|                          | UART8 <sup>(2)</sup>   | -                   | -    | -    | -    | -    | -    | -           | -     | -     | Х    | -    | -      | -   | - | - | - |  |
|                          | DCMI                   | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | х    | -      | -   | - | - | - |  |
|                          | SDIO                   | -                   | -    | -    | -    | -    | -    | -           | -     | -     | -    | Х    | -      | -   | - | - | - |  |
|                          |                        |                     |      |      |      |      |      |             |       |       |      |      |        |     |   |   |   |  |

#### Table 2. Peripherals interconnect matrix for products listed in Table 1 (continued)



| Users  |            |   |    |    |    |    |        |                                |   |      |     |    |   |     |   |   |   |
|--------|------------|---|----|----|----|----|--------|--------------------------------|---|------|-----|----|---|-----|---|---|---|
|        | Timers DMA |   |    |    |    |    | Analog |                                |   |      |     |    |   |     |   |   |   |
|        | Generators |   | И2 | M3 | М4 | M5 | M8     | TIM9<br>TIM11<br>TIM12<br>DMA1 |   | DMA2 | ADC |    |   | DAC |   |   |   |
|        |            |   | Ē  | μ  | F  | Ē  | ₽      | F                              | Ĩ | ₽    | DN  | DN | 1 | 2   | 3 | 1 | 2 |
| ε      | VBAT       | - | -  | -  | -  | -  | -      | -                              | - | -    | -   | -  | Х | -   | - | - | - |
| System | VREFIN     | - | -  | -  | -  | -  | -      | -                              | - | -    | -   | -  | Х | -   | - | - | - |
| Ś      | EXTI       | - | -  | -  | -  | -  | -      | -                              | - | -    | -   | -  | Х | Х   | Х | Х | Х |

 Table 2. Peripherals interconnect matrix for products listed in Table 1 (continued)

1. Only in STM32F42xxx, STM32F43xxx, STM32F446xx and STM32F469/479xx.

 $\mbox{2. Only in STM32F42xxx. STM32F43xxx and STM32F469/479xx. } \label{eq:stm32F469}$ 

3. Not in STM32F446xx.

- 4. Only in STM32F446xx.
- 5. Only in STM32F446xx and STM32F469/479xx.

### 2.1 Timers block

#### 2.1.1 From TIM to TIM

Some of the timers are linked together internally for synchronization or chaining. When one timer is configured in Master mode, it can reset, start, stop or clock the counter of another timer configured in Slave mode.

A description of this feature is provided in the "Timer synchronization" section of RM0090, RM0386 and RM0390 reference manuals, while all the possible master/slave connections are described in the "TIMx internal trigger connection" tables of the same documents.

The output (from Master) is on signal TIMx\_TRGO following a configurable timer event. The input (to slave) is on signals TIMx\_ITR0/ITR1/ITR2/ITR3.

*Figure 2* is an overview of the trigger selection and the Master mode selection blocks.



Figure 2. Master / Slave timer overview



As shown in *Figure 3*, some timers can be used to generate an ADC triggering event. The output (from timer) is on signal TIMx\_TRGO or TIMx\_CHx event.

Figure 3. Master TIM / Slave ADC overview

The input (to ADC) is on signal EXTSEL [3:0], JEXTSEL [3:0].



ADC synchronization is described in the "Conversion on external trigger and trigger polarity" section of RM0090, RM0386 and RM0390 reference manuals. The connection between timers and ADCs regular and injected channels is described in the "External trigger for regular channels" and "External trigger for injected channels tables" of the same documents.

#### 2.1.3 From TIM to DAC

Some timers can be used as triggering event to start a DAC conversion (see *Figure 4*).

The output (from timer) is on signal TIMx\_TRGO directly connected to corresponding DAC Inputs.

The selection of the input on DAC is provided in the "DAC trigger selection" section of the RM0090, RM0386 and RM0390 reference manuals.



#### Figure 4. Master TIM / Slave DAC overview

#### 2.1.4 From TIM to DMA

Refer to Section 2.6: DMA block.

DocID027335 Rev 3



### 2.2 Analog block

Analog block includes:

- ADC block: three ADCs;
- DAC block: two DAC converters;
- Temperature sensor Block.

#### 2.2.1 From ADC to ADC

In multi ADC mode, the start of conversion is triggered alternately or simultaneously by the ADC1 master to the ADC2 and ADC3 slaves, depending on the mode selected by the MULTI[4:0] bits in the ADC\_CCR register.

This feature is explained in the "Multi ADC mode" section of RM0090, RM0386 and RM0390 reference manuals.

#### 2.2.2 From Temperature sensor to ADC1

On STM32F4xx devices, the temperature sensor is internally connected to the input channel, either ADC1\_IN16 or ADC1\_IN18 can be used to convert the sensor output voltage into a digital value.

The section "Temperature sensor" in the RM0090, RM0386 and RM0390 reference manuals describes the connection between the sensor and the ADC and the procedure to apply in order to read the converted value.

#### 2.2.3 From Analog block to DMA

Refer to Section 2.6: DMA block.

# 2.3 Clocks block

System block includes:

- LSE clock;
- LSI clock;
- Clock security system (CSS);
- Real-time clock (RTC).

#### 2.3.1 From CSS to TIM

CSS can generate system errors in the form of timer break toward timers.

The purpose of the break function is to protect power switches driven by PWM signals generated by the timers.

The list of possible break sources is given in the "Using the break function (TIM1/TIM8)" section of the RM0090, RM0386 and RM0390 reference manuals.

#### 2.3.2 From LSE, LSI, RTC to TIM

External clock (LSE), internal clock (LSI) and RTC wakeup interrupt can be used as input to general-purpose timer (TIM5 channel 4/TIM11 channel 1).



This feature is described in the following sections of the RM0090, RM0386 and RM0390 reference manuals:

- "Internal/external clock measurement using TIM5/TIM11";
- "TIM5 option register (TIM5\_OR)";
- "TIM11 option register 1 (TIM11\_OR)".

### 2.4 System block

Power supplies block includes:

- The internal reference voltage VREFINT;
- VBAT;
- External interrupt/event controller (EXTI).

#### 2.4.1 From VBAT, VREFIN to ADC

The VBAT channel is connected to channel ADC1\_IN18. It can be converted as an injected or regular channel.

The VREFINT is connected to ADC1\_IN17.

Refer to the following sections of the RM0090, RM0386 and RM0390 reference manuals for a description of the interconnection between VBAT, VREFINT and ADC:

- "Channel selection";
- "Battery charge monitoring".

#### 2.4.2 From EXTI to Analog block

EXTI can be used to generate an ADC triggering event or to start a DAC conversion.

ADC synchronization is described in the "Conversion on external trigger and trigger polarity" section of the RM0090, RM0386 and RM0390 reference manuals, while selection of input triggers on DAC is provided in the "DAC trigger selection" section of the same documents.

# 2.5 Communication interfaces block

#### 2.5.1 From SPDIFRX to TIM

SPDIFRX (SPDIFRX\_FRAME\_SYNC) is connected to TIM11\_CH1 to measure the clock drift of received SPDIFRX frames.

This interconnection is explained in the section "TIM11 option register 1 (TIM11\_OR)" of the RM0390 reference manual.

#### 2.5.2 From USB block to TIM

USB block includes:

- USB on-the-go full-speed (OTG\_FS);
- USB on-the-go high-speed (OTG\_HS).



USB (OTG\_FS SOF) and USB (OTG HS SOF) can generate a trigger to general-purpose timer (TIM2), as shown in *Figure 5*.





The interconnection between USB and TIM2 is described in the "SOF trigger" section of RM0090, RM0386 and RM0390 reference manuals.

#### 2.5.3 From ETH block to TIM

The MAC can generate a trigger to general-purpose timer (TIM2).

This PTP trigger signal is connected to the TIM2 ITR1 input selectable by software. The connection is enabled through bits 11 and 10 in the TIM2 option register (TIM2\_OR).

#### Figure 6. PTP trigger output to TIM2 ITR1 connection



Connection of ETH to TIM2 is described in the section "Precision time protocol (IEEE1588 PTP)" of the RM0090 and RM0386 reference manuals.

#### 2.5.4 From Communication interfaces to DMA

Refer to Section 2.6: DMA block.

#### 2.6 DMA block

Each stream is associated with a DMA request that can be selected out of 8 possible channel requests. The selection is controlled by the CHSEL[2:0] bits in the DMA\_SxCR



register. The 8 requests from the peripherals (TIM, ADC, SPI, I2C, etc.) are independently connected to each channel and their connection depends on the product implementation.

This interconnection is explained in the following tables of RM0090, RM0386 and RM0390 reference manuals:

- "DMA1 request mapping";
- "DMA2 request mapping".



# 3 Application example

The example described in this section will demonstrate how to use the peripherals interconnect matrix on STM32F4 microcontrollers, namely how to set up ADC1 to start single conversions every time TIM 8 overflows. Each time an end of conversion occurs the DMA transfers the converted data from the ADC to memory.

This application uses the STM32F4xx HAL API.

# 3.1 Hardware description

Please refer to *Figure 7*, where the same color scheme of *Figure 1* has been used:

- TIM 8 peripheral: used to generate an ADC triggering event;
- ADC1 peripheral: used in Slave mode;
- DMA peripheral: used to transmit data from the slave ADC to the memory.



Figure 7. Application overview

# 3.2 Software description

The ADC1 is configured to convert TIM8 capture compare event ADC channel1. Each time an end of conversion occurs, the DMA transfers, in normal mode, the converted data from ADC1 DR register to the *aDST\_Buffer[]* table.

/\* Enables ADC DMA request after last transfer and enables ADC peripheral\*/
HAL\_ADC\_Start\_DMA (&hadc1,(uint32\_t\*)&aDST\_Buffer[0], BUFFER\_SIZE);

In this example, the system clock is 180 MHz, APB2 = 90 MHz and ADC clock = APB2/2. Since ADC1 clock is 45 MHz and sampling time is set to 3 cycles, the conversion time to 12 bit data is 12 cycles so the total conversion time is  $(12 + 3) / 45 = 0.33 \mu s$ .



The detail for related code is provided in *Table 3*.

#### Table 3. Peripherals interconnect configuration detail

| Interconnect                          | Code example                                                                                                                                                                                                                                                    | Comments                                                                                                                                                                                               |
|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TIM8_TRGO<br>selection                | <pre>sMasterConfig.MasterOutputTrigger=TIM_TRGO_UPDATE;<br/>sMasterConfig.MasterSlaveMode=TIM_MASTERSLAVEMODE_DISABLE;<br/>sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;<br/>HAL_TIMEx_MasterConfigSynchronization(&amp;htim8, &amp;sMasterConfig);</pre> | Configures the Master TIM to generate<br>a triggering event<br>(TIM_TRGO_UPDATE).                                                                                                                      |
| ADC1<br>external<br>trigger<br>source | <pre>hadc1.Init.ExternalTrigConvEdge=ADC_EXTERNALTRIGCONVEDGE_RISING;<br/>hadc1.Init.ExternalTrigConv = ADC_EXTERNALTRIGCONV_T8_TRGO;<br/>hadc1.Init.DMAContinuousRequests = ENABLE;<br/>hadc1.Init.EOCSelection = ENABLE;<br/>HAL_ADC_Init(&amp;hadc1);</pre>  | The TIM8_TRGO event triggers<br>conversion for the regular group with<br>rising edge.<br>Since converted regular channel<br>values are stored into a unique data<br>register, the DMA mode is enabled. |
| DMA handle                            | HAL_LINKDMA(hadc, DMA_Handle, hdma_adc);                                                                                                                                                                                                                        | Associates the initialized DMA handle to the ADC handle.                                                                                                                                               |

# 4 Conclusion

In this application note a useful complement to datasheets and reference manuals has been described by introducing the Peripherals interconnect matrix.

A basic use case has been presented and described in detail.

Users can start from it when developing their own solutions based on microcontrollers of the STM32F405/415, STM32F407/417, STM32F427/437, STM32F429/439, STM32F446 and STM32F469/479 lines.



# 5 Revision history

| Date        | Revision | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03-Feb-2015 | 1        | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 19-Mar-2015 | 2        | Changed document classification from ST Restricted to Public.<br>Updated title of <i>Table 2</i> and caption of <i>Figure 1</i> .<br>Updated references to RM0090 and RM0390 reference manuals in:<br>- Section 2.1.1: From TIM to TIM;<br>- Section 2.1.2: From TIM to ADC;<br>- Section 2.1.3: From TIM to DAC;<br>- Section 2.2.1: From ADC to ADC;<br>- Section 2.2.2: From Temperature sensor to ADC1;<br>- Section 2.3.1: From CSS to TIM;<br>- Section 2.3.2: From LSE, LSI, RTC to TIM;<br>- Section 2.4.1: From VBAT, VREFIN to ADC;<br>- Section 2.4.2: From EXTI to Analog block;<br>- Section 2.5.1: From SPDIFRX to TIM;<br>- Section 2.5.3: From ETH block to TIM;<br>- Section 2.5.3: From ETH block to TIM;<br>- Section 2.6: DMA block. |
| 17-Aug-2015 | 3        | <ul> <li>Added product lines STM32F469/479, hence updated:</li> <li><i>Introduction</i> and <i>Table 1</i> on cover page;</li> <li><i>Figure 1, Table 2</i> and its footnotes.</li> <li>Added reference to RM0386 reference manual in Sections 2.1.1, 2.1.2, 2.1.3, 2.2.1, 2.2.2, 2.3.1, 2.3.2 2.4.1, 2.4.2, 2.5.2, 2.5.3 and 2.6.</li> <li>Updated Section 2.5.1: From SPDIFRX to TIM.</li> </ul>                                                                                                                                                                                                                                                                                                                                                       |

#### Table 4. Document revision history



#### IMPORTANT NOTICE - PLEASE READ CAREFULLY

STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgement.

Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers' products.

No license, express or implied, to any intellectual property right is granted by ST herein.

Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product.

ST and the ST logo are trademarks of ST. All other product or service names are the property of their respective owners.

Information in this document supersedes and replaces information previously supplied in any prior versions of this document.

© 2015 STMicroelectronics – All rights reserved

