# 1. Description

## 1.1. Project

| Project Name    | PDM               |
|-----------------|-------------------|
| Board Name      | PDM               |
| Generated with: | STM32CubeMX 5.0.0 |
| Date            | 12/08/2018        |

### 1.2. MCU

| MCU Series     | STM32F3       |
|----------------|---------------|
| MCU Line       | STM32F302     |
| MCU name       | STM32F302R8Tx |
| MCU Package    | LQFP64        |
| MCU Pin number | 64            |

## 2. Pinout Configuration



# 3. Pins Configuration

| Pin Number | Pin Name        | Pin Type | Alternate     | Label                       |
|------------|-----------------|----------|---------------|-----------------------------|
| LQFP64     | (function after |          | Function(s)   |                             |
| EGITOT     | reset)          |          | r driodori(o) |                             |
| 4          | VBAT            | Dower    |               |                             |
| 1          |                 | Power    | DCC OSC IN    | OCC IN                      |
| 5          | PF0-OSC_IN      | 1/0      | RCC_OSC_IN    | OSC_IN                      |
| 6          | PF1-OSC_OUT     | I/O      | RCC_OSC_OUT   | OSC_OUT                     |
| 7 10       | NRST<br>PC2     | Reset    | ADC4 INO      | CLV SENSE                   |
|            | PC3             | 1/0      | ADC1_IN8      | GLV_SENSE                   |
| 11         |                 | I/O      | ADC1_IN9      | VBAT_SENSE                  |
| 12         | VSSA/VREF-      | Power    |               |                             |
| 13         | VDDA/VREF+      | Power    | 4.D.O.4 .IN14 | 551105 10 4                 |
| 14         | PA0             | I/O      | ADC1_IN1      | EFUSE_IS_1                  |
| 15         | PA1             | I/O      | ADC1_IN2      | EFUSE_IS_2                  |
| 16         | PA2             | I/O      | ADC1_IN3      | EFUSE_IS_3                  |
| 17         | PA3             | I/O      | ADC1_IN4      | EFUSE_IS_4                  |
| 18         | VSS             | Power    |               |                             |
| 19         | VDD             | Power    |               |                             |
| 20         | PA4             | I/O      | ADC1_IN5      | EFUSE_IS_5                  |
| 22         | PA6             | I/O      | ADC1_IN10     | FLYWIRE                     |
| 23         | PA7 *           | I/O      | GPIO_Output   | EFUSE_AUX_2_IN              |
| 24         | PC4 *           | I/O      | GPIO_Output   | EFUSE_AUX_DSEL              |
| 25         | PC5 *           | I/O      | GPIO_Output   | EFUSE_AUX_DEN               |
| 26         | PB0 *           | I/O      | GPIO_Output   | EFUSE_AUX_1_IN              |
| 27         | PB1 *           | I/O      | GPIO_Output   | EFUSE_PDM_FAN_IN            |
| 28         | PB2 *           | I/O      | GPIO_Output   | EFUSE_FAN_COOLING_D<br>SEL  |
| 29         | PB10 *          | I/O      | GPIO_Output   | EFUSE_FAN_COOLING_D<br>EN   |
| 30         | PB11 *          | I/O      | GPIO_Output   | EFUSE_COOLING_IN            |
| 31         | VSS             | Power    |               |                             |
| 32         | VDD             | Power    |               |                             |
| 33         | PB12 *          | I/O      | GPIO_Output   | EFUSE_CAN_IN                |
| 34         | PB13 *          | I/O      | GPIO_Output   | EFUSE_CAN_AIR_SHDN_<br>DSEL |
| 35         | PB14 *          | I/O      | GPIO_Output   | EFUSE_CAN_AIR_SHDN_<br>DEN  |
| 36         | PB15 *          | I/O      | GPIO_Output   | EFUSE_AIR_SHDN_IN           |
| 37         | PC6 *           | I/O      | GPIO_Output   | EFUSE_ACC_ENC_FAN_IN        |
| 38         | PC7 *           | I/O      | GPIO_Output   | EFUSE_ACC_FAN_DSEL          |
|            |                 |          |               |                             |

