# 1. Description

### 1.1. Project

| Project Name    | Medium_Self_Balance_Vehicle |
|-----------------|-----------------------------|
| Board Name      | custom                      |
| Generated with: | STM32CubeMX 4.26.0          |
| Date            | 12/03/2019                  |

### 1.2. MCU

| MCU Series     | STM32F1       |
|----------------|---------------|
| MCU Line       | STM32F103     |
| MCU name       | STM32F103C8Tx |
| MCU Package    | LQFP48        |
| MCU Pin number | 48            |

# 2. Pinout Configuration



# 3. Pins Configuration

| Pin Number | Pin Name        | Pin Type | Alternate      | Label    |
|------------|-----------------|----------|----------------|----------|
| LQFP48     | (function after |          | Function(s)    |          |
|            | reset)          |          | , ,            |          |
| 1          | VBAT            | Power    |                |          |
| 5          | PD0-OSC_IN      | I/O      | RCC_OSC_IN     |          |
| 6          | PD1-OSC_OUT     | I/O      | RCC_OSC_OUT    |          |
| 7          | NRST            | Reset    |                |          |
| 8          | VSSA            | Power    |                |          |
| 9          | VDDA            | Power    |                |          |
| 10         | PA0-WKUP        | I/O      | TIM2_CH1       |          |
| 11         | PA1             | I/O      | TIM2_CH2       |          |
| 14         | PA4 *           | I/O      | GPIO_Output    | LED_Blue |
| 15         | PA5 *           | I/O      | GPIO_Input     | KEY_USER |
| 16         | PA6             | I/O      | ADC1_IN6       | Vol_ADC  |
| 23         | VSS             | Power    |                |          |
| 24         | VDD             | Power    |                |          |
| 25         | PB12 *          | I/O      | GPIO_Output    | BIN2     |
| 26         | PB13 *          | I/O      | GPIO_Output    | BIN1     |
| 27         | PB14 *          | I/O      | GPIO_Output    | AIN1     |
| 28         | PB15 *          | I/O      | GPIO_Output    | AIN2     |
| 29         | PA8             | I/O      | TIM1_CH1       | PWMA     |
| 30         | PA9             | I/O      | USART1_TX      |          |
| 31         | PA10            | I/O      | USART1_RX      |          |
| 32         | PA11            | I/O      | TIM1_CH4       | PWMB     |
| 34         | PA13            | I/O      | SYS_JTMS-SWDIO |          |
| 35         | VSS             | Power    |                |          |
| 36         | VDD             | Power    |                |          |
| 37         | PA14            | I/O      | SYS_JTCK-SWCLK |          |
| 38         | PA15 *          | I/O      | GPIO_Output    | OLED_DC  |
| 39         | PB3 *           | I/O      | GPIO_Output    | OLED_RST |
| 40         | PB4 *           | I/O      | GPIO_Output    | OLED_SDA |
| 41         | PB5 *           | I/O      | GPIO_Output    | OLED_SCL |
| 42         | PB6             | I/O      | TIM4_CH1       |          |
| 43         | PB7             | I/O      | TIM4_CH2       |          |
| 44         | воото           | Boot     |                |          |
| 45         | PB8 *           | I/O      | GPIO_Output    |          |
| 46         | PB9 *           | I/O      | GPIO_Output    |          |
| 47         | VSS             | Power    |                |          |
| 48         | VDD             | Power    |                |          |

| Medium_ | _Self_Ba | alance_ | _Vehicle  | Project |
|---------|----------|---------|-----------|---------|
|         |          | Confi   | iguration | Report  |

| * The pin is affected with an I/O function |  |  |
|--------------------------------------------|--|--|
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |
|                                            |  |  |

# 4. Clock Tree Configuration



# 5. IPs and Middleware Configuration

#### 5.1. ADC1

mode: IN6

#### 5.1.1. Parameter Settings:

ADCs\_Common\_Settings:

Mode Independent mode

ADC\_Settings:

Data Alignment Right alignment

Scan Conversion Mode Disabled
Continuous Conversion Mode Disabled
Discontinuous Conversion Mode Disabled

ADC\_Regular\_ConversionMode:

Enable Regular Conversions Enable
Number Of Conversion 1

External Trigger Conversion Source Regular Conversion launched by software

Rank 1

Channel Channel 6

Sampling Time 239.5 Cycles \*

ADC\_Injected\_ConversionMode:

Number Of Conversions 0

WatchDog:

Enable Analog WatchDog Mode false

### 5.2. RCC

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

#### 5.2.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

#### 5.3. SYS

**Debug: Serial Wire** 

Timebase Source: SysTick

#### 5.4. TIM1

Channel1: PWM Generation CH1 Channel4: PWM Generation CH4

5.4.1. Parameter Settings:

#### **Counter Settings:**

Prescaler (PSC - 16 bits value) 0

Counter Mode Up

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

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

Reset (UG bit from TIMx\_EGR)

#### **Break And Dead Time management - BRK Configuration:**

BRK State Disable
BRK Polarity High

#### **Break And Dead Time management - Output Configuration:**

Automatic Output State Disable
Off State Selection for Run Mode (OSSR) Disable
Off State Selection for Idle Mode (OSSI) Disable
Lock Configuration Off

#### **PWM Generation Channel 1:**

Mode PWM mode 1

Pulse (16 bits value) 0
Fast Mode Disable
CH Polarity High
CH Idle State Reset

#### **PWM Generation Channel 4:**

Mode PWM mode 1

Pulse (16 bits value) 0
Fast Mode Disable

| CH Polarity   | High  |
|---------------|-------|
| CH Idle State | Reset |
|               |       |
|               |       |
|               |       |

### 5.5. TIM2

| Combined Channels: Encoder Mod                        | de                                         |
|-------------------------------------------------------|--------------------------------------------|
| 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. TIM3

mode: Clock Source

### 5.6.1. Parameter Settings:

#### **Counter Settings:**

Prescaler (PSC - 16 bits value) 7199 \* Counter Mode Up Counter Period (AutoReload Register - 16 bits value ) 99 \*

Internal Clock Division (CKD) No Division Disable auto-reload preload **Trigger Output (TRGO) Parameters:** Master/Slave Mode (MSM bit) Disable (Trigger input effect not delayed) Reset (UG bit from TIMx\_EGR) Trigger Event Selection 5.7. TIM4 **Combined Channels: Encoder Mode** 5.7.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

Polarity Rising Edge
IC Selection Direct
Prescaler Division Ratio No division
Input Filter 3 \*

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

### 5.8. **USART1**

Prescaler Division Ratio

Input Filter

**Mode: Asynchronous** 

5.8.1. Parameter Settings:

No division

3 \*

**Basic Parameters:** 

Baud Rate 115200

Word Length 8 Bits (including Parity)

Parity None Stop Bits 1

**Advanced Parameters:** 

Data Direction Receive and Transmit

Over Sampling 16 Samples

