# 1. Description

## 1.1. Project

| Project Name    | F429ZI_FreeRTOS_Template |
|-----------------|--------------------------|
| Board Name      | NUCLEO-F429ZI            |
| Generated with: | STM32CubeMX 5.1.0        |
| Date            | 04/18/2019               |

### 1.2. MCU

| MCU Series     | STM32F4       |
|----------------|---------------|
| MCU Line       | STM32F429/439 |
| MCU name       | STM32F429ZITx |
| MCU Package    | LQFP144       |
| MCU Pin number | 144           |

# 2. Pinout Configuration



# 3. Pins Configuration

| Pin Number | Pin Name               | Pin Type | Alternate   | Label                                        |
|------------|------------------------|----------|-------------|----------------------------------------------|
| LQFP144    | (function after reset) |          | Function(s) |                                              |
| 6          | VBAT                   | Power    |             |                                              |
| 7          | PC13                   | I/O      | GPIO_EXTI13 | USER_Btn [B1]                                |
| 16         | VSS                    | Power    |             |                                              |
| 17         | VDD                    | Power    |             |                                              |
| 25         | NRST                   | Reset    |             |                                              |
| 27         | PC1                    | I/O      | ETH_MDC     | RMII_MDC [LAN8742A-CZ-<br>TR_MDC]            |
| 30         | VDD                    | Power    |             |                                              |
| 31         | VSSA                   | Power    |             |                                              |
| 32         | VREF+                  | Power    |             |                                              |
| 33         | VDDA                   | Power    |             |                                              |
| 35         | PA1                    | I/O      | ETH_REF_CLK | RMII_REF_CLK<br>[LAN8742A-CZ-<br>TR_REFCLK0] |
| 36         | PA2                    | I/O      | ETH_MDIO    | RMII_MDIO [LAN8742A-CZ-<br>TR_MDIO]          |
| 38         | VSS                    | Power    |             |                                              |
| 39         | VDD                    | Power    |             |                                              |
| 43         | PA7                    | I/O      | ETH_CRS_DV  | RMII_CRS_DV [LAN8742A-<br>CZ-TR_CRS_DV]      |
| 44         | PC4                    | I/O      | ETH_RXD0    | RMII_RXD0 [LAN8742A-CZ-<br>TR_RXD0]          |
| 45         | PC5                    | I/O      | ETH_RXD1    | RMII_RXD1 [LAN8742A-CZ-<br>TR_RXD1]          |
| 46         | PB0 *                  | I/O      | ETH_RXD2    | ETH_RXD2                                     |
| 51         | VSS                    | Power    |             |                                              |
| 52         | VDD                    | Power    |             |                                              |
| 61         | VSS                    | Power    |             |                                              |
| 62         | VDD                    | Power    |             |                                              |
| 71         | VCAP_1                 | Power    |             |                                              |
| 72         | VDD                    | Power    |             |                                              |
| 74         | PB13                   | I/O      | ETH_TXD1    | RMII_TXD1 [LAN8742A-CZ-<br>TR_TXD1]          |
| 75         | PB14 **                | I/O      | GPIO_Output | LD3 [Red]                                    |
| 77         | PD8 *                  | I/O      | USART3_TX   | USART3_TX                                    |
| 78         | PD9 *                  | I/O      | USART3_RX   | USART3_RX                                    |
| 83         | VSS                    | Power    |             |                                              |

| Pin Number<br>LQFP144 | Pin Name<br>(function after<br>reset) | Pin Type | Alternate<br>Function(s) | Label                                |
|-----------------------|---------------------------------------|----------|--------------------------|--------------------------------------|
| 84                    | VDD                                   | Power    |                          |                                      |
| 94                    | VSS                                   | Power    |                          |                                      |
| 95                    | VDD                                   | Power    |                          |                                      |
| 105                   | PA13                                  | I/O      | SYS_JTMS-SWDIO           | TMS                                  |
| 106                   | VCAP_2                                | Power    |                          |                                      |
| 107                   | VSS                                   | Power    |                          |                                      |
| 108                   | VDD                                   | Power    |                          |                                      |
| 109                   | PA14                                  | I/O      | SYS_JTCK-SWCLK           | TCK                                  |
| 120                   | VSS                                   | Power    |                          |                                      |
| 121                   | VDD                                   | Power    |                          |                                      |
| 126                   | PG11                                  | I/O      | ETH_TX_EN                | RMII_TX_EN [LAN8742A-<br>CZ-TR_TXEN] |
| 128                   | PG13                                  | I/O      | ETH_TXD0                 | RMII_TXD0 [LAN8742A-CZ-<br>TR_TXD0]  |
| 130                   | VSS                                   | Power    |                          |                                      |
| 131                   | VDD                                   | Power    |                          |                                      |
| 137                   | PB7 **                                | I/O      | GPIO_Output              | LD2 [Blue]                           |
| 138                   | воото                                 | Boot     |                          |                                      |
| 143                   | PDR_ON                                | Reset    |                          |                                      |
| 144                   | VDD                                   | Power    |                          |                                      |

