# 1. Description

### 1.1. Project

| Project Name    | FSM2018            |
|-----------------|--------------------|
| Board Name      | custom             |
| Generated with: | STM32CubeMX 4.27.0 |
| Date            | 11/09/2018         |

### 1.2. MCU

| MCU Series     | STM32F0       |
|----------------|---------------|
| MCU Line       | STM32F0x2     |
| MCU name       | STM32F042K6Tx |
| MCU Package    | LQFP32        |
| MCU Pin number | 32            |

## 2. Pinout Configuration



# 3. Pins Configuration

| Pin Number<br>LQFP32 | Pin Name<br>(function after<br>reset) | Pin Type | Alternate<br>Function(s) | Label                      |
|----------------------|---------------------------------------|----------|--------------------------|----------------------------|
| 1                    | VDD                                   | Power    |                          |                            |
| 4                    | NRST                                  | Reset    |                          |                            |
| 5                    | VDDA                                  | Power    |                          |                            |
| 6                    | PA0                                   | I/O      | TIM2_CH1                 |                            |
| 7                    | PA1                                   | I/O      | TIM2_CH2                 |                            |
| 8                    | PA2 *                                 | I/O      | GPIO_Input               | PRIMARY_APS_Z              |
| 9                    | PA3 *                                 | I/O      | GPIO_Input               | PRIMARY_APPS_ALARM_<br>PIN |
| 10                   | PA4 *                                 | I/O      | GPIO_Input               | BSPD_brake_threshold       |
| 11                   | PA5                                   | I/O      | ADC_IN5                  |                            |
| 12                   | PA6                                   | I/O      | TIM16_CH1                |                            |
| 13                   | PA7                                   | I/O      | TIM17_CH1                |                            |
| 16                   | VSS                                   | Power    |                          |                            |
| 17                   | VDDIO2                                | Power    |                          |                            |
| 27                   | PB4                                   | I/O      | TIM3_CH1                 |                            |
| 28                   | PB5                                   | I/O      | TIM3_CH2                 |                            |
| 29                   | PB6 *                                 | I/O      | GPIO_Input               | SECONDARY_APPS_Z           |
| 30                   | PB7 *                                 | I/O      | GPIO_Input               | SECONDARY_APPS_ALAR<br>M   |
| 32                   | VSSA                                  | Power    |                          |                            |

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

## 4. Clock Tree Configuration



Page 4

## 5. IPs and Middleware Configuration

5.1. ADC

mode: IN5

mode: Vrefint Channel 5.1.1. Parameter Settings:

ADC\_Settings:

Clock Prescaler Asynchronous clock mode
Resolution ADC 12-bit resolution

Data Alignment Right alignment

Scan Conversion Mode

Backward \*

Continuous Conversion Mode

Disabled

Discontinuous Conversion Mode Disabled

DMA Continuous Requests Enabled \*

End Of Conversion Selection End of single conversion

Overrun behaviour Overrun data preserved

Low Power Auto Wait Disabled

Low Power Auto Power Off Disabled

ADC\_Regular\_ConversionMode:

Sampling Time 7.5 Cycles \*

External Trigger Conversion Source

Timer 1 Trigger Out event \*

External Trigger Conversion Edge

Trigger detection on the rising edge

WatchDog:

Enable Analog WatchDog Mode false

5.2. SYS

**Timebase Source: SysTick** 

5.3. TIM1

Clock Source : Internal Clock

5.3.1. Parameter Settings:

**Counter Settings:** 

Prescaler (PSC - 16 bits value) 0

Counter Mode Up

Counter Period (AutoReload Register - 16 bits value ) 4999 \*

Internal Clock Division (CKD) No Division

Repetition Counter (RCR - 8 bits value) 0

auto-reload preload Disable

**Trigger Output (TRGO) Parameters:** 

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

Trigger Event Selection Update Event \*

#### 5.4. TIM2

**Combined Channels: Encoder Mode** 

#### 5.4.1. Parameter Settings:

#### **Counter Settings:**

Prescaler (PSC - 16 bits value) 0

Counter Mode Up

Counter Period (AutoReload Register - 32 bits value) 65535 \*

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)