| Pin Number | Pin Name        | Pin Type | Alternate         | Label                        |
|------------|-----------------|----------|-------------------|------------------------------|
| LQFP64     | (function after |          | Function(s)       |                              |
| Lairoi     | ,               |          | r driodori(o)     |                              |
|            | reset)          |          |                   |                              |
| 39         | PC8 *           | I/O      | GPIO_Output       | EFUSE_ACC_FAN_DEN            |
| 40         | PC9 *           | I/O      | GPIO_Output       | EFUSE_ACC_SEG_FAN_IN         |
| 41         | PA8 *           | I/O      | GPIO_Output       | EFUSE_RIGHT_INVERTER<br>_IN  |
| 42         | PA9 *           | I/O      | GPIO_Output       | EFUSE_INVERTER_DSEL          |
| 43         | PA10 *          | I/O      | GPIO_Output       | EFUSE_INVERTER_DEN           |
| 44         | PA11            | I/O      | CAN_RX            |                              |
| 45         | PA12            | I/O      | CAN_TX            |                              |
| 46         | PA13            | I/O      | SYS_JTMS-SWDIO    | SWDIO                        |
| 47         | VSS             | Power    |                   |                              |
| 48         | VDD             | Power    |                   |                              |
| 49         | PA14            | I/O      | SYS_JTCK-SWCLK    | SWCLK                        |
| 50         | PA15 *          | I/O      | GPIO_Output       | EFUSE_LEFT_INVERTER_I<br>N   |
| 51         | PC10            | I/O      | GPIO_EXTI10       | CHARGER_FAULT                |
| 52         | PC11            | I/O      | GPIO_EXTI11       | CHARGER_INDICATOR            |
| 53         | PC12            | I/O      | GPIO_EXTI12       | BOOST_PGOOD                  |
| 54         | PD2             | I/O      | GPIO_EXTI2        | CELL_BALANCE_OVERVO<br>LTAGE |
| 55         | PB3 **          | I/O      | SYS_JTDO-TRACESWO | SWO                          |
| 60         | BOOT0           | Boot     |                   |                              |
| 63         | VSS             | Power    |                   |                              |
| 64         | 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



Page 5

# 5. Software Project

## 5.1. Project Settings

| Name                              | Value                                                                 |
|-----------------------------------|-----------------------------------------------------------------------|
| Project Name                      | PDM                                                                   |
| Project Folder                    | C:\Users\Jason\Desktop\Formula Electric\Consolidated-Firmware\src\PDM |
| Toolchain / IDE                   | MDK-ARM V5                                                            |
| Firmware Package Name and Version | STM32Cube FW_F3 V1.10.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 | 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)                                                  |                                       |

# 6. Power Consumption Calculator report

#### 6.1. Microcontroller Selection

| Series    | STM32F3       |
|-----------|---------------|
| Line      | STM32F302     |
| мси       | STM32F302R8Tx |
| Datasheet | 025147_Rev7   |

#### 6.2. Parameter Selection

| Temperature | 25  |
|-------------|-----|
| 11/100      | 3.6 |

# 7. IPs and Middleware Configuration 7.1. ADC1

IN1: IN1 Single-ended IN2: IN2 Single-ended IN3: IN3 Single-ended IN4: IN4 Single-ended IN5: IN5 Single-ended IN8: IN8 Single-ended IN9: IN9 Single-ended IN10: IN10 Single-ended

mode: Temperature Sensor Channel

mode: Vrefint Channel mode: Vbat Channel

#### 7.1.1. Parameter Settings:

#### ADC\_Settings:

Clock Prescaler ADC Asynchronous clock mode

Resolution

Data Alignment

Scan Conversion Mode

Continuous Conversion Mode

Discontinuous Conversion Mode

Disabled

DMA Continuous Requests

Disabled

End Of Conversion Selection End of single conversion

Overrun behaviour Overrun data overwritten

Low Power Auto Wait Disabled

#### ADC\_Regular\_ConversionMode:

Enable Regular Conversions Enable

Number Of Conversion 8 \*

External Trigger Conversion Source

Timer 2 Trigger Out event \*