<sup>\*\*</sup> The pin is affected with an I/O function

<sup>\*</sup> The pin is affected with a peripheral function but no peripheral mode is activated

# 4. Clock Tree Configuration



# 5. Software Project

## 5.1. Project Settings

| Name                              | Value                                                     |  |
|-----------------------------------|-----------------------------------------------------------|--|
| Project Name                      | F429ZI_FreeRTOS_Template                                  |  |
| Project Folder                    | /home/ladeveze/workspace/sandbox/campus-numerique/nucelo- |  |
| Toolchain / IDE                   | TrueSTUDIO                                                |  |
| Firmware Package Name and Version | STM32Cube FW_F4 V1.24.0                                   |  |

## 5.2. Code Generation Settings

| Name                                                          | Value                                 |
|---------------------------------------------------------------|---------------------------------------|
| STM32Cube Firmware Library Package                            | Copy only the necessary library files |
| Generate peripheral initialization as a pair of '.c/.h' files | Yes                                   |
| Backup previously generated files when re-generating          | No                                    |
| Delete previously generated files when not re-generated       | Yes                                   |
| Set all free pins as analog (to optimize the power            | No                                    |
| consumption)                                                  |                                       |

# 6. Power Consumption Calculator report

#### 6.1. Microcontroller Selection

| Series    | STM32F4       |
|-----------|---------------|
| Line      | STM32F429/439 |
| MCU       | STM32F429ZITx |
| Datasheet | 024030_Rev9   |

#### 6.2. Parameter Selection

| Temperature | 25  |
|-------------|-----|
| Vdd         | 3.6 |

# 7. IPs and Middleware Configuration 7.1. ETH

Mode: RMII

#### 7.1.1. Parameter Settings:

**Advanced : Ethernet Media Configuration:** 

Auto Negotiation Enabled

**General: Ethernet Configuration:** 

Ethernet MAC Address 00:80:E1:00:00:00

PHY Address 0 \*

**Ethernet Basic Configuration:** 

Rx Mode Polling Mode
TX IP Header Checksum Computation By hardware

#### 7.1.2. Advanced Parameters:

#### **External PHY Configuration:**

PHY LAN8742A\_PHY\_ADDRESS

PHY Address Value

PHY Reset delay these values are based on a 1 ms

Systick interrupt

0x00000FF \*

PHY Configuration delay

PHY Read TimeOut

Ox0000FFF \*

PHY Write TimeOut

Ox0000FFF \*

**Common: External PHY Configuration:** 

Transceiver Basic Control Register 0x00 \* Transceiver Basic Status Register 0x01 \* **PHY Reset** 0x8000 \* Select loop-back mode 0x4000 \* Set the full-duplex mode at 100 Mb/s 0x2100 \* Set the half-duplex mode at 100 Mb/s 0x2000 \* Set the full-duplex mode at 10 Mb/s 0x0100 \* Set the half-duplex mode at 10 Mb/s 0x0000 \* Enable auto-negotiation function 0x1000 \* Restart auto-negotiation function 0x0200 \* Select the power down mode 0x0800 \* Isolate PHY from MII 0x0400 \*

Auto-Negotiation process completed 0x0020 \*

Valid link established 0x0004 \*

Jabber condition detected 0x0002 \*

#### **Extended: External PHY Configuration:**

PHY special control/status register Offset

Ox1F \*

PHY Speed mask

Ox0004 \*

PHY Duplex mask

Ox0010 \*

PHY Interrupt Source Flag register Offset

Ox001D \*

PHY Link down inturrupt

Ox000B \*

#### 7.2. GFXSIMULATOR

#### 7.2.1. Simulator Graphic:

#### 7.3. RCC

#### 7.3.1. Parameter Settings:

#### **System Parameters:**

VDD voltage (V) 3.3
Instruction Cache Enabled
Prefetch Buffer Enabled
Data Cache Enabled

Flash Latency(WS) 1 WS (2 CPU cycle)

#### **RCC Parameters:**

HSI Calibration Value 16

TIM Prescaler Selection Disabled

