

# 1. Description

## 1.1. Project

| Project Name    | MX_Pig_V1         |
|-----------------|-------------------|
| Board Name      | NUCLEO-F103RB     |
| Generated with: | STM32CubeMX 6.1.2 |
| Date            | 04/28/2022        |

### 1.2. MCU

| MCU Series     | STM32F1       |
|----------------|---------------|
| MCU Line       | STM32F103     |
| MCU name       | STM32F103RBTx |
| MCU Package    | LQFP64        |
| MCU Pin number | 64            |

## 1.3. Core(s) information

| Core(s) | Arm Cortex-M3 |
|---------|---------------|

# 2. Pinout Configuration



# 3. Pins Configuration

| Pin Number | Pin Name        | Pin Type | Alternate         | Label                |
|------------|-----------------|----------|-------------------|----------------------|
| LQFP64     | (function after | , , ,    | Function(s)       | _5.00.               |
| LQIIOT     |                 |          | r driction(3)     |                      |
|            | reset)          |          |                   |                      |
| 1          | VBAT            | Power    |                   |                      |
| 2          | PC13-TAMPER-RTC | I/O      | GPIO_EXTI13       | B1 [Blue PushButton] |
| 3          | PC14-OSC32_IN   | I/O      | RCC_OSC32_IN      |                      |
| 4          | PC15-OSC32_OUT  | I/O      | RCC_OSC32_OUT     |                      |
| 5          | PD0-OSC_IN      | I/O      | RCC_OSC_IN        |                      |
| 6          | PD1-OSC_OUT     | I/O      | RCC_OSC_OUT       |                      |
| 7          | NRST            | Reset    |                   |                      |
| 12         | VSSA            | Power    |                   |                      |
| 13         | VDDA            | Power    |                   |                      |
| 16         | PA2             | I/O      | USART2_TX         | USART_TX             |
| 17         | PA3             | I/O      | USART2_RX         | USART_RX             |
| 18         | VSS             | Power    |                   |                      |
| 19         | VDD             | Power    |                   |                      |
| 20         | PA4             | I/O      | ADC1_IN4          |                      |
| 21         | PA5 *           | I/O      | GPIO_Output       | LD2 [Green Led]      |
| 22         | PA6             | I/O      | ADC1_IN6          |                      |
| 23         | PA7             | I/O      | ADC1_IN7          |                      |
| 26         | PB0             | I/O      | ADC1_IN8          |                      |
| 29         | PB10            | I/O      | USART3_TX         |                      |
| 30         | PB11            | I/O      | USART3_RX         |                      |
| 31         | VSS             | Power    |                   |                      |
| 32         | VDD             | Power    |                   |                      |
| 33         | PB12 *          | I/O      | GPIO_Output       | PB12                 |
| 42         | PA9             | I/O      | USART1_TX         | USART1_TX            |
| 43         | PA10            | I/O      | USART1_RX         | USART1_RX            |
| 46         | PA13            | I/O      | SYS_JTMS-SWDIO    | TMS                  |
| 47         | VSS             | Power    |                   | -                    |
| 48         | VDD             | Power    |                   |                      |
| 49         | PA14            | I/O      | SYS_JTCK-SWCLK    | TCK                  |
| 55         | PB3 **          | 1/0      | SYS_JTDO-TRACESWO | SWO                  |
| 60         | воото           | Boot     |                   |                      |
| 63         | VSS             | Power    |                   |                      |
| 64         | VDD             | Power    |                   |                      |

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

| ** 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                      | MX_Pig_V1.0            |  |
| Project Folder                    | F:\\code\MX_Pig_V1.0   |  |
| Toolchain / IDE                   | MDK-ARM V5.27          |  |
| Firmware Package Name and Version | STM32Cube FW_F1 V1.8.4 |  |
| Application Structure             | Advanced               |  |
| Generate Under Root               | No                     |  |
| Do not generate the main()        | No                     |  |
| Minimum Heap Size                 | 0x200                  |  |
| Minimum Stack Size                | 0x400                  |  |

### 5.2. Code Generation Settings

| Name                                                          | Value                                 |
|---------------------------------------------------------------|---------------------------------------|
| STM32Cube MCU packages and embedded software                  | 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                                    |
| Keep User Code when re-generating                             | Yes                                   |
| Delete previously generated files when not re-generated       | Yes                                   |
| Set all free pins as analog (to optimize the power            | No                                    |
| consumption)                                                  |                                       |
| Enable Full Assert                                            | No                                    |

### 5.3. Advanced Settings - Generated Function Calls