External Trigger Conversion Edge

Trigger detection on the rising edge

<u>Rank</u> 2 \*

Channel 2 \*
Sampling Time 4.5 Cycles \*
Offset Number No offset

Offset 0 **3 \*** 

Channel

Channel 3 \*

Sampling Time 4.5 Cycles \*

Offset Number No offset

Offset 0 **4** \*

Channel 4 \*

Sampling Time 4.5 Cycles \*

Offset Number No offset
Offset 0

<u>Rank</u> 5 \*

Channel 5 \*
Sampling Time 4.5 Cycles \*

Sampling Time 4.5 Cycles \*
Offset Number No offset

Offset 0
Rank 6 \*

Channel 8 \*
Sampling Time 4.5 Cycles \*

Offset Number No offset
Offset 0
Rank 7 \*

Channel 9 \*

Sampling Time

4.5 Cycles \*

Offset Number

No offset

Offset 0
Rank 8 \*

Channel 10 \*

Sampling Time 4.5 Cycles \*

Offset Number No offset

Offset 0 Rank 1

Channel Channel 1
Sampling Time 1.5 Cycles
Offset Number No offset

Offset 0

ADC\_Injected\_ConversionMode:

Enable Injected Conversions Enable
Number Of Conversions 0

**Analog Watchdog 1:** 

Enable Analog WatchDog1 Mode false

**Analog Watchdog 2:** 

Enable Analog WatchDog2 Mode false

**Analog Watchdog 3:** 

Enable Analog WatchDog3 Mode false

#### 7.2. CAN

mode: Mode

#### 7.2.1. Parameter Settings:

#### **Bit Timings Parameters:**

Prescaler (for Time Quantum) 8 \*

Time Quantum 222.22222222222 \*

Time Quanta in Bit Segment 1 7 Times \*
Time Quanta in Bit Segment 2 1 Time

ReSynchronization Jump Width 1 Time

**Basic Parameters:** 

Time Triggered Communication Mode

Automatic Bus-Off Management

Automatic Wake-Up Mode

No-Automatic Retransmission

Enable \*

Receive Fifo Locked Mode

Transmit Fifo Priority

Disable

Enable \*

Enable \*

**Advanced Parameters:** 

Operating Mode Normal

#### 7.3. IWDG

mode: Activated

#### 7.3.1. Parameter Settings:

#### **Watchdog Clocking:**

IWDG counter clock prescaler

IWDG window value

31 \*

IWDG down-counter reload value

31 \*

#### 7.4. RCC

#### High Speed Clock (HSE): Crystal/Ceramic Resonator

#### 7.4.1. Parameter Settings:

#### **System Parameters:**

VDD voltage (V) 3.3
Prefetch Buffer Enabled

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

**RCC Parameters:** 

HSI Calibration Value 16
HSE Startup Timout Value (ms) 100
LSE Startup Timout Value (ms) 5000

#### 7.5. SYS

**Debug: Serial Wire** 

Timebase Source: SysTick

#### 7.6. TIM2

**Clock Source: Internal Clock** 

#### 7.6.1. Parameter Settings:

#### **Counter Settings:**

Prescaler (PSC - 16 bits value) 14400 \*

Counter Mode Up

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

Internal Clock Division (CKD)

auto-reload preload

No Division

Disable

#### **Trigger Output (TRGO) Parameters:**

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

Trigger Event Selection TRGO Update Event \*

#### 7.7. TIM6

#### mode: Activated

#### 7.7.1. Parameter Settings:

#### **Counter Settings:**

Prescaler (PSC - 16 bits value) 640 \*

Counter Mode Up

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

auto-reload preload Disable

#### **Trigger Output (TRGO) Parameters:**

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

#### 7.8. TIM17

#### mode: Activated

#### 7.8.1. Parameter Settings:

#### **Counter Settings:**

Prescaler (PSC - 16 bits value) 65535 \*

Counter Mode Up

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

Internal Clock Division (CKD) No Division

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