HSE Startup Timout Value (ms) 100

LSE Startup Timout Value (ms) 5000

#### **Power Parameters:**

Power Regulatror Voltage Scale Power Regulator Voltage Scale 3

Power Over Drive Disabled

#### 7.4. SYS

**Debug: Serial Wire** 

**Timebase Source: TIM2** 

#### 7.5. TIM3

**Clock Source: Internal Clock** 

7.5.1. Parameter Settings:

**Counter Settings:** 

Prescaler (PSC - 16 bits value) 0

Counter Mode Up

Counter Period (AutoReload Register - 16 bits value) 0

Internal Clock Division (CKD)

No Division

auto-reload preload

Disable

**Trigger Output (TRGO) Parameters:** 

Master/Slave Mode (MSM bit) Disable (Trigger input effect not delayed)

Trigger Event Selection Reset (UG bit from TIMx\_EGR)

#### 7.6. TIM4

**Clock Source: Internal Clock** 

7.6.1. Parameter Settings:

**Counter Settings:** 

Prescaler (PSC - 16 bits value) 0

Counter Mode Up

Counter Period (AutoReload Register - 16 bits value ) 0

Internal Clock Division (CKD)

No Division

auto-reload preload

Disable

**Trigger Output (TRGO) Parameters:** 

Master/Slave Mode (MSM bit) Disable (Trigger input effect not delayed)

Trigger Event Selection Reset (UG bit from TIMx\_EGR)

#### 7.7. FREERTOS

Interface: CMSIS\_V1

7.7.1. Config parameters:

API:

FreeRTOS API CMSIS v1

**Versions:** 

FreeRTOS version 10.0.1

CMSIS-RTOS version 1.02

Kernel settings:

USE\_PREEMPTION Enabled

CPU\_CLOCK\_HZ SystemCoreClock

 TICK\_RATE\_HZ
 1000

 MAX\_PRIORITIES
 7

 MINIMAL\_STACK\_SIZE
 128

 MAX\_TASK\_NAME\_LEN
 16

 USE\_16\_BIT\_TICKS
 Disabled

IDLE\_SHOULD\_YIELD Enabled
USE\_MUTEXES Enabled
USE\_RECURSIVE\_MUTEXES Disabled
USE\_COUNTING\_SEMAPHORES Disabled

QUEUE\_REGISTRY\_SIZE 8

USE\_APPLICATION\_TASK\_TAG Disabled
ENABLE\_BACKWARD\_COMPATIBILITY Enabled
USE\_PORT\_OPTIMISED\_TASK\_SELECTION Enabled
USE\_TICKLESS\_IDLE Disabled
USE\_TASK\_NOTIFICATIONS Enabled
RECORD\_STACK\_HIGH\_ADDRESS Disabled

**Memory management settings:** 

Memory AllocationDynamicTOTAL\_HEAP\_SIZE15360Memory Management schemeheap\_4

Hook function related definitions:

USE\_IDLE\_HOOK Disabled
USE\_TICK\_HOOK Disabled
USE\_MALLOC\_FAILED\_HOOK Disabled
USE\_DAEMON\_TASK\_STARTUP\_HOOK Disabled
CHECK\_FOR\_STACK\_OVERFLOW Disabled

Run time and task stats gathering related definitions:

GENERATE\_RUN\_TIME\_STATS Disabled
USE\_TRACE\_FACILITY Disabled
USE\_STATS\_FORMATTING\_FUNCTIONS Disabled

Co-routine related definitions:

USE\_CO\_ROUTINES Disabled MAX\_CO\_ROUTINE\_PRIORITIES 2

Software timer definitions:

USE\_TIMERS Disabled

Interrupt nesting behaviour configuration:

LIBRARY\_LOWEST\_INTERRUPT\_PRIORITY 15
LIBRARY\_MAX\_SYSCALL\_INTERRUPT\_PRIORITY 5

#### 7.7.2. Include parameters:

#### Include definitions:

vTaskPrioritySet Enabled uxTaskPriorityGet Enabled Enabled vTaskDelete vTaskCleanUpResources Disabled vTaskSuspend Enabled Disabled vTaskDelayUntil Enabled vTaskDelay xTaskGetSchedulerState Enabled Enabled  $x \\ Task \\ Resume \\ From ISR$ xQueueGetMutexHolder Disabled Disabled xSemaphoreGetMutexHolder Disabled pcTaskGetTaskName uxTaskGetStackHighWaterMark Disabled xTaskGetCurrentTaskHandle Disabled Disabled eTaskGetState xEventGroupSetBitFromISR Disabled Disabled xTimerPendFunctionCall Disabled xTaskAbortDelay Disabled xTaskGetHandle