| Rank | Function Name       | Peripheral Instance Name |
|------|---------------------|--------------------------|
| 1    | MX_GPIO_Init        | GPIO                     |
| 2    | MX_DMA_Init         | DMA                      |
| 3    | SystemClock_Config  | RCC                      |
| 4    | MX_USART2_UART_Init | USART2                   |
| 5    | MX_USART1_UART_Init | USART1                   |
| 6    | MX_USART3_UART_Init | USART3                   |
| 7    | MX_ADC1_Init        | ADC1                     |
| 8    | MX_TIM3_Init        | TIM3                     |

# 6. Power Consumption Calculator report

### 6.1. Microcontroller Selection

| Series    | STM32F1       |
|-----------|---------------|
| Line      | STM32F103     |
| MCU       | STM32F103RBTx |
| Datasheet | DS5319_Rev17  |

### 6.2. Parameter Selection

| Temperature | 25  |
|-------------|-----|
| Vdd         | 3.3 |

### 6.3. Battery Selection

| Battery           | Li-SOCL2(A3400) |
|-------------------|-----------------|
| Capacity          | 3400.0 mAh      |
| Self Discharge    | 0.08 %/month    |
| Nominal Voltage   | 3.6 V           |
| Max Cont Current  | 100.0 mA        |
| Max Pulse Current | 200.0 mA        |
| Cells in series   | 1               |
| Cells in parallel | 1               |

## 6.4. Sequence

| Step                   | Step1       | Step2        |
|------------------------|-------------|--------------|
| Mode                   | RUN         | STOP         |
| Vdd                    | 3.3         | 3.3          |
| Voltage Source         | Battery     | Battery      |
| Range                  | No Scale    | No Scale     |
| Fetch Type             | FLASH       | n/a          |
| CPU Frequency          | 72 MHz      | 0 Hz         |
| Clock Configuration    | HSE PLL     | Regulator LP |
| Clock Source Frequency | 8 MHz       | 0 Hz         |
| Peripherals            |             |              |
| Additional Cons.       | 0 mA        | 0 mA         |
| Average Current        | 27 mA       | 14 µA        |
| Duration               | 0.1 ms      | 0.9 ms       |
| DMIPS                  | 90.0        | 0.0          |
| Ta Max                 | 100.99      | 105          |
| Category               | In DS Table | In DS Table  |

### 6.5. Results

| Sequence Time | 1 ms              | Average Current | 2.71 mA    |
|---------------|-------------------|-----------------|------------|
| Battery Life  | 1 month, 21 days, | Average DMIPS   | 61.0 DMIPS |
|               | 17 hours          |                 |            |

### 6.6. Chart



# 7. Peripherals and Middlewares Configuration

7.1. ADC1 mode: IN4 mode: IN6 mode: IN7 mode: IN8

mode: Temperature Sensor Channel

mode: Vrefint Channel7.1.1. Parameter Settings:

ADCs\_Common\_Settings:

Mode Independent mode

ADC\_Settings:

Data Alignment Right alignment

Scan Conversion Mode Enabled

Continuous Conversion Mode Disabled

Discontinuous Conversion Mode Enabled \*

Number Of Discontinuous Conversions 1

Number Of Discontinuous Conversions

 $ADC\_Regular\_Conversion Mode:$ 

Enable Regular Conversions Enable

Number Of Conversion 6 \*

External Trigger Conversion Source Regular Conversion launched by software

Rank 1

Channel 4

Sampling Time 71.5 Cycles \*

Rank 2 \*

Channel 6 \*
Sampling Time 71.5 Cycles \*

<u>Rank</u> 3 \*

Channel 7 \*
Sampling Time 71.5 Cycles \*

<u>Rank</u> 4 \*

Channel 8 \*
Sampling Time 71.5 Cycles \*

Rank 5 \*

Channel Temperature Sensor \*

Sampling Time 71.5 Cycles \*

<u>Rank</u> 6 \*

Channel Vrefint \*
Sampling Time
Channel Vrefint \*
71.5 Cycles \*

ADC\_Injected\_ConversionMode:

Enable Injected Conversions Disable

WatchDog:

Enable Analog WatchDog Mode false

#### 7.2. RCC

High Speed Clock (HSE): BYPASS Clock Source Low Speed Clock (LSE): Crystal/Ceramic Resonator

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

#### 7.3. SYS

**Debug: Serial Wire** 

**Timebase Source: TIM1** 

#### 7.4. TIM3

**Clock Source : Internal Clock** 

#### 7.4.1. Parameter Settings:

#### **Counter Settings:**

Prescaler (PSC - 16 bits value) 3600-1 \*

Counter Mode Up

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

Internal Clock Division (CKD)

No Division

auto-reload preload

Disable

| Trigger Output (TRGO) F | arameters: |
|-------------------------|------------|
|-------------------------|------------|

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

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

#### 7.5. **USART1**