<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                  |
|-----------------------------|-----------------|-----------------------|------------------------------|---------------------------|--------------|-----------------------------|
| ADC1                        | PC2             | ADC1_IN8              | Analog mode                  | No pull up pull down      | n/a          | GLV SENSE                   |
|                             | PC3             | ADC1_IN9              | Analog mode                  | No pull up pull down      | n/a          | VBAT_SENSE                  |
|                             | PA0             | ADC1_IN1              | Analog mode                  | No pull up pull down      | n/a          | EFUSE_IS_1                  |
|                             | PA1             | ADC1_IN2              | Analog mode                  | No pull up pull down      | n/a          | EFUSE_IS_2                  |
|                             | PA2             | ADC1_IN3              | Analog mode                  | No pull up pull down      | n/a          | EFUSE_IS_3                  |
|                             | PA3             | ADC1_IN4              | Analog mode                  | No pull up pull down      | n/a          | EFUSE_IS_4                  |
|                             | PA4             | ADC1_IN5              | Analog mode                  | No pull up pull down      | n/a          | EFUSE_IS_5                  |
|                             | PA6             | ADC1_IN10             | Analog mode                  | No pull up pull down      | n/a          | FLYWIRE                     |
| CAN                         | PA11            | CAN_RX                | Alternate Function Push Pull | No pull up pull down      | High *       |                             |
|                             | PA12            | CAN_TX                | Alternate Function Push Pull | No pull up pull down      | High *       |                             |
| RCC                         | PF0-OSC_IN      | RCC_OSC_IN            | n/a                          | n/a                       | n/a          | OSC_IN                      |
|                             | PF1-<br>OSC_OUT | RCC_OSC_OUT           | n/a                          | n/a                       | n/a          | OSC_OUT                     |
| SYS                         | PA13            | SYS_JTMS-<br>SWDIO    | n/a                          | n/a                       | n/a          | SWDIO                       |
|                             | PA14            | SYS_JTCK-<br>SWCLK    | n/a                          | n/a                       | n/a          | SWCLK                       |
| Single<br>Mapped<br>Signals | PB3             | SYS_JTDO-<br>TRACESWO | n/a                          | n/a                       | n/a          | SWO                         |
| GPIO                        | PA7             | GPIO_Output           | Output Open Drain *          | Pull up *                 | Low          | EFUSE_AUX_2_IN              |
|                             | PC4             | GPIO_Output           | Output Open Drain *          | Pull up *                 | Low          | EFUSE_AUX_DSEL              |
|                             | PC5             | GPIO_Output           | Output Open Drain *          | Pull up *                 | Low          | EFUSE_AUX_DEN               |
|                             | PB0             | GPIO_Output           | Output Push Pull             | No pull up pull down      | Low          | EFUSE_AUX_1_IN              |
|                             | PB1             | GPIO_Output           | Output Open Drain *          | Pull up *                 | Low          | EFUSE_PDM_FAN_IN            |
|                             | PB2             | GPIO_Output           | Output Open Drain *          | Pull up *                 | Low          | EFUSE_FAN_COOLING_<br>DSEL  |
|                             | PB10            | GPIO_Output           | Output Open Drain *          | Pull up *                 | Low          | EFUSE_FAN_COOLING_<br>DEN   |
|                             | PB11            | GPIO_Output           | Output Open Drain *          | Pull up *                 | Low          | EFUSE_COOLING_IN            |
|                             | PB12            | GPIO_Output           | Output Open Drain *          | Pull up *                 | Low          | EFUSE_CAN_IN                |
|                             | PB13            | GPIO_Output           | Output Open Drain *          | Pull up *                 | Low          | EFUSE_CAN_AIR_SHDN<br>_DSEL |
|                             | PB14            | GPIO_Output           | Output Open Drain *          | Pull up *                 | Low          | EFUSE_CAN_AIR_SHDN<br>_DEN  |
|                             | PB15            | GPIO_Output           | Output Open Drain *          | Pull up *                 | Low          | EFUSE_AIR_SHDN_IN           |