<sup>\*</sup> User modified value

# 8. System Configuration

# 8.1. GPIO configuration

| IP               | Pin  | Signal             | GPIO mode                                                  | GPIO pull/up pull<br>down   | Max<br>Speed | User Label                                   |
|------------------|------|--------------------|------------------------------------------------------------|-----------------------------|--------------|----------------------------------------------|
| ETH              | PC1  | ETH_MDC            | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | RMII_MDC [LAN8742A-<br>CZ-TR_MDC]            |
|                  | PA1  | ETH_REF_CLK        | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | RMII_REF_CLK<br>[LAN8742A-CZ-<br>TR_REFCLK0] |
|                  | PA2  | ETH_MDIO           | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | RMII_MDIO [LAN8742A-<br>CZ-TR_MDIO]          |
|                  | PA7  | ETH_CRS_DV         | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | RMII_CRS_DV<br>[LAN8742A-CZ-<br>TR_CRS_DV]   |
|                  | PC4  | ETH_RXD0           | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | RMII_RXD0 [LAN8742A-<br>CZ-TR_RXD0]          |
|                  | PC5  | ETH_RXD1           | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | RMII_RXD1 [LAN8742A-<br>CZ-TR_RXD1]          |
|                  | PB13 | ETH_TXD1           | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | RMII_TXD1 [LAN8742A-<br>CZ-TR_TXD1]          |
|                  | PG11 | ETH_TX_EN          | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | RMII_TX_EN [LAN8742A-<br>CZ-TR_TXEN]         |
|                  | PG13 | ETH_TXD0           | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | RMII_TXD0 [LAN8742A-<br>CZ-TR_TXD0]          |
| SYS              | PA13 | SYS_JTMS-<br>SWDIO | n/a                                                        | n/a                         | n/a          | TMS                                          |
|                  | PA14 | SYS_JTCK-<br>SWCLK | n/a                                                        | n/a                         | n/a          | TCK                                          |
| Single<br>Mapped | PB0  | ETH_RXD2           | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | ETH_RXD2                                     |
| Signals          | PD8  | USART3_TX          | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | USART3_TX                                    |
|                  | PD9  | USART3_RX          | Alternate Function Push Pull                               | No pull-up and no pull-down | Very High    | USART3_RX                                    |
| GPIO             | PC13 | GPIO_EXTI13        | External Interrupt Mode with Rising edge trigger detection | No pull-up and no pull-down | n/a          | USER_Btn [B1]                                |
|                  | PB14 | GPIO_Output        | Output Push Pull                                           | No pull-up and no pull-down | Low          | LD3 [Red]                                    |
|                  | PB7  | GPIO_Output        | Output Push Pull                                           | No pull-up and no pull-down | Low          | LD2 [Blue]                                   |

# 8.2. DMA configuration

nothing configured in DMA service

# 8.3. NVIC configuration

| Interrupt Table                                 | Enable | Preenmption Priority | SubPriority |  |
|-------------------------------------------------|--------|----------------------|-------------|--|
| Non maskable interrupt                          | true   | 0                    | 0           |  |
| Hard fault interrupt                            | true   | 0                    | 0           |  |
| Memory management fault                         | true   | 0                    | 0           |  |
| Pre-fetch fault, memory access fault            | true   | 0                    | 0           |  |
| Undefined instruction or illegal state          | true   | 0                    | 0           |  |
| System service call via SWI instruction         | true   | 0                    | 0           |  |
| Debug monitor                                   | true   | 0                    | 0           |  |
| Pendable request for system service             | true   | 15                   | 0           |  |
| System tick timer                               | true   | 15                   | 0           |  |
| TIM2 global interrupt                           | true   | 0                    | 0           |  |
| TIM3 global interrupt                           | true   | 5                    | 0           |  |
| TIM4 global interrupt                           | true   | 5                    | 0           |  |
| EXTI line[15:10] interrupts                     | true   | 5                    | 0           |  |
| Ethernet global interrupt                       | true   | 5                    | 0           |  |
| PVD interrupt through EXTI line 16              | unused |                      |             |  |
| Flash global interrupt                          | unused |                      |             |  |
| RCC global interrupt                            | unused |                      |             |  |
| Ethernet wake-up interrupt through EXTI line 19 | unused |                      |             |  |
| FPU global interrupt                            | unused |                      |             |  |

<sup>\*</sup> User modified value

# 9. Software Pack Report