### **Mode: Asynchronous**

### 7.5.1. Parameter Settings:

#### **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

#### 7.6. USART2

#### **Mode: Asynchronous**

#### 7.6.1. Parameter Settings:

#### **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

#### **7.7. USART3**

**Mode: Asynchronous** 

### 7.7.1. Parameter Settings:

#### **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

#### 7.8. FREERTOS

Interface: CMSIS\_V1

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

18 \*

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 Management scheme heap\_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.8.2. Include parameters:

#### Include definitions:

vTaskPrioritySet Enabled uxTaskPriorityGet Enabled vTaskDelete Enabled Disabled vTaskCleanUpResources vTaskSuspend Enabled vTaskDelayUntil Disabled vTaskDelay Enabled xTaskGetSchedulerState Enabled xTaskResumeFromISR Enabled xQueueGetMutexHolder Disabled xSemaphoreGetMutexHolder Disabled pcTaskGetTaskName Disabled uxTaskGetStackHighWaterMark Disabled xTaskGetCurrentTaskHandle Disabled eTaskGetState Disabled  $x \\ Event Group Set Bit From ISR$ Disabled xTimerPendFunctionCall Disabled xTaskAbortDelay Disabled

xTaskGetHandle Disabled

### 7.8.3. Advanced settings:

Newlib settings (see parameter description first):

USE\_NEWLIB\_REENTRANT Disabled

Project settings (see parameter description first):

Use FW pack heap file Enabled

<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                        | PA4                     | ADC1_IN4              | Analog mode                                                | n/a                         | n/a          |                      |
|                             | PA6                     | ADC1_IN6              | Analog mode                                                | n/a                         | n/a          |                      |
|                             | PA7                     | ADC1_IN7              | Analog mode                                                | n/a                         | n/a          |                      |
|                             | PB0                     | ADC1_IN8              | Analog mode                                                | n/a                         | n/a          |                      |
| RCC                         | PC14-<br>OSC32_IN       | RCC_OSC32_IN          | n/a                                                        | n/a                         | n/a          |                      |
|                             | PC15-<br>OSC32_OU<br>T  | RCC_OSC32_O<br>UT     | n/a                                                        | n/a                         | n/a          |                      |
|                             | 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          | TMS                  |
|                             | PA14                    | SYS_JTCK-<br>SWCLK    | n/a                                                        | n/a                         | n/a          | тск                  |
| USART1                      | PA9                     | USART1_TX             | Alternate Function Push Pull                               | n/a                         | High *       | USART1_TX            |
|                             | PA10                    | USART1_RX             | Input mode                                                 | No pull-up and no pull-down | n/a          | USART1_RX            |
| USART2                      | PA2                     | USART2_TX             | Alternate Function Push Pull                               | n/a                         | Low          | USART_TX             |
|                             | PA3                     | USART2_RX             | *                                                          | No pull-up and no pull-down | n/a          | USART_RX             |
| USART3                      | PB10                    | USART3_TX             | Alternate Function Push Pull                               | n/a                         | High *       |                      |
|                             | PB11                    | USART3_RX             | Input mode                                                 | No pull-up and no pull-down | n/a          |                      |
| Single<br>Mapped<br>Signals | PB3                     | SYS_JTDO-<br>TRACESWO | n/a                                                        | n/a                         | n/a          | swo                  |
| GPIO                        | PC13-<br>TAMPER-<br>RTC | GPIO_EXTI13           | External Interrupt Mode with Rising edge trigger detection | No pull-up and no pull-down | n/a          | B1 [Blue PushButton] |
|                             | PA5                     | GPIO_Output           | Output Push Pull                                           | No pull-up and no pull-down | Low          | LD2 [Green Led]      |
|                             | PB12                    | GPIO_Output           | Output Push Pull                                           | No pull-up and no pull-down | Medium *     | PB12                 |

### 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: Half Word

Memory Data Width: Half Word

# 8.3. NVIC configuration

# 8.3.1. NVIC

| 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   | 15                   | 0           |  |
| System tick timer                       | true   | 15                   | 0           |  |
| DMA1 channel1 global interrupt          | true   | 6                    | 0           |  |
| ADC1 and ADC2 global interrupts         | true   | 5                    | 0           |  |
| TIM1 update interrupt                   | true   | 0                    | 0           |  |
| TIM3 global interrupt                   | true   | 5                    | 0           |  |
| USART1 global interrupt                 | true   | 7                    | 0           |  |
| EXTI line[15:10] interrupts             | true   | 12                   | 0           |  |
| PVD interrupt through EXTI line 16      | unused |                      |             |  |
| Flash global interrupt                  | unused |                      |             |  |
| RCC global interrupt                    | unused |                      |             |  |
| USART2 global interrupt                 | unused |                      |             |  |
| USART3 global interrupt                 | unused |                      |             |  |