#### Encoder:

Encoder Mode Encoder Mode TI1 and TI2 \*

\_\_\_\_ Parameters for Channel 1 \_\_\_\_

Polarity Rising Edge
IC Selection Direct
Prescaler Division Ratio No division
Input Filter 0

\_\_\_\_ Parameters for Channel 2 \_\_\_\_

Polarity Rising Edge
IC Selection Direct
Prescaler Division Ratio No division

Input Filter 0

#### 5.5. TIM3

**Combined Channels: Encoder Mode** 

#### 5.5.1. Parameter Settings:

| Counter Settings:                                     |                                                                 |
|-------------------------------------------------------|-----------------------------------------------------------------|
| Prescaler (PSC - 16 bits value)                       | 0                                                               |
| Counter Mode                                          | Up                                                              |
| Counter Period (AutoReload Register - 16 bits value ) | 65535 *                                                         |
| 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)                                    |
| Encoder:                                              |                                                                 |
| Encoder Mode                                          | Encoder Mode TI1 and TI2 *                                      |
| Parameters for Channel 1                              |                                                                 |
| Polarity                                              | Rising Edge                                                     |
| IC Selection                                          | Direct                                                          |
| Prescaler Division Ratio                              | No division                                                     |
| Input Filter                                          | 0                                                               |
| Parameters for Channel 2                              |                                                                 |
| Polarity                                              | Rising Edge                                                     |
| IC Selection                                          | Direct                                                          |
| Prescaler Division Ratio                              | No division                                                     |
| Input Filter                                          | 0                                                               |
|                                                       |                                                                 |
| 5.6. TIM14                                            |                                                                 |
|                                                       |                                                                 |
| mode: Activated                                       |                                                                 |
| 5.6.1. Parameter Settings:                            |                                                                 |
| Counter Settings:                                     |                                                                 |
| Prescaler (PSC - 16 bits value)                       | 7 *                                                             |
| Counter Mode                                          | Up                                                              |
| Counter Period (AutoReload Register - 16 bits value ) | ((SystemCoreClockCube / 8) / CONTROL LOOP FREQUENCY CUBE) - 1 * |

### 5.7. TIM16

auto-reload preload

Internal Clock Division (CKD)

No Division

Disable

mode: Activated

**Channel1: Input Capture direct mode** 

5.7.1. Parameter Settings:

#### **Counter Settings:**

Prescaler (PSC - 16 bits value) WHEEL\_SPEED\_TIMER\_PRESCALER\_CUBE \*

Counter Mode Up

Counter Period (AutoReload Register - 16 bits value ) 65535 \*
Internal Clock Division (CKD) No Division

Repetition Counter (RCR - 8 bits value) 0
auto-reload preload Disable

**Input Capture Channel 1:** 

Polarity Selection Rising Edge
IC Selection Direct
Prescaler Division Ratio No division

Input Filter (4 bits value) 0

#### 5.8. TIM17

mode: Activated

**Channel1: Input Capture direct mode** 

5.8.1. Parameter Settings:

#### **Counter Settings:**

Prescaler (PSC - 16 bits value) WHEEL\_SPEED\_TIMER\_PRESCALER\_CUBE \*

Counter Mode Up

Counter Period (AutoReload Register - 16 bits value ) 65535 \*

Internal Clock Division (CKD) No Division

Repetition Counter (RCR - 8 bits value) 0

auto-reload preload Disable

**Input Capture Channel 1:** 

Polarity Selection Rising Edge IC Selection Direct

Prescaler Division Ratio No division

Input Filter (4 bits value) 0

| * User modified value |  |
|-----------------------|--|
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |
|                       |  |

# 6. System Configuration

## 6.1. GPIO configuration