| IP | Pin  | Signal      | GPIO mode                                                  | GPIO pull/up pull    | Max   | User Label                  |
|----|------|-------------|------------------------------------------------------------|----------------------|-------|-----------------------------|
|    |      |             |                                                            | down                 | Speed |                             |
|    | PC6  | GPIO_Output | Output Open Drain *                                        | Pull up *            | Low   | EFUSE_ACC_ENC_FAN_I<br>N    |
|    | PC7  | GPIO_Output | Output Open Drain *                                        | Pull up *            | Low   | EFUSE_ACC_FAN_DSEL          |
|    | PC8  | GPIO_Output | Output Open Drain *                                        | Pull up *            | Low   | EFUSE_ACC_FAN_DEN           |
|    | PC9  | GPIO_Output | Output Open Drain *                                        | Pull up *            | Low   | EFUSE_ACC_SEG_FAN_I<br>N    |
|    | PA8  | GPIO_Output | Output Open Drain *                                        | Pull up *            | Low   | EFUSE_RIGHT_INVERTE<br>R_IN |
|    | PA9  | GPIO_Output | Output Open Drain *                                        | Pull up *            | Low   | EFUSE_INVERTER_DSEL         |
|    | PA10 | GPIO_Output | Output Push Pull                                           | Pull up *            | Low   | EFUSE_INVERTER_DEN          |
|    | PA15 | GPIO_Output | Output Push Pull                                           | Pull up *            | Low   | EFUSE_LEFT_INVERTER<br>_IN  |
|    | PC10 | GPIO_EXTI10 | External Interrupt                                         | No pull up pull down | n/a   | CHARGER_FAULT               |
|    |      |             | Mode with Falling                                          |                      |       |                             |
|    |      |             | edge trigger detection                                     |                      |       |                             |
|    | PC11 | GPIO_EXTI11 | External Interrupt Mode with Rising edge trigger detection | No pull up pull down | n/a   | CHARGER_INDICATOR           |
|    | PC12 | GPIO_EXTI12 | External Interrupt                                         | No pull up pull down | n/a   | BOOST_PGOOD                 |
|    |      |             | Mode with                                                  |                      |       |                             |
|    |      |             | Rising/Falling edge                                        |                      |       |                             |
|    | PD2  | GPIO_EXTI2  | External Interrupt                                         | No pull up pull down | n/a   | CELL_BALANCE_OVERV          |
|    |      |             | Mode with Falling                                          |                      |       | OLTAGE                      |
|    |      |             | edge trigger detection                                     |                      |       |                             |

## 8.2. DMA configuration

| DMA request | Stream        | Direction            | Priority |
|-------------|---------------|----------------------|----------|
| ADC1        | DMA1_Channel1 | Peripheral To Memory | High *   |

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

Mode: Circular \*

Peripheral Increment: Disable

Memory Increment: Enable \*

Peripheral Data Width: Word \*

Memory Data Width: Word \*

## 8.3. NVIC configuration

|                                                |        |                      | 0.151.1     |  |
|------------------------------------------------|--------|----------------------|-------------|--|
| 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   | 0                    | 0           |  |
| System tick timer                              | true   | 0                    | 0           |  |
| EXTI line2 and Touch Sense controller          | true   | 0                    | 0           |  |
| DMA1 channel1 global interrupt                 | true   | 0                    | 0           |  |
| CAN TX and USB high priority interrupts        | true   | 0                    | 0           |  |
| CAN RX0 and USB low priority interrupts        | true   | 0                    | 0           |  |
| CAN RX1 interrupt                              | true   | 0                    | 0           |  |
| TIM1 trigger, commutation and TIM17 interrupts | true   | 0                    | 0           |  |
| TIM2 global interrupt                          | true   | 0                    | 0           |  |
| EXTI line[15:10] interrupts                    | true   | 0                    | 0           |  |
| TIM6 global interrupt, DAC interrupts          | true   | 0                    | 0           |  |
| PVD interrupt through EXTI line16              |        | unused               |             |  |
| Flash global interrupt                         | unused |                      |             |  |
| RCC global interrupt                           | unused |                      |             |  |
| ADC1 interrupt                                 | unused |                      |             |  |
| CAN SCE interrupt                              | unused |                      |             |  |
| Floating point unit interrupt                  | unused |                      |             |  |

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

# 9. Software Pack Report