### 8.3.2. NVIC Code generation

| Enabled interrupt Table                 | Select for init sequence ordering | Generate IRQ<br>handler | Call HAL handler |
|-----------------------------------------|-----------------------------------|-------------------------|------------------|
| Non maskable interrupt                  | false                             | true                    | false            |
| Hard fault interrupt                    | false                             | true                    | false            |
| Memory management fault                 | false                             | true                    | false            |
| Prefetch fault, memory access fault     | false                             | true                    | false            |
| Undefined instruction or illegal state  | false                             | true                    | false            |
| System service call via SWI instruction | false                             | false                   | false            |
| Debug monitor                           | false                             | true                    | false            |
| Pendable request for system service     | false                             | false                   | false            |
| System tick timer                       | false                             | false                   | true             |
| DMA1 channel1 global interrupt          | false                             | true                    | true             |
| ADC1 and ADC2 global interrupts         | false                             | true                    | true             |
| TIM1 update interrupt                   | false                             | true                    | true             |
| TIM3 global interrupt                   | false                             | true                    | true             |

| Enabled interrupt Table     | Select for init   | Generate IRQ | Call HAL handler |
|-----------------------------|-------------------|--------------|------------------|
|                             | sequence ordering | handler      |                  |
| USART1 global interrupt     | false             | true         | true             |
| EXTI line[15:10] interrupts | false             | true         | true             |

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

# 9. System Views

- 9.1. Category view
- 9.1.1. Current





### 10. Docs & Resources

Type Link

Datasheet http://www.st.com/resource/en/datasheet/CD00161566.pdf

Reference http://www.st.com/resource/en/reference\_manual/CD00171190.pdf

manual

Programming http://www.st.com/resource/en/programming\_manual/CD00228163.pdf

manual

Programming http://www.st.com/resource/en/programming\_manual/CD00283419.pdf

manual

Errata sheet http://www.st.com/resource/en/errata\_sheet/CD00190234.pdf

Application note http://www.st.com/resource/en/application\_note/CD00160362.pdf

Application note http://www.st.com/resource/en/application\_note/CD00164185.pdf

Application note http://www.st.com/resource/en/application\_note/CD00167326.pdf

Application note http://www.st.com/resource/en/application\_note/CD00167594.pdf

Application note http://www.st.com/resource/en/application\_note/CD00211314.pdf

Application note http://www.st.com/resource/en/application\_note/CD00249778.pdf

Application note http://www.st.com/resource/en/application\_note/CD00259245.pdf

Application note http://www.st.com/resource/en/application\_note/CD00264321.pdf

Application note http://www.st.com/resource/en/application\_note/CD00264342.pdf

Application note http://www.st.com/resource/en/application\_note/CD00264379.pdf

Application note http://www.st.com/resource/en/application\_note/DM00024853.pdf

Application note http://www.st.com/resource/en/application\_note/DM00032987.pdf

Application note http://www.st.com/resource/en/application\_note/DM00033267.pdf

Application note http://www.st.com/resource/en/application\_note/DM00033344.pdf

Application note http://www.st.com/resource/en/application\_note/DM00042534.pdf

Application note http://www.st.com/resource/en/application\_note/DM00052530.pdf

Application note http://www.st.com/resource/en/application\_note/DM00073742.pdf

Application note http://www.st.com/resource/en/application\_note/DM00080497.pdf

Application note http://www.st.com/resource/en/application\_note/DM00129215.pdf

Application note http://www.st.com/resource/en/application\_note/DM00160482.pdf http://www.st.com/resource/en/application\_note/DM00156964.pdf Application note Application note http://www.st.com/resource/en/application\_note/DM00209695.pdf Application note http://www.st.com/resource/en/application\_note/DM00220769.pdf http://www.st.com/resource/en/application\_note/DM00257177.pdf Application note Application note http://www.st.com/resource/en/application\_note/DM00272912.pdf http://www.st.com/resource/en/application\_note/DM00236305.pdf Application note Application note http://www.st.com/resource/en/application\_note/DM00296349.pdf Application note http://www.st.com/resource/en/application note/DM00325582.pdf Application note http://www.st.com/resource/en/application note/DM00327191.pdf Application note http://www.st.com/resource/en/application\_note/DM00354244.pdf Application note http://www.st.com/resource/en/application\_note/DM00315319.pdf Application note http://www.st.com/resource/en/application\_note/DM00380469.pdf Application note http://www.st.com/resource/en/application\_note/DM00395696.pdf http://www.st.com/resource/en/application\_note/DM00493651.pdf Application note Application note http://www.st.com/resource/en/application\_note/DM00536349.pdf