<sup>\*</sup> 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 |
|--------|-----------------|--------------------|------------------------------|-----------------------------|--------------|------------|
| ADC1   | PA6             | ADC1_IN6           | Analog mode                  | n/a                         | n/a          | Vol_ADC    |
| RCC    | PD0-<br>OSC_IN  | RCC_OSC_IN         | n/a                          | n/a                         | n/a          |            |
|        | PD1-<br>OSC_OUT | RCC_OSC_OUT        | n/a                          | n/a                         | n/a          |            |
| SYS    | PA13            | SYS_JTMS-<br>SWDIO | n/a                          | n/a                         | n/a          |            |
|        | PA14            | SYS_JTCK-<br>SWCLK | n/a                          | n/a                         | n/a          |            |
| TIM1   | PA8             | TIM1_CH1           | Alternate Function Push Pull | n/a                         | High *       | PWMA       |
|        | PA11            | TIM1_CH4           | Alternate Function Push Pull | n/a                         | High *       | PWMB       |
| TIM2   | PA0-WKUP        | TIM2_CH1           | Input mode                   | No pull-up and no pull-down | n/a          |            |
|        | PA1             | TIM2_CH2           | Input mode                   | No pull-up and no pull-down | n/a          |            |
| TIM4   | PB6             | TIM4_CH1           | Input mode                   | No pull-up and no pull-down | n/a          |            |
|        | PB7             | TIM4_CH2           | Input mode                   | No pull-up and no pull-down | n/a          |            |
| USART1 | PA9             | USART1_TX          | Alternate Function Push Pull | n/a                         | High *       |            |
|        | PA10            | USART1_RX          | Input mode                   | No pull-up and no pull-down | n/a          |            |
| GPIO   | PA4             | GPIO_Output        | Output Push Pull             | No pull-up and no pull-down | Low          | LED_Blue   |
|        | PA5             | GPIO_Input         | Input mode                   | No pull-up and no pull-down | n/a          | KEY_USER   |
|        | PB12            | GPIO_Output        | Output Push Pull             | No pull-up and no pull-down | Low          | BIN2       |
|        | PB13            | GPIO_Output        | Output Push Pull             | No pull-up and no pull-down | Low          | BIN1       |
|        | PB14            | GPIO_Output        | Output Push Pull             | No pull-up and no pull-down | Low          | AIN1       |
|        | PB15            | GPIO_Output        | Output Push Pull             | No pull-up and no pull-down | Low          | AIN2       |
|        | PA15            | GPIO_Output        | Output Push Pull             | No pull-up and no pull-down | Low          | OLED_DC    |
|        | PB3             | GPIO_Output        | Output Push Pull             | No pull-up and no pull-down | Low          | OLED_RST   |
|        | PB4             | GPIO_Output        | Output Push Pull             | No pull-up and no pull-down | Low          | OLED_SDA   |
|        | PB5             | GPIO_Output        | Output Push Pull             | No pull-up and no pull-down | Low          | OLED_SCL   |
|        | PB8             | GPIO_Output        | Output Open Drain *          | No pull-up and no pull-down | Medium *     |            |
|        | PB9             | GPIO_Output        | Output Open Drain *          | No pull-up and no pull-down | Medium *     |            |

## 6.2. DMA configuration

nothing configured in DMA service

## 6.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           |
| Prefetch 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           |
| TIM2 global interrupt                   | true   | 0                    | 1           |
| TIM3 global interrupt                   | true   | 2                    | 0           |
| TIM4 global interrupt                   | true   | 0                    | 0           |
| USART1 global interrupt                 | true 1 |                      | 0           |
| PVD interrupt through EXTI line 16      |        | unused               |             |
| Flash global interrupt                  |        | unused               |             |
| RCC global interrupt                    | unused |                      |             |
| ADC1 and ADC2 global interrupts         | unused |                      |             |
| TIM1 break interrupt                    | unused |                      |             |
| TIM1 update interrupt                   | unused |                      |             |
| TIM1 trigger and commutation interrupts | unused |                      |             |
| TIM1 capture compare interrupt          | unused |                      |             |

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

# 7. Power Consumption Calculator report

### 7.1. Microcontroller Selection

| Series    | STM32F1       |
|-----------|---------------|
| Line      | STM32F103     |
| мси       | STM32F103C8Tx |
| Datasheet | 13587_Rev17   |

#### 7.2. Parameter Selection

| Temperature | 25  |
|-------------|-----|
| 11/700      | 3.3 |

# 8. Software Project

### 8.1. Project Settings

| Name                              | Value                                                               |
|-----------------------------------|---------------------------------------------------------------------|
| Project Name                      | Medium_Self_Balance_Vehicle                                         |
| Project Folder                    | G:\Big_Big\Simulink\STM32Cube_code\Code\Medium_Self_Balance_Vehicle |
| Toolchain / IDE                   | MDK-ARM V5                                                          |
| Firmware Package Name and Version | STM32Cube FW_F1 V1.6.0                                              |

### 8.2. Code Generation Settings

| Name                                                            | Value                                           |  |
|-----------------------------------------------------------------|-------------------------------------------------|--|
| STM32Cube Firmware Library Package                              | Copy all used libraries into the project folder |  |
| 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 consumption) | No                                              |  |

| <b>9.</b> | So | ftware | <b>Pack</b> | Report |
|-----------|----|--------|-------------|--------|
|-----------|----|--------|-------------|--------|