| IP    | Pin | Signal     | GPIO mode                    | GPIO pull/up pull<br>down   | Max<br>Speed | User Label                 |
|-------|-----|------------|------------------------------|-----------------------------|--------------|----------------------------|
| ADC   | PA5 | ADC_IN5    | Analog mode                  | No pull-up and no pull-down | n/a          |                            |
| TIM2  | PA0 | TIM2_CH1   | Alternate Function Push Pull | Pull-up *                   | Low          |                            |
|       | PA1 | TIM2_CH2   | Alternate Function Push Pull | Pull-up *                   | Low          |                            |
| TIM3  | PB4 | TIM3_CH1   | Alternate Function Push Pull | Pull-up *                   | Low          |                            |
|       | PB5 | TIM3_CH2   | Alternate Function Push Pull | Pull-up *                   | Low          |                            |
| TIM16 | PA6 | TIM16_CH1  | Alternate Function Push Pull | No pull-up and no pull-down | Low          |                            |
| TIM17 | PA7 | TIM17_CH1  | Alternate Function Push Pull | No pull-up and no pull-down | Low          |                            |
| GPIO  | PA2 | GPIO_Input | Input mode                   | No pull-up and no pull-down | n/a          | PRIMARY_APS_Z              |
|       | PA3 | GPIO_Input | Input mode                   | No pull-up and no pull-down | n/a          | PRIMARY_APPS_ALARM<br>_PIN |
|       | PA4 | GPIO_Input | Input mode                   | No pull-up and no pull-down | n/a          | BSPD_brake_threshold       |
|       | PB6 | GPIO_Input | Input mode                   | No pull-up and no pull-down | n/a          | SECONDARY_APPS_Z           |
|       | PB7 | GPIO_Input | Input mode                   | No pull-up and no pull-down | n/a          | SECONDARY_APPS_ALA<br>RM   |

### 6.2. DMA configuration

| DMA request | Stream        | Direction            | Priority |
|-------------|---------------|----------------------|----------|
| ADC         | DMA1_Channel1 | Peripheral To Memory | Medium * |

### ADC: DMA1\_Channel1 DMA request Settings:

Mode: Circular \*

Peripheral Increment: Disable

Memory Increment: Enable \*

Peripheral Data Width: Half Word

Memory Data Width: Half Word

## 6.3. NVIC configuration

| Interrupt Table                                                          | Enable | Preenmption Priority | SubPriority |
|--------------------------------------------------------------------------|--------|----------------------|-------------|
| Non maskable interrupt                                                   | true   | 0                    | 0           |
| Hard fault interrupt                                                     | true   | 0                    | 0           |
| System service call via SWI instruction                                  | true   | 0                    | 0           |
| Pendable request for system service                                      | true   | 0                    | 0           |
| System tick timer                                                        | true   | 0                    | 0           |
| DMA1 channel 1 interrupt                                                 | true   | 0                    | 0           |
| TIM14 global interrupt                                                   | true   | 0                    | 0           |
| TIM16 global interrupt                                                   | true   | 0                    | 0           |
| TIM17 global interrupt                                                   | true   | 0                    | 0           |
| PVD and VDDIO2 supply comparator interrupts through EXTI lines 16 and 31 |        | unused               |             |
| Flash global interrupt                                                   | unused |                      |             |
| RCC and CRS global interrupts                                            | unused |                      |             |
| ADC interrupt                                                            | unused |                      |             |
| TIM1 break, update, trigger and commutation interrupts                   | unused |                      |             |
| TIM1 capture compare interrupt                                           | unused |                      |             |
| TIM2 global interrupt                                                    | unused |                      |             |
| TIM3 global interrupt                                                    | unused |                      |             |

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

# 7. Power Consumption Calculator report

### 7.1. Microcontroller Selection

| Series    | STM32F0       |
|-----------|---------------|
| Line      | STM32F0x2     |
| мси       | STM32F042K6Tx |
| Datasheet | 025832_Rev5   |

#### 7.2. Parameter Selection

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

# 8. Software Project

### 8.1. Project Settings

| Name                              | Value                                                           |
|-----------------------------------|-----------------------------------------------------------------|
| Project Name                      | FSM2018                                                         |
| Project Folder                    | C:\Users\Ahmad\Documents\Formula\Consolidated-Firmware\FSM_2018 |
| Toolchain / IDE                   | MDK-ARM V5                                                      |
| Firmware Package Name and Version | STM32Cube FW_F0 V1.9.0                                          |

### 8.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 | No                                    |
| 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)                                                  |                                       |

# 9. Software Pack Report