

# STM32G0 and STM32CubeMX 5.0 Workshop



# Agenda

2

|                                |                                                              |
|--------------------------------|--------------------------------------------------------------|
| <b>8:00 AM – 9:00 AM</b>       | <b>Registration and system check for pre-installed tools</b> |
| <b>9:00 AM – 3:00 PM</b>       | STM32G0 Overview                                             |
| <b>(Lunch from 12 to 1 PM)</b> | Overview of the STM32CubeProgrammer                          |
|                                | Lab: Upload and save a binary firmware image to a file       |
|                                | STM32CubeMX 5.0 Overview                                     |
|                                | STM32Cube Library                                            |
|                                | Lab: Blink an LED by software                                |
|                                | Lab: Use hardware (PWM timer) to blink an LED                |
|                                | Lab: External Interrupt                                      |
|                                | Lab: Low power                                               |
|                                | Lab: Power Consumption Estimation                            |
|                                | Optional Lab: Utilize a printf for console output            |
|                                | Optional Lab: Low Layer Library usage                        |
|                                | Optional DMA presentation                                    |
|                                | Optional Lab: DMA                                            |
|                                | Lab: Restore original demo code firmware to the board        |

# STM32G0 MCU series

## Efficiency at its best





# STM32G0: great investment

4

## Keep releasing your growing creativity

Note ●: Cortex-M0+ Radio Co-processor



# Cortex-M Seamless scalability

Extended Performance  
*Cortex-M4 / M7*

Floating Point Unit (FPU)  
DSP (SIMD, fast MAC)

Foundation  
*Cortex-M3*

Advanced data  
processing  
Bit field  
manipulations

Budget price  
*Cortex-M0/M0+*

General data  
processing  
I/O control tasks





# Key messages of STM32G0 series

1

## Efficient

- ARM Cortex M0+ at 64MHz
- Compact cost: maximum I/Os count
- Best RAM/Flash Ratio
- Smallest possible package down to 8-pin

- Very low power consumption (3µA in stop, <100µA/MHZ in Run)
- Accurate internal high-speed clock 1% RC
- Best optimization, down to each and every detail
- Offers the best value for money

2

## Robust

- Low electromagnetic susceptibility, EMC
- Clock Monitoring and 2 Watchdogs
- Error correction on Flash

- IoT ready with embedded security
- Hardware AES-256 encryption
- New Securable Memory Area
- Safe Firmware upgrade / Install

3

## Simple

- Easy to configure thanks to the intuitive and graphical STM32CubeMX configuration tool

- Easy to develop based on the Hardware Abstraction Layer library (HAL) or the low-layer library (LL) allowing maximum re-use and faster time-to-market



## Portfolio streeeeeetched for efficient budget applications





# Reducing BOM cost

8

New platform optimized with 1 power supply pair only up to 64pin packages





# Innovations for your benefit

9

- **No external clock** -10cts  
Accurate internal high speed clock +/-1% for 0 / 85°C
- **No decoupling capacitances** -4cts  
Remove up to 6 decoupling capacitors for supply and clocks
- **Smaller PCB** -1cts  
Smaller package, less components: save on PCB area

Additional benefits for your convenience:

- **USB-C power delivery** -15cts  
Integrated transceivers, pull-up/down resistors and digital
- **Secure programming** -25cts  
In house or at 3rd parties





# Providing more performance

10

Do not compromise on performance with STM32G0



- Up to 64 MHz/ 59 DMIPS
- Up to >142 CoreMark Result
- ARM Cortex-M0+ with Memory Protection Unit (MPU)
- Flexible DMA up to 7 channels



# Low-power modes efficiency

11

## When Mainstream MCU Series meets low-power requirements

| Wake-up time | Mode                                 | Power consumption | Wake-up sources                                                                        |
|--------------|--------------------------------------|-------------------|----------------------------------------------------------------------------------------|
| VBAT         | VBAT                                 | *10 nA / 400 nA   | Tamper: few I/Os, RTC                                                                  |
| 258 µs       | SHUTDOWN                             | *40 nA / 500 nA   | Wake-up sources: reset pin, few I/Os, RTC                                              |
| 14 µs        | STANDBY                              | *200 nA / 500 nA  | Wake-up sources: + BOR, IWDG                                                           |
| 5 µs         | STOP Flash-RTC off-off/off-on/on-off | 3.0µA / 5µA / 8µA | Wake-up sources: + all I/Os, PVD, COMPs, LPUART, LPTIM, I <sup>2</sup> C, UART, USB-PD |
| 6 cycles     | SLEEP 24MHz, Vdd=3V, PLL=on          | 800 µA            | Wake-up sources: any interrupt or event                                                |
|              | RUN at 64 MHz                        | <100 µA / MHz     |                                                                                        |

Conditions: 25°C, Vdd = 3V

Note : \* without RTC / with RTC



## Faster, more accurate analog and digital functions

- More **RAM** for Flash
  - Up to 36KB SRAM for 128KB and 64KB Flash
- **Timers** frequency up to **128MHz** resolution (<8ns)
  - **Advanced control** capabilities
- **12-bit ADC** up to **2.5MSPS** (0.4 $\mu$ s) conversion time
  - **16-bit** oversampling by hardware
- **32Mbit/s SPI**, 7 Mbaud/s USART, 1Mbit/s I<sup>2</sup>C communication





**FD CAN**  
Up to 2 instances



**V<sub>BAT</sub> with RTC**  
for battery backup  
400 nA in V<sub>BAT</sub> mode  
for RTC and  
20x 32-bit backup registers



**TRNG & AES**  
for Security  
128-/256-bit AES  
key encryption hardware  
accelerator



**Comparators**  
2 instances  
Down to 30ns propagation delay



**DAC**  
2x 12-bit DAC,

**ADC**

16x12-bit, 16-bit oversampling  
2.5MSPS (0.4μs)



**Timers**  
8ns PWM resolution  
Advanced control  
16- and 32-bit

# Smart peripherals

13



**USB-C Power Delivery**  
Up to 2 ports with dead-battery management



**USB**  
USB 2.0  
Full speed  
Device / Host



**SPI / UART / I<sup>2</sup>C**

4x SPIs  
8 USARTs (ISO 7816, LIN, IrDA, modem)  
3 I<sup>2</sup>C

**I/Os** Up to 92 fast I/Os



## Save on battery life

Low consumption process and design  
Low-Power UART: wake-up on frame  
Low-Power Timer: counts and generate signals  
I<sup>2</sup>C wake-up on address



## Smart integration

14

### Always keep control Diagnose, react

Main Clock monitoring  
Backup clock and interrupts  
Voltage monitoring: programmable interrupts and reset  
Window watchdog on CPU clock  
Independent watchdog on independent clock  
Checksum by hardware  
ECC on Flash, Parity on RAM



## Save on BOM cost

+/-1% high speed clock internal from 0 to 85°C  
+/-2% high speed clock internal from -40 to 125°C  
IO maximization: smaller package footprint



## High temperature

from -40°C up to + 125°C



## More flexibility



More RAM or more safety with parity enable/disable  
Dynamic DMA assignment on DMAMUX  
All IOs with external interrupt capability

## High robustness

Highly immune to fast-transients  
Robust IOs against negative injections





# Smart applications

15

- High temperature 125°C
- Fast CPU 64MHz
- Advanced timers with high-resolution 7.8ns
- Fast comparators
- ADC-12bit, DAC-12bit
- Low-thickness packages
- AES & security for secure upgrades

## Air conditioning, e-bikes, industrial equipments

- High temperature 125°C
- CANFD support
- SPI, USART, I<sup>2</sup>C
- Advanced timers with high-resolution 7.8ns
- Real Time Clock with backup registers
- AES & security for secure upgrades



# STM32 G0 product lines

## Common peripherals and architecture:

ARM Cortex-M0+  
64MHz  
0.93 DMIPS/MHz

MPU

Communication Peripheral:  
USART, SPI, I<sup>2</sup>C

Multiple general-purpose  
16-bit timers

Integrated reset and brown-out warning

DMA channels

2x watchdogs  
Real-time clock (RTC)

Integrated regulator  
PLL and clock circuit

Main oscillator and  
32 kHz oscillator

**Internal RC oscillators**  
32kHz , 16 MHz

-40 to +125 °C

Low voltage 1.65 to 3.6 V  
(Value Line: 2.0 to 3.6V)

Temperature sensor

## STM32G0x0 – Value Line (ex: STM32G070)

Up to 512KB Flash  
Up to c- 80KB SRAM  
12-bit ADC 2.5MSPS

## STM32G0x1 – Access Line (ex: STM32G071)

Up to 512KB Flash  
Up to 80KB SRAM  
12-bit ADC 2.5MSPS  
**2x Comp 2x 12-bit DAC**  
1x 32-bit Timer  
1x 16-bit MC Timer >100MHz  
1x16-bit Timer >100MHz  
**USB-PD**  
**USB OTG 2.0 FS**  
**CAN-FD**  
Securable Memory Area

## STM32G0+11 – Access Line & Encryption (ex: STM32G081)

Up to 512KB Flash  
Up to 80KB SRAM  
12-bit ADC 2.5MSPS  
**2x Comp 2x 12-bit DAC.**  
1x 32-bit Timer  
1x 16-bit MC Timer >100MHz  
1x16-bit Timer >100MHz  
**USB-PD**  
**USB OTG 2.0 FS**  
**CAN-FD**  
Securable Memory Area  
AES TRNG

Up to +125°C



On some part-numbers



# STM32G0 Portfolio

17





## Advanced features and solutions

- Arm 32-bit Cortex-M0+ core
- 1.7 to 3.6V power supply
- RAM maximization
- 1% internal clock
- Direct Memory Access (DMA)
- Communication peripherals
- USB-C Power Delivery



- Timers up to 2xcpu resolution
- Real Time Clock
- I/O ports maximization
- ADC 12-bit Ultra-fast
- DAC 12-bit
- Comparators
- Safety features
- Advanced Security features



## No compromise on what matters

- Arm 32-bit Cortex-M0+ core
- 2.0 to 3.6V power supply
- RAM maximization
- 1% internal clock
- Direct Memory Access (DMA)
- Communication peripherals



- Timers
- Real Time Clock
- I/O ports maximization
- ADC 12-bit Ultra-fast
- Safety features



# More security

20

Integrated security features, ready for tomorrow's needs

Firmware IP protection

Mutual distrustful

Secret key storage

Authentication

Secure firmware upgrade



Securable Memory Area  
Execute-only Protection  
Read-out Protection  
Write Protection  
Memory Protection Unit (MPU)  
AES-256 / SHA-256 Encryption  
True Random Number Generator  
Unique ID

User flash

Securable  
Memory Area



Standard user flash by default

Can be secured once exiting  
No more access nor debug

Configurable size

Good fit to store critical data  
• Critical routines  
• Keys



# LQFP64 pin-to-pin comparison

21

- 9 IOs more on STM32G071 vs STM32F071

- 5 IOs more on STM32G071 vs STM32F051



51 I/Os



60 I/Os

Extra-port vs STM32F0 ☺



# Consistent and optimized pinout

22



QFP64  
QFP/QFN48  
QFP/QFN32  
QFN28



# STM32G0 ecosystem

23

Go fast, be first

## HARDWARE TOOLS

STM32 Nucleo



Flexible prototyping

Discovery kit



Key feature prototyping

Evaluation board



Full feature evaluation

## SOFTWARE TOOLS

STM32CubeMX featuring intuitive pin selection, clock tree configuration, code generation and power consumption calculation



## Platform approach or custom code: you choose



- Open-source FAT file system (FatFs)
  - Open-source real-time OS (FreeRTOS)
  - Dozens of examples
- 
- STM32G0 Hardware Abstraction Layer (HAL) portable APIs
  - **High-performance, light-weight low-layer (LL) APIs**
  - High coverage for most STM32 peripherals
  - Production-ready and fully qualified
  - Dozens of usage examples
  - Open-source BSD license





# SUMMARY 3 Keys of STM32G0 series

25

1 Efficient

2 Robust

3 Simple



# STM32CubeMX 5.0

STM32CubeMX graphical software configuration tool





- Choose ideal MCU and simply configure
  - Pinouts
  - Clocks and oscillators
  - Peripherals
  - Low-power modes
  - Middleware



## Application benefits

- Helps choose the correct MCU for a given purpose
- Simulation provides an advantage in design phase
- Boosts development speed with a headstart

- Peripheral and middleware parameters
- Power consumption calculator
- Code generation
  - Possible to re-generate code while keeping user code intact.
- Option of command-line and batch operation
- Expandable by plugins
- MCU selector
  - Filter by family, package, peripherals or memory sizes.
  - Search for similar product.
- Pinout configuration
  - Choose peripherals to use and assign GPIO and alternate functions to pins.
- Configure NVIC and DMA
- Clock tree initialization
  - Choose oscillator and set PLL and clock dividers.

# Comprehensive choice of IDEs



**STM32CubeMX**

Generate Code



**Partners IDEs**

Compile & Debug



**STMStudio**

Monitor



CooCox atollie



**Free  
IDE**



# STM32G0 – System Architecture

# STM32G071 Block diagram

## Main specification

- 1.65V to 3.6V
- 0.93 DMIPS/MHz
- **V<sub>bat</sub>** supply
- V<sub>ref+</sub> pin
- **Max ambiant temp 125°C**
- One Supply pair
- Securable Memory Area
- High sink I/Os
- <100µA/MHz run mode
- **Stand-by** <1µA @ room temperature
- Stop 5 µA @ room temperature
- **Shutdown mode**
- Low EMI SAE (2.5@24MHz)
- Robust EMC/ESD/EMS
- 28/32/48 and 64 pins

**features highlight**



# Cortex M0+ vs Cortex M0

33

- STM32G0 has been upgraded with a Cortex M0+ core bringing more security and performances

|                                            | STM32F0                            | STM32G0                            |
|--------------------------------------------|------------------------------------|------------------------------------|
| Relocatable vector table                   | No                                 | Yes                                |
| Pipeline                                   | 3 Stages                           | 2 Stages                           |
| Performance                                | 2.20 Coremark/MHz<br>(48MHz – 1WS) | 2.23 Coremark/MHz<br>(64MHz – 2WS) |
| MPU                                        | No                                 | Yes                                |
| Breakpoints                                | 4                                  | 4                                  |
| Single cycle<br>32bits x 32bits Multiplier | Yes                                | Yes                                |

# System architecture overview

34



- **Two masters:**
  - Cortex®-M0+ core
  - General-purpose DMA
- **Three slaves:**
  - Internal SRAM
  - Internal Flash memory
  - AHB with AHB-to-APB bridge that connects all the APB peripherals
- Dedicated IOPORT for accessing the GPIOs

# STM32G0 - RCC



# Main Differences with STM32F0

36

- The Reset and Clock Controller is similar to the one implemented in the STM32F0 family with some enhancements

|                                  | STM32F0        | STM32G0                     |
|----------------------------------|----------------|-----------------------------|
| NRST                             | Input & output | GPIO, Input, Input & output |
| Reset Holder                     | No             | Yes                         |
| PLL                              | One output     | Three outputs               |
| CSS on LSE + LSCO *              | No             | Yes                         |
| HSI divider to SYSCLK            | No             | Yes                         |
| Timer 1 & 15 running at 2xSYSCLK | No             | Yes                         |

\* CSS on HSE was already available for both F0 and G0 products

# Simplified clock tree

37



- Selected between HSI16, HSE, PLL, LSI, and LSE
- System clock, AHB and APB maximum frequency: 64 MHz

| Voltage range       | SYSCLK      | HSI16                | HSE         | PLL               |
|---------------------|-------------|----------------------|-------------|-------------------|
| Range 1             | 64 MHz max. | 16 MHz               | 48 MHz      | VCO max = 344 MHz |
| Range 2             | 16 MHz max. | 16 MHz               | 16 MHz      | VCO max = 128 MHz |
| Low-power run/sleep | 2 MHz max.  | Allowed with divider | Not allowed | Not allowed       |



# STM32 NUCLEO features



Flexible board power supply :  
through USB or external source

Integrated ST-Link/V2-1:  
mass storage device flash programming

2 push buttons, 2 color Leds

Arduino extension connectors :  
easy access to add-ons

One STM32 MCU flavor with 64 pins

Morpho extension headers :  
direct access to all MCU I/Os

We are now going to provide you with the STM32G0 Nucleo board.

- Connect USB ST-LINK (CN2) to your PC
  - ST-LINK driver may be installed if this is the first time the board is plugged in.
- LD1 should be **ON** and solid **RED** (indicating board power available and ST-Link is functional)





## Lab: Saving the original code

# Lab : Saving the original code

42

## Objective:

- The objective of this lab is to save the “out-of-the-box” firmware demonstration code using our stand-alone programmer:  
STM32CubeProgrammer

# STM32CubeProgrammer features

- Main Features:**

- Unify existing programming software tools :  
Merge STVP, ST-Link Utility and Bootloader softwares tools in one solution.
- Multiplatform (Windows, Linux and macOS) 
- Debug and bootloader interfaces support: ST-LINK debug probe (JTAG/SWD), Bootloader interfaces (UART, USB DFU, SPI, I<sup>2</sup>C and CAN)
- Secure programming



# Run STM32CubeProgrammer

44



# Connect to the ST-LINK

45



# Save the content of the flash

- Change the size to: 0x20000 ①
  - Equivalent to 128K which is the size of the Flash of the STM32G0 on the Nucleo board
- Then click: ②  
Read -> Save As...



# Save the content of the flash

47

- Save it to a location you will remember because we will restore it at the end of the workshop.
- Save as a binary file (\*.bin)

For example: C:\STM32G0WorkShop\HandsOn\original code\original\_code.bin



# Disconnect to the ST-LINK



# STM32Cube and STM32CubeMX

# Introduction

50



# STM32Cube





# Package organization

53



# HAL general concepts

## HAL based project organization

54



# HAL general concepts

## HAL drivers file

55

| File                      | Description                                                                                |
|---------------------------|--------------------------------------------------------------------------------------------|
| stm32g0xx_hal_ppp.c/.h    | Peripheral driver with cross family portable APIs                                          |
| stm32g0xx_hal_ppp_ex.c/.h | Extended peripheral features APIs                                                          |
| stm32g0xx_hal.c           | HAL global APIs (HAL_Init, HAL_DeInit, HAL_Delay,...)                                      |
| stm32g0xx_hal.h           | HAL header file, it should be included in user code                                        |
| stm32g0xx_hal_conf.h      | Config file for HAL, should be customized by user to select the peripherals to be included |
| stm32g0xx_hal_def.h       | Contains HAL common type definitions and macros                                            |

# Key features

56

| Layer       | Category           | Provided embedded software                                     | Provided examples                              |
|-------------|--------------------|----------------------------------------------------------------|------------------------------------------------|
| HAL         | Analog             | Analog/Digital conversion, ...                                 | ~66 examples<br>on ST evaluation boards* !     |
|             | Timers             | Timers, RTC, Watchdogs, ...                                    |                                                |
|             | Connectivity       | I2C, USART, SPI, I2S, SDMMC, CEC, ...                          |                                                |
| Middleware  | RTOS               | FreeRTOS open source RTOS, with CMSIS-RTOS wrapper             | ~10 applications<br>on ST evaluation boards* ! |
|             | USB Power Delivery | PD stack, device policy manager, policy engine, protocol layer |                                                |
|             | File System        | FatFS open-source file system                                  |                                                |
| Application | Demonstration      | Full demonstrations for ST boards                              | ~1 demonstration project for ST boards!        |

# Examples overview (1/2)

57

- For each board, a set of examples is provided with preconfigured projects for EWARM, MDK-ARM and SW4STM32 toolchains
  - This figure shows the projects structure for the NUCLEO-G071RB board, which is identical for other boards
  - The examples are classified depending on the STM32Cube level they apply to, and are named as follows:
    - Examples in Level 0 are called **Examples**, and use HAL drivers without any middleware component
    - Examples in Level 1 are called **Applications**, and provide typical use cases of each middleware component
    - Examples in Level 2 are called **Demonstration**, and implement all the HAL, BSP and middleware components



# Examples overview (2/2)

58

- The Template project is provided to build quickly any firmware application for all supported boards
- All examples have the same structure,
  - \Inc folder contains all header files
  - \Src folder for the source code
  - \EWARM, \MDK-ARM and \SW4STM32 contain the preconfigured project for each toolchain
  - readme.txt describes example behavior and the environment needed to make it work
  - \*.ioc file that allows user to open most of FW examples within STM32CubeMX (starting from STM32CubeMX 5.0)

# STM32CubeMX



- Choose ideal MCU and simply configure

- Pinouts
- Clocks and oscillators
- Peripherals
- Low-power modes
- Middleware



## Application benefits

- Helps choose the correct MCU for a given purpose
- Simulation provides an advantage in design phase
- Boosts development speed with a headstart

# Prerequisites and settings

61

- STM32CubeMX needs Java RE
  - Check release notes of the particular version for additional requirements
  - Multiplatform tool runs on Windows, Linux and macOS
- After installation, hit Alt+S to configure the updater – not only for the GUI but also for Cube FW libraries
- Select SW library placement.



- Updates are accessible from the Help menu
- The tool updater can detect new releases of the tool and the associated Cube library
- Use the libraries manager to download new library packages



# MCU selector

63

- Find MCU by name ...
  - Quickly locate by Series and Lines
- ... or application needs
  - Package (pin count)
  - RAM size
  - NV memory requirements
  - Embedded peripherals
  - Number and type of interfaces
  - Core and frequency
  - Price
- Convenient links to documentation
- Export table to Excel file

The screenshot shows the STM32 MCU Selector tool. At the top, there's a navigation bar with tabs for "MCU Selector" (which is active) and "Board Selector". Below the navigation bar is a "MCU Filters" section with various search and filter options. A "Part Number Search" input field is present, along with filters for "Core", "Series", "Line", "Package", "Other", and "Advanced Graphic". Under "Peripheral", there's a list of supported peripherals with counts: ADC 12-bit (0), ADC 16-bit (0), AES (0), CAN (0), COMP (0), CRYP (0), DAC 12-bit (0), DCMI (0), DFSDM (0), DSIHOST (0), Ethernet (0), FDCAN (0), FMC (0), FMP/I2C (0), FSMC (0), GFXMMU (0), HASH (0), HDMI CEC (0), HMAC (0), HRTIM (0), I2C (0), I2S (0), IRTIM (0), JPEG (0), LPTIM (0), and LPUART (0). To the right, a detailed product page for the STM32G070RB is displayed, featuring a thumbnail of the chip, its package (LQFP64), and its features. Below this is a table titled "MCUs List: 40 items" showing a list of 40 different STM32 MCUs, each with columns for Part No., Market, Board, Package, Flash, RAM, IO, Freq., and GFX Score.

| * | Part No     | Market... | Board         | Package  | Flash      | RAM       | IO | Freq.  | GFX Score |
|---|-------------|-----------|---------------|----------|------------|-----------|----|--------|-----------|
| ★ | STM32G070KB | ...       | ...           | LQFP32   | 128 kBytes | 36 kBytes | 30 | 64 MHz | 0.0       |
| ★ | STM32G070RB | ...       | NUCLEO-G070RB | LQFP64   | 128 kBytes | 36 kBytes | 60 | 64 MHz | 0.0       |
| ★ | STM32G071C6 | ...       | ...           | LQFP48   | 32 kBytes  | 36 kBytes | 44 | 64 MHz | 0.0       |
| ★ | STM32G071C6 | ...       | ...           | UFQFPN48 | 32 kBytes  | 36 kBytes | 44 | 64 MHz | 0.0       |
| ★ | STM32G071C8 | ...       | ...           | LQFP48   | 64 kBytes  | 36 kBytes | 44 | 64 MHz | 0.0       |
| ★ | STM32G071C8 | ...       | ...           | UFQFPN48 | 64 kBytes  | 36 kBytes | 44 | 64 MHz | 0.0       |
| ★ | STM32G071CB | ...       | ...           | LQFP48   | 128 kBytes | 36 kBytes | 44 | 64 MHz | 0.0       |
| ★ | STM32G071CB | ...       | ...           | UFQFPN48 | 128 kBytes | 36 kBytes | 44 | 64 MHz | 0.0       |
| ★ | STM32G071EB | ...       | ...           | WL CSP25 | 128 kBytes | 36 kBytes | 23 | 64 MHz | 0.0       |
| ★ | STM32G071G6 | ...       | ...           | UFQFPN28 | 32 kBytes  | 36 kBytes | 26 | 64 MHz | 0.0       |
| ★ | STM32G071G8 | ...       | ...           | UFQFPN28 | 64 kBytes  | 36 kBytes | 26 | 64 MHz | 0.0       |
| ★ | STM32G071G8 | ...       | ...           | UFQFPN28 | 64 kBytes  | 36 kBytes | 26 | 64 MHz | 0.0       |
| ★ | STM32G071GB | ...       | ...           | UFQFPN28 | 128 kBytes | 36 kBytes | 26 | 64 MHz | 0.0       |
| ★ | STM32G071GB | ...       | ...           | UFQFPN28 | 128 kBytes | 36 kBytes | 26 | 64 MHz | 0.0       |
| ★ | STM32G071K6 | ...       | ...           | LQFP32   | 32 kBytes  | 36 kBytes | 30 | 64 MHz | 0.0       |
| ★ | STM32G071K6 | ...       | ...           | UFQFPN32 | 32 kBytes  | 36 kBytes | 30 | 64 MHz | 0.0       |
| ★ | STM32G071K8 | ...       | ...           | LQFP32   | 64 kBytes  | 36 kBytes | 30 | 64 MHz | 0.0       |
| ★ | STM32G071K8 | ...       | ...           | LQFP32   | 64 kBytes  | 36 kBytes | 30 | 64 MHz | 0.0       |
| ★ | STM32G071K8 | ...       | ...           | UFQFPN32 | 64 kBytes  | 36 kBytes | 30 | 64 MHz | 0.0       |
| ★ | STM32G071K8 | ...       | ...           | UFQFPN32 | 64 kBytes  | 36 kBytes | 30 | 64 MHz | 0.0       |

# Pin assignment

64

- Pinout from:
  - Peripheral tree
  - Manually
- Automatic signal remapping
- Management of dependencies between peripherals and/or middleware (FatFS, USB ...)



# Pin assignment continued

Peripheral is not available, all its alternate pins are assigned elsewhere

Orange means the peripheral is not enabled, only the pin is assigned

Click on the pin  
to view  
alternate  
functions

Freeze the signal placement using the pin icon



# Peripheral and Middleware configuration

- Global view of used peripherals and middleware
- Highlight of configuration errors
  - + Not configured
  - ✓ OK
  - ⚠ Non-blocking problem
  - ✗ Error



# Middleware configuration

- Presents options specific to each supported software component
- All settings are organized in logical groups
- Description and constraints are available for quick reference



# Peripheral configuration

68

- All available initialization parameters are presented with short description and options
- Interrupt may be assigned to peripherals
- DMA may be associated, where applicable
- GPIO settings for peripherals with input and/or output



# NVIC configuration panel

69

- Single control panel for all interrupts
- Manage priorities and sub-priorities
- Searching, filtering and sorting interrupts in the list
- Code generation tab allows to customize interrupt initialization

The screenshot shows the STM32CubeMX software interface for the STM32G071RB Nucleo board. The main window title is "STM32CubeMX STM32G0.ioc: STM32G071RBTx NUCLEO-G071RB". The top menu bar includes File, Window, Help, and social media links. The toolbar has a "GENERATE CODE" button. The navigation bar shows "Home / STM32G071RBTx - NUCLEO-G071RB / STM32G0.ioc - Pinout & Configuration". The main content area has tabs for Pinout & Configuration, Clock Configuration, Project Manager, and Tools. The Pinout & Configuration tab is active, showing the "NVIC Mode and Configuration" section. It features a search bar, a table titled "NVIC Interrupt Table", and checkboxes for "Sort by Preemption Priority and Sub Priority" and "Show only enabled interrupts". The table lists various interrupt sources with their enable status, preemption priority, and FreeRTOS usage. The sidebar on the left lists categories like System Core (DMA, GPIO, IWDG, NVIC), Analog (ADC1, COMP1, COMP2, DAC1), and Timers (LPTIM1, LPTIM2, RTC, TIM1, TIM2, TIM3, TIM6, TIM7, TIM14, TIM15). The bottom of the table view has checkboxes for Enabled, Preemption Priority, and Uses FreeRTOS functions.

| Interrupt Source                                                                             | Enabled                             | Preemption Prior... | Uses FreeRTOS functions             |
|----------------------------------------------------------------------------------------------|-------------------------------------|---------------------|-------------------------------------|
| Non maskable interrupt                                                                       | <input checked="" type="checkbox"/> | 0                   | <input type="checkbox"/>            |
| Hard fault interrupt                                                                         | <input checked="" type="checkbox"/> | 0                   | <input type="checkbox"/>            |
| System service call via SWI instruction                                                      | <input checked="" type="checkbox"/> | 0                   | <input checked="" type="checkbox"/> |
| Pendable request for system service                                                          | <input checked="" type="checkbox"/> | 3                   | <input checked="" type="checkbox"/> |
| Time base: System tick timer                                                                 | <input checked="" type="checkbox"/> | 3                   | <input checked="" type="checkbox"/> |
| PVD interrupt through EXTI line 16                                                           | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| Flash global interrupt                                                                       | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| RCC global interrupt                                                                         | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| UCPD1 and UCPD2 interrupts / UCPD1 and UCPD2 wake-up interrupts through EXTI lines 32 and 33 | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| TIM6, DAC1 and LPTIM1 interrupts (LPTIM1 interrupt through EXTI line 29)                     | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| TIM7 and LPTIM2 interrupts (LPTIM2 interrupt through EXTI line 30)                           | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| I2C2 global interrupt                                                                        | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| SPI1 global interrupt                                                                        | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| SPI2 global interrupt                                                                        | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| USART1 global interrupt / USART1 wake-up interrupt through EXTI line 25                      | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| USART2 global interrupt / USART2 wake-up interrupt through EXTI line 26                      | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| USART3, USART4 and LPUART1 interrupts / LPUART1 wake-up interrupt through EXTI line 28       | <input type="checkbox"/>            | 3                   | <input checked="" type="checkbox"/> |
| HDMI-CEC global interrupt / HDMI-CEC wake-up interrupt through EXTI line 27                  | <input checked="" type="checkbox"/> | 3                   | <input checked="" type="checkbox"/> |

# DMA configuration panel

70

- Manages all DMA requests including memory to memory
- Configure direction, priority and other settings

The screenshot shows the STM32CubeMX software interface for the STM32G071RBTx NUCLEO-G071RB. The main window is titled "STM32CubeMX STM32G0.ioc\* STM32G071RBTx NUCLEO-G071RB". The top menu bar includes File, Window, Help, and social media links. The toolbar has a "GENERATE CODE" button. The left sidebar has a tree view with categories: System Core (DMA selected), Analog, and Timers. The main configuration area is titled "Pinout & Configuration" and shows a table for DMA1 settings:

| DMA Request | Channel        | Direction            | Priority |
|-------------|----------------|----------------------|----------|
| LPUART1_RX  | DMA1 Channel 1 | Peripheral To Memory | Low      |

Below the table are sections for "DMA Request Settings" (Mode: Normal, Increment Address: , Peripheral: , Memory: ) and "DMA Request Generator Settings" (Request generation Signal, Signal polarity, Request number). The bottom section is "DMA Request Synchronization Settings" (Enable synchronization: , Synchronization signal, Signal polarity, Enable event: , Request number).

# Code generation

71

- Generate all the initialization code in C
- Generates project file for any supported development toolchain
- User code can be added in dedicated sections and will be kept upon regeneration
- Option to use the latest library version or keep the same even if regenerating



The screenshot shows a code editor window titled "main.c". The code is structured with several sections marked by comments:

```
124  /* Private user code -----  
125  /* USER CODE BEGIN 0 */  
126  
127  /* USER CODE END 0 */  
128  
129  /**  
130  * @brief  The application entry point  
131  * @retval int  
132  */  
133  int main(void)  
134  {  
135      /* USER CODE BEGIN 1 */  
136  
137      /* USER CODE END 1 */  
138  
139      /* MCU Configuration-----  
140  
141      /* Reset of all peripherals, Initializes the Flash interface of the  
142      HAL_Init();  
143  
144      /* USER CODE BEGIN Init */  
145  
146      /* USER CODE END Init */  
147
```

A blue speech bubble on the right side of the screen contains the text: "Write your code here to keep option to regenerate the project".

# Clock configuration

72

- Immediate display of all clock values
- Active and inactive clock paths are differentiated
- Management of clock constraints and features



# Code generation project settings

- Name your project when saving
- Browse for project location
- Pick the preferred toolchain
- Review the exact MCU type and library version



# Code generation options

- Library package
  - Whole library or the necessary part may be copied to the generated project folder
  - Or keep the library in original place and refer to it from all projects
- Generated files
  - Each peripheral initialized in separate file or in common source file
  - Options for working with old files
  - **The option to keep user code intact is here**
- HAL settings
  - Setting available pins to analog reduces power consumption, but be careful to **explicitly select SWD/JTAG in pinout**
  - Full assert is useful for debugging



# PCC (Power Consumption Calculator)

STM32CubeMX STM32G0.ioc\*: STM32G071RBTx NUCLEO-G071RB

File Window Help

STM32 CubeMX Home / STM32G071RBTx - NUCLEO-G071RB / STM32G0.ioc - Tools GENERATE CODE

**General PCC configuration panel**

**Sequence configuration**

**Result overview**

**Power Sequence Configuration**

| Step | Mode         | V <sub>DD</sub> | Range/Scale | Memory                | CPU/Bus Freq | Clock Config     | Peripherals | Step Current | Duration |
|------|--------------|-----------------|-------------|-----------------------|--------------|------------------|-------------|--------------|----------|
| 1    | RUN          | 3.0             | Range1-High | FLASH                 | 64 MHz       | HSE BYP PLL      |             | 6.25 mA      | 1 ms     |
| 2    | SLEEP        | 3.0             | Range1-High | FLASH                 | 64 MHz       | HSI PLL          |             | 1.85 mA      | 1 ms     |
| 3    | RUN          | 3.0             | Range1-High | SRAM1 Flash-PowerDown | 48 MHz       | HSI BYP PLL      |             | 4.9 mA       | 1 ms     |
| 4    | LOWPOWER_RUN | 3.0             | NoRange     | SRAM1 Flash-PowerDown | 1 MHz        | HSI Regulator_LP |             | 225 µA       | 1 ms     |
| 5    | STOP0        | 3.0             | NoRange     | Flash-PowerDown       | 16 MHz       | HSI              |             | 100 µA       | 1 ms     |

**Consumption Profile by Step**

The graph displays the consumption profile over time. The Y-axis represents Consumption in mA, ranging from 0.0 to 6.5. The X-axis represents Time in ms, ranging from 0.00 to 5.25. The consumption levels for each step are as follows:

- Step 1: RUN (0.00 to 1.00 ms) - Consumption ~6.25 mA
- Step 2: SLEEP (1.00 to 1.50 ms) - Consumption ~2.25 mA
- Step 3: RUN (1.50 to 2.00 ms) - Consumption ~4.9 mA
- Step 4: LP\_RUN (2.00 to 3.00 ms) - Consumption ~0.25 mA
- Step 5: STOP0 (3.00 to 4.00 ms) - Consumption ~0.05 mA

Legend: Idd by Step (Red line), Average Current (Blue line)

Sequence Time / Ta Max 5 ms / 128.78 °C  
Battery Life Estimation No battery selected!

Average Consumption 2.66 mA  
Average DMIPS 55.31 DMIPS

# PCC - Sequence consumption profile display

76

- It's possible to detach the charts to external display for presentation purposes
- Several different views selectable
  - Plot current vs time
  - Pie chart
  - Consumption of peripherals



# Generating Project Report Files

77

- An optional step is to generate a PDF report
- The PDF report is also available without PCC
- Complete saved project work includes:
  - Project.ioc
  - Project.pcs
  - Project.pdf
  - Project.txt
  - Project.jpg
  - ... and the generated project for a supported development environment

STM32G0 Project Configuration Report

## 6. Power Consumption Calculator report

### 6.1. Microcontroller Selection

|           |               |
|-----------|---------------|
| Series    | STM32G0       |
| Line      | STM32G0x1     |
| MCU       | STM32G071RBTx |
| Datasheet | DS12232 Rev0  |

### 6.2. Parameter Selection

|             |     |
|-------------|-----|
| Temperature | 25  |
| Vdd         | 3.0 |

### 6.3. Battery Selection

|                   |                              |
|-------------------|------------------------------|
| Battery           | Li-MnO <sub>2</sub> (CR1225) |
| Capacity          | 48.0 mAh                     |
| Self Discharge    | 0.12 %/month                 |
| Nominal Voltage   | 3.0 V                        |
| Max Cont Current  | 1.0 mA                       |
| Max Pulse Current | 5.0 mA                       |
| Cells in series   | 1                            |
| Cells in parallel | 1                            |

# Lab: Blinky



## Objective:

- The objective of this lab is to generate a very simple project using STM32CubeMX Software.
- In this example we are going to blink one of the LEDs present on the STM32G0 Nucleo board, connected to PA5 of the STM32G0 MCU.

# Run STM32CubeMX

80



The screenshot shows the STM32CubeMX software interface. At the top, there is a toolbar with icons for file operations, a search bar, and social media links for Facebook, YouTube, Twitter, and LinkedIn. The main menu includes 'File', 'Window', and 'Help'. A blue arrow points from the 'MX' icon in the bottom-left corner towards the software window.

**Existing Projects**

**Recent Opened Projects**

- stm32g0\_nucleo.ioc MX  
Last modified date : 10/12/2018 23:35:33
- test1.ioc MX  
Last modified date : 10/12/2018 15:49:41
- test\_g0\_atollic.ioc MX  
Last modified date : 29/11/2018 22:45:01

**New Project**

I need to :

- Start My project from MCU ... ACCESS TO MCU SELECTOR
- Start My project from STBo... ACCESS TO BOARD SELECTOR

**Manage software installations**

Check for STM32CubeMX and embedded software pac... CHECK FOR UPDATES

Install or remove embedded software packages INSTALL / REMOVE

**Wireless and ultra-low-power MCU**  
State-of-the-art RF performance

 STM32WB

- Dual-core
- Dual-protocol
- Key storage
- BOM saving



# Step 1: Create New Project



- Click Access To MCU Selector 1
- Type: “stm32g071rb” in the Part Number Search 2
- Then Select **STM32G071RBTx**
  - LQFP64, 128kB Flash 3
- Double Click

| Part No.      | Reference    | Mark. | Unit Price for 10k. | Board         | Package          | Flash           | RAM             | I/O    | Freq.  | GFX Sc. | HMAC | MDS | SHA |
|---------------|--------------|-------|---------------------|---------------|------------------|-----------------|-----------------|--------|--------|---------|------|-----|-----|
| STM32G071RB   | STM32G071RBx | 0.0   | 0.0                 | OPBG04        | LQFP64           | 128 kB... 36 kB | 60              | 64 MHz | 0.0    | 0       | 0    | 0   | 0   |
| STM32G071RBTx | Active       | 1.49  | 1.49                | NUCLEO-G071RB | STM32G071B-DISCO | LQFP64          | 128 kB... 36 kB | 60     | 64 MHz | 0.0     | 0    | 0   | 0   |

# Step 2: Pin Configuration

82

- In this example we are going to use one of the LEDs present on the STM32G0 Nucleo board (connected to PA5 as seen in the schematic below)
- Search for **PA5** in the search window at the bottom right 
- Left-click **PA5** and set it to **GPIO\_Output** mode



# Step 3: Generate Source Code

- Open Project Manager



- Set the project name (**blinky**) and the project location (**C:\STM32G0Workshop\HandsOn**)

Project Settings

Project Name  
blinky

Project Location  
C:\STM32G0Workshop\HandsOn

- Set the IDE Toolchain to **MDK-ARM V5**



- Generate Code



**Note:** STM32CubeMX projects have an *.ioc* file extension

Linker Settings

Minimum Heap Size 0x200

Minimum Stack Size 0x400

Mcu and Firmware Package

Mcu Reference

STM32G071RBTx

- Free licenses for STM32 devices based on Cortex-M0/M0+ cores :
  - Applicable immediately to all **STM32G0**, STM32F0 and STM32L0 MCUs.
  - PC-locked multi-year licenses.
  - No code size limit.
  - Multiple language support.
  - Technical support included.
- Direct download from Keil website :
  - No limit of number of downloads by customer.
  - Direct access to configuration files for STM32 and associated boards.
  - Free access to MDK-ARM periodic updates.

- To get a free MDK-ARM license for STM32F0, STM32L0 and **STM32G0**:

- Go to Keil website at : [www.keil.com/mdk-st](http://www.keil.com/mdk-st)
- Download MDK-ARM tool chain.
- Activate the free license using this Product Serial Number (PSN) :  
**4PPFW-QBEHZ-M0D5M**

# Inside Keil uVision (ARM-MDK)



# The MDK-ARM IDE Debugger



# Step 4: Toggle The LED

87

In the Keil uVision5 IDE:

- Expand the file tree and open the **main.c** file
- Add the following code **inside the while(1) loop in “main.c” between the “USER CODE BEGIN WHILE” and “USER CODE END WHILE”**

```
HAL_GPIO_TogglePin(GPIOA, GPIO_PIN_5);  
HAL_Delay(100);
```



```
/* Infinite loop */  
/* USER CODE BEGIN WHILE */  
while (1)  
{  
    HAL_GPIO_TogglePin(GPIOA, GPIO_PIN_5);  
    HAL_Delay(100);  
    /* USER CODE END WHILE */
```

Note: Code within the “USER CODE BEGIN WHILE” / “USER CODE END WHILE” section will be preserved after regeneration by STM3CubeMX.

**IMPORTANT NOTE:** The code to be added for the labs is located in a text file called:  
**“code\_to\_add\_vx.x.txt”**, copying from the presentation may not work properly.

**TIP:** You can do a search of the USER CODE section where to add the code in Keil using shortcut:  
CTRL +F or Edit -> Find...

# Step 5: Build the Project and Debug

- Click the “Build” button (F7)



- Click the “Start/Stop Debug Session” button (Ctrl + F5)



# Step 5: Build the Project

89

- If you see this warning message due to a minor Syntax error in the startup file, just press OK to continue.



Note: To correct the Syntax error in the startup\_stm32g071x.s:

- Remove "<h2><center>&copy;" from line 17.
- Remove "</center></h2>" from line 18.

- Click the “Run” button (F5)



- Enjoy the flashing Green LED (LD4)!



# Firmware Project Overview

# Project Overview

91

- **startup\_stm32g071xx.s**
  - System initialization, vector table, reset and jump to main()
- **User files**
  - main.c (program entry point)
  - stm32g0xx\_hal\_msp.c (micro specific peripheral initialization and de-initialization functions)
  - stm32g0xx\_it.c (Peripheral interrupt handlers)
- **HAL driver files**
  - Peripheral source files
- **system\_stm32g0xx.c**
  - Contains SystemInit() function called at startup before branch to main()
  - Contains core clock variable (HCLK)
  - SystemCoreClockUpdate() function



- Main Characteristics

- Initializes stack pointer
- Contains the device vector table
- Contains Reset handler
  - Called after RESET
  - Calls SystemInit()
  - Branch to main()

```
; ****
;* File Name      : startup_stm32g071xx.s
;* Author        : MCD Application Team
;* Description   : STM32G071xx devices vector table for MDK-ARM toolchain.
;*
;*               This module performs:
;*               - Set the initial SP
;*               - Set the initial PC == Reset_Handler
;*               - Set the vector table entries with the exceptions ISR address
;*               - Branches to __main in the C library (which eventually
;*                 calls main()).
;*
;*               After Reset the CortexM0 processor is in Thread mode,
;*               priority is Privileged, and the Stack is set to Main.
;* <<< Use Configuration Wizard in Context Menu >>>
; ****
```

```
; Vector Table Mapped to Address 0 at Reset
AREA    RESET, DATA, READONLY
EXPORT  __Vectors
EXPORT  __Vectors_End
EXPORT  __Vectors_Size

__Vectors    DCD    __initial_sp           ; Top of Stack
             DCD    Reset_Handler         ; Reset Handler
             DCD    NMI_Handler          ; NMI Handler
             DCD    HardFault_Handler    ; Hard Fault Handler
```

```
; Reset handler routine
Reset_Handler    PROC
                  EXPORT Reset_Handler          [WEAK]
IMPORT  __main
IMPORT  SystemInit
                  LDR     R0, =SystemInit
                  BLX     R0
                  LDR     R0, =__main
                  BX      R0
ENDP
```

- **SystemInit():**

- This function is called at startup after reset and before branch to main.

## SystemInit()

```
/**  
 * @brief  Setup the microcontroller system.  
 * @param  None  
 * @retval None  
 */  
void SystemInit(void)  
{  
    /* Configure the Vector Table location add offset address -----*/  
    #ifdef VECT_TAB_SRAM  
        SCB->VTOR = SRAM_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal SRAM */  
    #else  
        SCB->VTOR = FLASH_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal FLASH */  
    #endif  
}
```

- Header files

- Main.h

- main() function

- Configures system clock
- Call peripheral config. functions
- Infinite loop

- Configuration functions

- SystemClock\_Config()
- MX\_GPIO\_Init()

```
/* Includes --
#include "main.h"

int main(void)
{
    /* USER CODE BEGIN 1 */

    /* USER CODE END 1 */

    /* MCU Configuration-----*/
    /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
    HAL_Init();

    /* USER CODE BEGIN Init */

    /* USER CODE END Init */

    /* Configure the system clock */
    SystemClock_Config();

    /* USER CODE BEGIN SysInit */

    /* USER CODE END SysInit */

    /* Initialize all configured peripherals */
    MX_GPIO_Init();
}
```

```
static void MX_GPIO_Init(void)
{
    GPIO_InitTypeDef GPIO_InitStruct = {0};

    /* GPIO Ports Clock Enable */
    __HAL_RCC_GPIOA_CLK_ENABLE();

    /*Configure GPIO pin Output Level */
    HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_RESET);

    /*Configure GPIO pin : PA5 */
    GPIO_InitStruct.Pin = GPIO_PIN_5;
    GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
    GPIO_InitStruct.Pull = GPIO_NOPULL;
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
    HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
}
```

```
/**
 * @brief System Clock Configuration
 * @retval None
 */
void SystemClock_Config(void)
{
    RCC_OscInitTypeDef RCC_OscInitStruct = {0};
    RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};

    /**Configure the main internal regulator output voltage
    */
    HAL_PWREX_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1);
    /**Initializes the CPU, AHB and APB busses clocks
    */
    RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
    RCC_OscInitStruct.HSIClockState = RCC_HSI_ON;
    RCC_OscInitStruct.HSIDiv = RCC_HSI_DIV1;
    RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
    RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
    if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
    {
        Error_Handler();
    }
}
```

# Example HAL driver file

- `stm32g0xx_hal_gpio.c`
  - GPIO Initialize and De-Initialize API functions
  - GPIO Read and Write API function
  - GPIO EXTI IRQ handler
  - GPIO Callback function

```
void HAL_GPIO_Init(GPIO_TypeDef *GPIOx, GPIO_InitTypeDef *GPIO_InitStruct)
{
    uint32_t position = 0x00u;
```

```
GPIO_PinState HAL_GPIO_ReadPin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin)
{
    GPIO_PinState bitstatus;
```

```
void HAL_GPIO_EXTI_IRQHandler(uint16_t GPIO_Pin)
{
    /* EXTI line interrupt detected */
    if (__HAL_GPIO_EXTI_GET_RISING_IT(GPIO_Pin) != 0x00u)
    {
        __HAL_GPIO_EXTI_CLEAR_RISING_IT(GPIO_Pin);
        HAL_GPIO_EXTI_Rising_Callback(GPIO_Pin);
    }

    if (__HAL_GPIO_EXTI_GET_FALLING_IT(GPIO_Pin) != 0x00u)
    {
        __HAL_GPIO_EXTI_CLEAR_FALLING_IT(GPIO_Pin);
        HAL_GPIO_EXTI_Falling_Callback(GPIO_Pin);
    }
}
```

```
weak void HAL_GPIO_EXTI_Rising_Callback(uint16_t GPIO_Pin)
{
    /* Prevent unused argument(s) compilation warning */
    UNUSED(GPIO_Pin);

    /* NOTE: This function should not be modified, when the callback is needed,
       the HAL_GPIO_EXTI_Callback could be implemented in the user file
    */
}
```

# Lab: PWM (Pulse Width Modulation) Timer

## Objective:

- Now let's use a more advanced peripheral like the Timer.
- In this lab we are going to configure a Timer in a PWM mode to blink the LED that we previously controlled with a GPIO.
- PA5 has an alternate Timer channel alternate function which is Timer 2 Channel 1: TIM2\_CH1 that we will be using.

# Timer - Overview

98



- Multiple timer units providing timing resources

- Internally (triggers and time-bases)
- Externally, for outputs or inputs:
  - For waveform generation (PWM)
  - For signal monitoring or measurement (frequency or timing)

## Application benefits

- Versatile operating modes reducing CPU burden and minimizing interfacing circuitry needs
- A single architecture for all timer instances offers scalability and ease-of-use
- Also fully featured for motor control and digital power conversion applications

# STM32G0 timer instance features

| Feature            |        | TIM1<br>(Advanced Control)                                                                                   | TIM2                                                                                  | TIM3   | TIM6    | TIM7        | TIM14                                                   | TIM15                        | TIM16                        | TIM17 |  |  |
|--------------------|--------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--------|---------|-------------|---------------------------------------------------------|------------------------------|------------------------------|-------|--|--|
|                    |        |                                                                                                              | (General-Purpose)                                                                     |        | (Basic) |             | (General-Purpose)                                       |                              |                              |       |  |  |
| Clock source       |        | CK_INT<br>External input pin<br>External trigger input ETR                                                   | CK_INT<br>External input pin<br>External trigger input ETR<br>Internal trigger inputs |        | CK_INT  | CK_INT      | CK_INT<br>External input pin<br>Internal trigger inputs | CK_INT<br>External input pin | CK_INT<br>External input pin |       |  |  |
| Resolution         |        | 16-bit                                                                                                       | 32-bit                                                                                | 16-bit | 16-bit  | 16-bit      | 16-bit                                                  |                              |                              |       |  |  |
| Prescaler          |        | 16-bit                                                                                                       |                                                                                       |        |         |             |                                                         |                              |                              |       |  |  |
| Counter direction  |        | Up, Down, Up&Down                                                                                            | Up, Down, Up&Down                                                                     |        | Up      | Up          | Up                                                      |                              |                              |       |  |  |
| Repetition counter |        | ✓                                                                                                            | -                                                                                     |        | -       | -           | ✓                                                       |                              |                              |       |  |  |
| Synchronization    | Master | ✓                                                                                                            | ✓                                                                                     |        | ✓       | ✓           | ✓                                                       |                              |                              |       |  |  |
|                    | Slave  | ✓                                                                                                            | ✓                                                                                     |        | -       | -           | ✓                                                       | -                            |                              |       |  |  |
| Number of channels |        | 6:<br>➤ CH1/CH1N<br>➤ CH2/CH2N<br>➤ CH3/CH3N<br>➤ CH4<br>➤ CH5 and CH6 output only, not available externally | 4:<br>➤ CH1<br>➤ CH2<br>➤ CH3<br>➤ CH4                                                |        | 0       | 1:<br>➤ CH1 | 2:<br>➤ CH1/CH1N<br>➤ CH2                               | 1:<br>➤ CH1/CH1N             |                              |       |  |  |
| Trigger input      |        | ✓                                                                                                            | ✓                                                                                     |        |         |             |                                                         |                              |                              |       |  |  |

# STM32G0 timer instance features

100

| Feature                      | TIM1<br>(Advanced Control)                                           | TIM2                               | TIM3 | TIM6     | TIM7     | TIM14           | TIM15           | TIM16           | TIM17           |
|------------------------------|----------------------------------------------------------------------|------------------------------------|------|----------|----------|-----------------|-----------------|-----------------|-----------------|
| Input capture mode           | ✓                                                                    | ✓                                  | -    | ✓        | ✓        | ✓               | ✓               | ✓               | ✓               |
| PWM input mode               | ✓                                                                    | ✓                                  | -    | ✓        | ✓        | ✓               | ✓               | -               | ✓               |
| Forced output mode           | ✓                                                                    | ✓                                  | -    | ✓        | ✓        | ✓               | ✓               | ✓               | ✓               |
| Output compare mode          | ✓                                                                    | ✓                                  | -    | ✓        | ✓        | ✓               | ✓               | ✓               | ✓               |
| PWM                          | Standard<br>Asymmetric<br>Combined<br>Combined 3-phase<br>6-step PWM | Standard<br>Asymmetric<br>Combined | -    | Standard | Standard | Standard        | Standard        | Standard        | Standard        |
| Programmable dead-time       | ✓ (CH1-3)                                                            | -                                  | -    | -        | -        | ✓ (CH1)         | ✓ (CH1)         | -               | -               |
| Break inputs                 | 2 bidirectional                                                      | 0                                  | 0    | 0        | 0        | 1 bidirectional | 1 bidirectional | 1 bidirectional | 1 bidirectional |
| One-Pulse Mode               | ✓                                                                    | ✓                                  | -    | ✓        | ✓        | ✓               | ✓               | ✓               | ✓               |
| Retriggerable one pulse mode | ✓                                                                    | ✓                                  | -    | ✓        | -        | ✓               | ✓               | ✓               | ✓               |
| Encoder interface mode       | ✓                                                                    | ✓                                  | -    | ✓        | -        | ✓               | ✓               | ✓               | ✓               |
| Timer input XOR function     | ✓                                                                    | -                                  | -    | -        | -        | ✓               | ✓               | ✓               | ✓               |
| DMA                          | ✓                                                                    | ✓                                  | ✓    | ✓        | ✓        | -               | ✓               | ✓               | ✓               |

## Multiple internal or external clocking options

- Timers 1 and 15 are clocked up to 128 MHz to bring additional resolution below 8 ns
  - Finer resolution for buck converters (10-bit accuracy @ 100 kHz PWM)
  - Lower frequency steps for variable frequency resonant converters (e.g. LLC), e.g. 0.4kHz max. frequency step at 200 kHz switching (0.2%)
- Uses cases
  - Timer 1 has 3 complementary pairs: LLC primary and secondary sides (synchronous rectification), boundary conduction mode PFC, buck
  - Timer 15 has one pair only (buck, LLC primary side)

- Support of incremental / quadrature encoders and motor drive applications

- Up- and down-counting modes supported
  - On TIM1, TIM2 and TIM3
- Center-aligned PWM generation
  - Direction changes on overflow and underflow
  - Reduces acoustic noise in electric motors
- Built-in support of quadrature encoders
  - Rotary encoder / digital potentiometer
  - Position sensor
  - Allows direct angle reading in timer



## A variety of PWM modes to address multiple applications

- Basic PWM, edge- or center-aligned



Edge-aligned PWM



Center-aligned PWM

- Asymmetric center-aligned PWM



Asymmetric PWM



Phase-shifted PWM  
(asymmetric mode)

# Some more PWM modes

104

Extends the PWM capabilities and avoids external glue logic

- Combined PWM mode
  - Combines two channels with OR or AND function for more complex waveforms
- Combined 3-phase mode
  - Allows a 4<sup>th</sup> PWM to be combined with a regular 3-phase PWM for zero vector insertion



## For PWM signals requiring external control

- Variable-frequency PWM
  - Driven by an external signal
- Cycle-by-cycle controlled duty cycle
  - For current loops, driven by comparator or external pin



Variable frequency  
Fixed ON time PWM



Cycle-by-cycle controlled PWM

# Lab: Rename the project

106

- Close Keil uVision5 IDE if it is open
- Open the last STM32CubeMX project (“**blinky**”) (using File->Recent Projects) and save it as a **new project** name “**pwm**” (using File -> Save Project As) as seen below:



# Lab: Timer 2 CH1 Configuration

107

- In this STM32CubeMX project we are going to add Timer 2 Channel 1 to blink LD4 (PA5) on the Nucleo board.
- In the **Pinout & Configuration** tab, Expand **Timers** Categories, then click on **TIM2** peripheral and set Channel1 to “**PWM Generation CH1**”.



# Remapping Timer 2 CH1 output to PA5

108

- By default the tool will configure Timer 2 CH1 to **PA0**
- We want to remap it to **PA5**
  - NOTE: PA5 is connected to LD4
- Hold “**Ctrl**” button and left mouse click on **PA0**
- Then drag the mouse pointer to **PA5** and then release



# Timer Parameters Calculation

109

- We want the Timer's PWM output channel to be:
  - T = 1 second period (1 Hz)
  - D = 50% duty cycle (0.5)
- Timer input clock frequency (**TPCLK**) is set to 8 MHz.
- **Prescaler** for the Timer is set to **128**. The resulting timer counter clock is:  
$$CK_{CNT} = TPCLK / Prescaler = 8MHz / 128 = 62500 \text{ Hz}$$
- To get T=1 Hz (or 1 sec period) the **Counter Period** needs to be set to: **62500**
  - Counter Period =  $CK_{CNT} / T = 62500 / 1 = 62500$
- To get D=50% duty cycle the **Pulse** needs to be set to: **31250**
  - Pulse = Counter Period / 2 =  $62500 / 2 = 31250$

# Clock Tree Configuration

110

STM32CubeMX pwm.ioc: STM32G071RBTx



File

Window

Help



Home

/ STM32G071RBTx

/ pwm.ioc - Clock Configuration

GENERATE CODE

Pinout &amp; Configuration

Clock Configuration

Project Manager

Tools



# TIM2 Configuration – 4 steps

- Select the Pinout & Configuration
- In Parameters Settings of the TIM2 ①
  - Configure 1 Hz timer
    - PSC Prescaler -1 = 127 ②
    - Counter Period = 62500 ③
  - Set CH1 PWM
    - Pulse = 31250 ④



# Generate Source Code

112

- Generate Code



- Click Open Project

- Open the **main.c**, Add the following code before the **while(1)** loop in order to start the PWM Timer:

Note : within “USER CODE BEGIN 2” / “USER CODE END 2” section

```
HAL_TIM_PWM_Start(&htim2, TIM_CHANNEL_1);
```

```
/* USER CODE BEGIN 2 */  
HAL_TIM_PWM_Start(&htim2, TIM_CHANNEL_1);  
/* USER CODE END 2 */
```

# Build the Project

113

- Click the “Build” button



- Click the “Start/Stop Debug Session” button



- Click “Run” button



- Enjoy the flashing LED (LD4)!
  - LD4 is flashing using the PWM Timer

# Lab: NVIC + External Interrupts

## Objective:

- In this project we are going to configure the GPIO that is connected to the user button as External Interrupt (EXTI) with rising edge trigger.
- We will also configure the Interrupt Controller: the NVIC.

- Wake-up from Stop mode, interrupts and events generation
  - Independent interrupt and event masks
- Configurable events
  - Active edge selection
  - Dedicated pending flag
  - Triggerable by software
  - Linked to:
    - GPIO, PVD, and COMPx
- Direct events
  - Status flag provided by related peripheral
  - Linked to:
    - RTC, TAMP, I2C1, USARTx, CEC, LPUART1, LPTIMx, LSE\_CSS and UCPDx

# EXTI - block diagram

117



# EXTI - lines mapping

118

| EXTI line | Line source    | Line type    |
|-----------|----------------|--------------|
| 0-15      | GPIO           | Configurable |
| 16        | PVD output     | Configurable |
| 17        | COMP1 output   | Configurable |
| 18        | COMP2 output   | Configurable |
| 19        | RTC            | Direct       |
| 20        | Reserved       | Direct       |
| 21        | TAMP           | Direct       |
| 22        | Reserved       | Direct       |
| 23        | I2C1 wakeup    | Direct       |
| 24        | Reserved       | Direct       |
| 25        | USART1 wakeup  | Direct       |
| 26        | USART2 wakeup  | Direct       |
| 27        | CEC wakeup     | Direct       |
| 28        | LPUART1 wakeup | Direct       |
| 29        | LPTIM1         | Direct       |
| 30        | LPTIM2         | Direct       |
| 31        | LSE_CSS        | Direct       |
| 32        | UCPD1 wakeup   | Direct       |
| 33        | UCPD2 wakeup   | Direct       |

- The NVIC (Nested vector Interrupt Controller) is integrated in the Cortex®-M0+ CPU:
  - 32 maskable interrupt channels
  - 4 programmable priority levels
  - Low-latency exception and interrupt handling
  - Power management control

## Application benefits

- Supports prioritization levels with dynamic control
- Fast response to interrupt requests
- Relocatable vector table

# Lab: Pinout Configuration

- Close Keil uVision5 IDE if it is open; Open the “**blinky**” STM32CubeMX project (using File->Recent Projects) and save it as a new project named “**exti**”.
- Add configuration of the IO that is connected to the User Button (connected to **PC13**) to toggle the LED LD4 (connected to **PA5**) on the STM32G0 Nucleo board.



- **PA5** is already configured as **GPIO** output push-pull.
- Left-click on **PC13** and set it to **GPIO\_EXTI13** mode.

# GPIO Configuration

- Select **GPIO** under **System View** ①
- Click on Pin Name **PC13** ②
- Make sure GPIO mode is “**External Interrupt Mode** with Rising edge trigger detection” ③



- Select **NVIC** under **System View**



- Enable “**EXTI line 4 to 15 interrupts**” (by checking the box) ①

| NVIC Mode and Configuration                         |                                              |                                 |                              |
|-----------------------------------------------------|----------------------------------------------|---------------------------------|------------------------------|
| Configuration                                       |                                              |                                 |                              |
| NVIC                                                |                                              | Code generation                 |                              |
| <input type="checkbox"/>                            | Sort by Preemption Priority and Sub Priority | <input type="checkbox"/>        | Show only enabled interrupts |
| Search <input type="text" value="Search (Ctrl+F)"/> | <input type="button" value=""/>              | <input type="button" value=""/> |                              |
| NVIC Interrupt Table                                | Enabled                                      | Preemption Priority             |                              |
| Non maskable interrupt                              | <input checked="" type="checkbox"/>          | 0                               |                              |
| Hard fault interrupt                                | <input checked="" type="checkbox"/>          | 0                               |                              |
| System service call via SWI instruction             | <input checked="" type="checkbox"/>          | 0                               |                              |
| Pendable request for system service                 | <input checked="" type="checkbox"/>          | 0                               |                              |
| Time base: System tick timer                        | <input checked="" type="checkbox"/>          | 0                               |                              |
| PVD interrupt through EXTI line 16                  | <input type="checkbox"/>                     | 0                               |                              |
| Flash global interrupt                              | <input type="checkbox"/>                     | 0                               |                              |
| RCC global interrupt                                | <input type="checkbox"/>                     | 0                               |                              |
| EXTI line 4 to 15 interrupts                        | <input checked="" type="checkbox"/>          | 0                               |                              |

# Generate Source Code

123

- Generate Code



- Click Open Project



- Open **main.c**, add the following code:

- within “USER CODE BEGIN PV” / “USER CODE END PV” section

```
uint8_t PC13_flag = 0;
```

```
/* USER CODE BEGIN PV */  
uint8_t PC13_flag=0;  
/* USER CODE END PV */
```

# Add EXTI Rising Edge Callback Function

124

- Also in **main.c** add the following code,
  - within “USER CODE BEGIN 4” / “USER CODE END 4” section

```
void HAL_GPIO_EXTI_Rising_Callback(uint16_t GPIO_Pin)
{
    PC13_flag++;
    if ((PC13_flag & 0x01) == 0x01)
    {
        HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_SET);
    }
    else
    {
        HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_RESET);
    }
}
```

```
/* USER CODE BEGIN 4 */
void HAL_GPIO_EXTI_Rising_Callback(uint16_t GPIO_Pin)
{
    PC13_flag++;
    if ((PC13_flag & 0x01) == 0x01)
    {
        HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_SET);
    }
    else
    {
        HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_RESET);
    }
/* USER CODE END 4 */
```

# Build the Project

125

- Click the “Build” button



- Click the “Start/Stop Debug Session” button



- Click “Run” button



- Push the Blue “USER” button to toggle the LED LD4!

# Lab: Low Power



## Objective:

- In this lab we are going use the STOP 1 mode and wakeup from RTC which is configured to wakeup the STM32 every 5 seconds.
- When the STM32 wakes up it will turn on the LED (LD4) for one second and then go back to STOP mode.
- The MCU can also wake-up using the user button which is configured as EXTI.

# Low Power Modes

|                         |                        |                   |
|-------------------------|------------------------|-------------------|
| Wakeup time             | RUN (Range1) at 64 MHz | 100 $\mu$ A / MHz |
|                         | RUN (Range2) at 16 MHz | 93 $\mu$ A / MHz  |
|                         | LPRUN at 2 MHz         | 90 $\mu$ A / MHz  |
|                         | SLEEP at 16 MHz        | 42 $\mu$ A / MHz  |
|                         | LPSLEEP at 2 MHz       | 32 $\mu$ A / MHz  |
|                         | STOP 0                 | 100 $\mu$ A       |
|                         | STOP 1                 | 4.1 $\mu$ A*      |
|                         | STANDBY + SRAM         | 320 nA/670 nA*    |
|                         | STANDBY                | 130 nA/480 nA*    |
|                         | SHUTDOWN               | 40 nA/380 nA*     |
| VBAT                    |                        | 340 nA*           |
| Typ @ VDD = 3 V @ 25 °C |                        |                   |
| * : with RTC            |                        |                   |

## FlexPowerControl

- Efficient running
- 7 low-power modes, several sub-modes
- High flexibility

## Application benefits

- High performance  
→ CoreMark score = 142.88
- Outstanding power efficiency

## Lowest power modes with full retention, 5 µs wakeup time to 16 MHz

- SRAM and all peripheral registers retention
  - All high-speed clocks are stopped
  - Flash can be switched OFF
- LSE (32.768 kHz external oscillator) and LSI (32 kHz internal oscillator) can be enabled
- Several peripherals can be active and wake up from Stop modes
- System clock at wakeup is HSI16 (2 µs wakeup time on RAM, 5.5µs on FLASH not powered)
- Stop 1 is equivalent to Stop 0 with Main Regulator off, resulting in a smaller current consumption but longer wake up time

# Stop 0 mode

130

## Available peripherals

|                |
|----------------|
| GPIO           |
| DMA            |
| <b>BOR</b>     |
| PVD            |
| USART          |
| LP UART        |
| <b>I2C 1</b>   |
| I2C 2          |
| SPI            |
| ADC            |
| <b>DAC</b>     |
| <b>COMP</b>    |
| Temp Sensor    |
| Timers         |
| <b>LPTIM 1</b> |
| <b>LPTIM 2</b> |
| <b>IWDG</b>    |
| WWDG           |
| Systick Timer  |
| <b>UCPD</b>    |
| RNG            |
| AES            |
| CRC            |
| <b>CEC</b>     |

I/Os kept, and configurable



## Available clocks

|              |
|--------------|
| <b>HSI16</b> |
| HSE          |
| <b>LSI</b>   |
| <b>LSE</b>   |

Active cell

97  $\mu$ A @ 3.0 V

## Wakeup time to 16 MHz:

- In SRAM: 2  $\mu$ s
- In Flash ON: 2  $\mu$ s
- In Flash OFF: 5.5  $\mu$ s

## Main regulator (MR)

Range 1 (up to 64 MHz)

Range 2 (up to 16 MHz)

Low Power regulator (LPR) up to 2 MHz

## Backup domain

Backup Register (5x32 bits)

RTC & TAMPER

## Wake-up event

|                     |
|---------------------|
| NRST                |
| <b>BOR</b>          |
| PVD                 |
| <b>RTC + Tamper</b> |
| USART               |
| LP UART             |
| <b>I2C 1</b>        |
| CEC                 |
| <b>COMP</b>         |
| <b>LPTIM 1</b>      |
| <b>LPTIM 2</b>      |
| <b>IWDG</b>         |
| GPIOs               |

Cell in power-down

Available Periph and clock

# Stop 1 mode

131

## Available peripherals

|                |
|----------------|
| GPIO           |
| DMA            |
| <b>BOR</b>     |
| PVD            |
| USART          |
| LP UART        |
| <b>I2C 1</b>   |
| I2C 2          |
| SPI            |
| ADC            |
| <b>DAC</b>     |
| <b>COMP</b>    |
| Temp Sensor    |
| Timers         |
| <b>LPTIM 1</b> |
| <b>LPTIM 2</b> |
| <b>IWDG</b>    |
| WWDG           |
| Systick Timer  |
| <b>UCPD</b>    |
| RNG            |
| AES            |
| CRC            |
| <b>CEC</b>     |

I/Os kept, and configurable



Cortex M0+



Available  
clocks

|              |
|--------------|
| <b>HSI16</b> |
| HSE          |
| <b>LSI</b>   |
| <b>LSE</b>   |

Active cell

Flash memory not powered:

- w/o RTC: 1.3  $\mu$ A @ 3.0 V
- w/ RTC: 4.1  $\mu$ A @ 3.0 V
- Flash memory powered:
- w/o RTC: 7.0  $\mu$ A @ 3.0 V

Main regulator (MR)

Low Power regulator (LPR) up to 2 MHz

Backup domain

Backup Register (5x32 bits)

RTC & TAMPER

Wakeup time to 16 MHz:

- In SRAM: 5  $\mu$ s
- In Flash ON: 5  $\mu$ s
- In Flash OFF: 9  $\mu$ s

Wake-up event

|                     |
|---------------------|
| NRST                |
| <b>BOR</b>          |
| PVD                 |
| <b>RTC + Tamper</b> |
| USART               |
| LP UART             |
| <b>I2C 1</b>        |
| CEC                 |
| <b>COMP</b>         |
| <b>LPTIM 1</b>      |
| <b>LPTIM 2</b>      |
| <b>IWDG</b>         |
| GPIOs               |

Cell in power-down

Available Periph and clock



- The RTC provides an ultra-low-power hardware calendar with alarms, in all low-power modes
- It belongs to the Battery Backup Domain, so it is kept functional when the main supply is off and VBAT is present
- The TAMP peripheral features the backup registers and tamper detection

## Application benefits

- Ultra-low power: 300 nA at 1.8 V
- Hardware BCD calendar to reduce software load

- Sub-seconds, seconds, minutes, hours, week day, date, month, year in BCD format
- “On the fly” programmable daylight savings compensation
- Two programmable alarms with wakeup interrupt function
- A periodic event with programmable resolution, triggering wakeup interrupt
- A reference clock source (50 or 60 Hz) can be used to enhance the calendar precision
- Digital calibration circuit to achieve 0.95 ppm accuracy
- Timestamp feature which can be used to save the calendar content with sub-second precision (one event)

# RTC - Block diagram

134



- RTC not affected by system reset when clocked by LSE

# Lab: Low Power

- Close Keil uVision5 IDE if it is open; In STM32CubeMX open the “exti” STM32CubeMX project save it as a new project like “lowpower”.

# Enable LSE (Low Speed External) Clock

136

- We are going to use the 32 KHz Crystal that is on the Nucleo board (see schematic below) to clock the RTC:



- In the **Pinout & Configuration** tab, expand **RCC** (in **System Core**) and choose Crystal/Ceramic Resonator for Low Speed Clock (LSE) clock:



# Enable and Configure the RTC

137

- In the **Pinout & Configuration** tab, under **Timers**, expand **RTC**



- Check the **Activate Clock Source**

- Select **Internal Wakeup** for the **Wakeup mode**

RTC Mode and Configuration

Mode

Activate Clock Source

Activate Calendar

Alarm A

Alarm B

Timestamp

WakeUp

Tamper 1

Tamper 2

Calibration

Reference clock detection

# Choose RTC clock source

138

- In the **Clock Configuration** tab, select **LSE** as input clock for **RTC**



Note: For applications that do not require precise RTC timings the LSI (Low Speed Internal RC) can be used to clock the RTC

## Wakeup Counter Calculation:

- To configure the wake up timer for 5s, the WakeUpCounter should be set to **10246** as calculated below:
- With RTC Clock set to **RTCCLK /16**
- Wakeup Time Base =  $\text{RTC\_PRESCALER} / \text{LSE} = 16 / (32.768\text{KHz}) = 0.488 \text{ ms}$
- Wakeup Time = Wakeup Time Base \* WakeUpCounter =  $0.488\text{ms} * \text{WakeUpCounter}$   
==> WakeUpCounter =  $5\text{s} / 0.488\text{ms} = 10246$

- Based on previous calculation we will configure the RTC
- In the **Pinout & Configuration** tab, click on **RTC** (under Timers category)
- Enter the following configuration:



# Enable Interrupts

141

- In the **Configuration** tab, go to **NVIC settings** and then enable the interrupt for **RTC**:



- In the “System View” in the NVIC, check that both RTC and EXTI[4…15] are enabled, if not re-enable them both:

| NVIC Mode and Configuration                          |                                              |                        |
|------------------------------------------------------|----------------------------------------------|------------------------|
| Configuration                                        |                                              |                        |
| NVIC                                                 | Code generation                              |                        |
| <input type="checkbox"/>                             | Sort by Preemption Priority and Sub Priority |                        |
| Search <input type="text" value="Search (Ctrl+F)"/>  | <input type="button"/>                       | <input type="button"/> |
| <input type="checkbox"/>                             | Show only enabled interrupts                 |                        |
| NVIC Interrupt Table                                 |                                              |                        |
|                                                      | Enabled                                      | Preemption Priority    |
| Non maskable interrupt                               | <input checked="" type="checkbox"/>          | 0                      |
| Hard fault interrupt                                 | <input checked="" type="checkbox"/>          | 0                      |
| System service call via SWI instruction              | <input checked="" type="checkbox"/>          | 0                      |
| Pendable request for system service                  | <input checked="" type="checkbox"/>          | 0                      |
| Time base: System tick timer                         | <input checked="" type="checkbox"/>          | 0                      |
| PVD interrupt through EXTI line 16                   | <input type="checkbox"/>                     | 0                      |
| RTC and TAMP interrupts through EXTI lines 19 and 21 | <input checked="" type="checkbox"/>          | 0                      |
| Flash global interrupt                               | <input type="checkbox"/>                     | 0                      |
| RCC global interrupt                                 | <input type="checkbox"/>                     | 0                      |
| EXTI line 4 to 15 interrupts                         | <input checked="" type="checkbox"/>          | 0                      |

# Generate Source Code

142

- Generate Code



- Click Open Project



# Add code – to main function

143

- Open the **main.c**, add the following code in the **while(1)** loop of the main function in the **USER CODE WHILE** section:

```
/* USER CODE BEGIN WHILE */
while (1)
{
    HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_SET);
    HAL_Delay(1000);
    HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_RESET);

    // enter STOP mode
    HAL_PWR_EnterSTOPMode(PWR_LOWPOWERREGULATOR_ON, PWR_STOPENTRY_WFI);

    // reconfigure system clock
    SystemClock_Config();
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
}
/* USER CODE END 3 */
```

```
/* Infinite loop */
/* USER CODE BEGIN WHILE */
while (1)
{
    HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_SET);
    HAL_Delay(1000);
    HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_RESET);

    // enter STOP mode
    HAL_PWR_EnterSTOPMode(PWR_LOWPOWERREGULATOR_ON, PWR_STOPENTRY_WFI);

    // reconfigure system clock
    SystemClock_Config();
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
}
/* USER CODE END 3 */
```

# Add code – to init function

144

- Open the **stm32g0xx\_hal\_msp.c** (under Application/User), Add the following line of code (marked in red below) to the msp init function HAL\_RTC\_MspInit():

```
void HAL_RTC_MspInit(RTC_HandleTypeDef* hrtc)
{
    if(hrtc->Instance==RTC)
    {
        /* USER CODE BEGIN RTC_MspInit 0 */

        /* USER CODE END RTC_MspInit 0 */
        /* Peripheral clock enable */
        __HAL_RCC RTC_ENABLE();
        /* RTC interrupt Init */
        HAL_NVIC_SetPriority(RTC_TAMP IRQn, 0, 0);
        HAL_NVIC_EnableIRQ(RTC_TAMP IRQn);
        /* USER CODE BEGIN RTC_MspInit 1 */
        __HAL_RCC RTCAPB_CLK_ENABLE();
        /* USER CODE END RTC_MspInit 1 */
    }
}
```



```
main.c      stm32g0xx_hal_msp.c      startup_stm32g071xx.s
/*
 * @brief RTC MSP Initialization
 * This function configures the hardware resources
 * @param hrtc: RTC handle pointer
 * @retval None
 */
void HAL_RTC_MspInit(RTC_HandleTypeDef* hrtc)
{
    if(hrtc->Instance==RTC)
    {
        /* USER CODE BEGIN RTC_MspInit 0 */

        /* USER CODE END RTC_MspInit 0 */
        /* Peripheral clock enable */
        __HAL_RCC RTC_ENABLE();
        /* RTC interrupt Init */
        HAL_NVIC_SetPriority(RTC_TAMP IRQn, 0, 0);
        HAL_NVIC_EnableIRQ(RTC_TAMP IRQn);
        /* USER CODE BEGIN RTC_MspInit 1 */
        __HAL_RCC RTCAPB_CLK_ENABLE();
        /* USER CODE END RTC_MspInit 1 */
    }
}
```

# Build the Project

145

- Click the “Build” button; or use menu Project > Build target.



- Click the “Load” button (F8) to flash the code into the STM32 (not using the debug session because we are using low power modes)



- Press Reset on your board (black button) once the code is loaded and the application will work as follows:
  - RUN mode for 1 second (LD4 LED on)
  - STOP mode for 5 seconds (LD4 LED off) with wakeup by RTC
  - If during the STOP mode (LD4 LED off) you press the user button: the interrupt (EXTI) will wakeup from STOP mode

# Lab: Estimation of power consumption

# Lab: Estimation of power consumption

147

## Objective:

- Use the Power tool inside the STM32CubeMX to estimate the average power consumption of the low power lab we just finished.

# Power Supply and Power Source Selection

148

- Using the “**lowpower**” project in STM32CubeMX

- Click on the **Tools** tab in STM32CubeMX



- Select **3V** for **VDD**



- In the **Battery Selection** section, select **AA Alkaline batteries (2 in series, 1 in parallel)** as the power source for the application



- Add a step to our power sequence:

- Click: Step.. Add



- Configure a first step: RUN mode

1

- Mode: Run
- Power Range: Range2 -Medium
- Memory Fetch Type: Flash
- VDD: 3.0
- Voltage Source: Battery

2

- CPU Frequency: 16 MHz
- Clock Configuration: HSI

3

- Enable IPs from Pinout function

4

- Duration: 1 second

5

- Click "Add"

# Adding a RUN mode step



- Add a step to our power sequence:

- Click: Step.. Add



- Add a second step: STOP1 mode

- 1
  - Power Mode: STOP1
  - Fetch Type: Flash -PowerDown
  - VDD: 3V
- 2
  - Clocks HSI 16 MHz
- 3
  - RTC enabled (to wakeup the system)
- 4
  - Step Duration: 5 seconds
- 5
  - Click "Add"
  - Resulting step consumption should be 3.4 uA

# Add a STOP1 mode step

150

**MX New Step**

Enable All IPs  Disable All IPs  Enable IPs from Pinout

**Power/Memory**

Power Mode: STOP1  
Power Range: NoRange  
Memory Fetch Type: Flash-PowerDown  
V<sub>DD</sub>: 3.0  
Voltage Source: Battery

**Clocks**

CPU Frequency: 16 MHz  
Interpolation Ranges:  
User Choice (Hz):  
Clock Configuration: HSI  
Clock Source Frequency: 16 MHz

**Optional Settings**

Step Duration: 5 s  
Additional Consumption: 0 mA

**Results**

Step Consumption: 3.4  $\mu$ A  
Without Peripherals: 3.4  $\mu$ A  
Peripherals Part: 0 nA (A: 0 nA - D: 0 nA)  
Ta Max (°C): 130

**Warnings**

**Enabled Peripherals**

Peripherals Selection

IWDG\*  
 LPTIM1\*  
 LPTIM2\*  
 RTC\*

**Add** **Cancel**

# Add a Wakeup from STOP1 mode step

151

- Add a last step: Wakeup from STOP1 mode

- 1
  - Power Mode: WU\_FROM\_STOP1
  - VDD = 3V
  - Voltage source: Battery

- 2
  - Click "Add"

- Resulting step consumption should be 1.21 mA

1

2

OK Cancel

**Edit Step**

Enable All IPs | Disable All IPs | Enable IPs from Pinout

Power/Memory

Power Mode: WU\_FROM\_STOP1

Power Range: NoRange

Memory Fetch Type: Flash-PowerDown

V<sub>DD</sub>: 3.0

Voltage Source: Battery

Clocks

CPU Frequency: 16 MHz

Interpolation Ranges:

User Choice (Hz):

Clock Configuration: HSI

Clock Source Frequency: 16 MHz

Optional Settings

Wakeup time: 9.0 µs

Additional Consumption: 0 mA

Results

Step Consumption: 1.21 mA

Without Peripherals: 1.21 mA

Peripherals Part: 0 nA (A: 0 nA - D: 0 nA)

T<sub>a</sub> Max (°C): 129.76

Warnings

Peripherals Selection

Enabled...

Peripherals

# Average Current Consumption Result

- Note: the Current consumption numbers are for the MCU only.



## Optional Lab: printf() debugging using UART

# Lab: printf() debugging using UART

154

## Objective:

- Redirect Printf output to LPUART1 which is connected to the ST-LINK Virtual COM port on the Nucleo board
- Using a Terminal like Teraterm we can view the printf output.

# printf() debugging settings overview

155



LPUART1 debug will be used via the ST-LINK Virtual-COM port

Set up additional GPIO / Clocks:

PA2 – LPUART1, “LPUART1-TX”

PA3 – LPUART1, “LPUART1-RX”

LPUART1 Clock = PCLK1 (64MHz)

LPUART1 settings:

Asynchronous Mode - 115200 N/8/1, No HW Flow control  
Tx/Rx, No advanced features

Teraterm Terminal will be used to display the printf output

LPUART1 is routed to the ST-LINK’s USART, and brought via the USB Virtual-COM port class (SB16/18 located on the back on the board have been soldered)

# STM32G0 USART/LPUART features

156

| USART features                                     | USART1/2        | USART3/4 | LPUART1 |
|----------------------------------------------------|-----------------|----------|---------|
| <b>Hardware flow control for modem</b>             | X               | X        | X       |
| <b>Multiprocessor communication</b>                | X               | X        | X       |
| <b>Synchronous mode (Slave/Master)</b>             | X               | X        | -       |
| <b>Smartcard mode</b>                              | X               | -        | -       |
| <b>Single wire half duplex communication</b>       | X               | X        | X       |
| <b>IrDA SIR ENDEC</b>                              | X               | -        | -       |
| <b>LIN mode</b>                                    | X               | -        | -       |
| <b>Dual clock domain and wakeup from Stop mode</b> | X               | -        | X       |
| <b>Receiver timeout</b>                            | X               | -        | -       |
| <b>Auto baudrate detection</b>                     | X               | -        | -       |
| <b>Driver enable</b>                               | X               | X        | X       |
| <b>Data length</b>                                 | 7, 8 and 9 bits |          |         |
| <b>TX/RX FIFO</b>                                  | X               | -        | X       |
| <b>TX/RX FIFO size (data word)</b>                 | 8               | -        | 8       |

- Transmit FIFO (TXFIFO) and Receive FIFO (RXFIFO)
- Transmission/Reception even during stop modes
- FIFO mode is enabled/disabled by software
- TXFIFO and RXFIFO are each 8 data words in length
- Adjustable TXFIFO and RXFIFO interrupt request thresholds

- LPUART (Low Power Universal Asynchronous Receiver/Transmitter)
  - Full UART communication at 9600 baud with wakeup from stop modes capability when using the low-speed 32.768 kHz external oscillator (LSE).
- Higher baud rates are available with other clock sources.



## Application benefits

- Inexpensive communication link between devices
- Simple hardware, only a few pins needed
- Wakes from low-power STOP modes
- Transmit and Receive FIFOs, with capability to transmit and receive in stop modes.

# LPUART Block diagram

159



# Create New Project

160

- In STM32CubeMX, click “Home”
- Click Access To MCU Selector ①



- Select **STM32G071RBTx** ②
  - LQFP64, 128KB Flash
- Double Click ③

MCU Selector / Board Selector

Part Number Search: stm32g071rb

Core: STM32G0

Series: STM32G0

Check/Uncheck All:  STM32G0

Line: STM32G0

Package: LQFP64

Other: Price From 0.0 to 1.49, IO = 60, Eeprom = 0 (Bytes), Flash = 128 (kBytes), Ram = 36 (kBytes), Freq. = 64 (MHz)

**STM32G071RB**  
Mainstream Arm Cortex-M0+ MCU with 128 Kbytes of Flash memory memory, 36 Kbytes RAM, 64 MHz CPU, 4x USART, timers, ADC, DAC, comm. I/F, 1.65-3.6V  
ACTIVE Active Product is in mass production  
Unit Price for 10kU (US\$) : 1.49  
Boards: NUCLEO-G071RB - STM32G071B-DISCO  
LQFP64

| Part No.     | Reference     | Mark.  | Unit Price for 10k. | Board         | Package          | Flash           | RAM             | I/O    | Freq.  | GFX Sc. | HMAC | MDS | SHA |
|--------------|---------------|--------|---------------------|---------------|------------------|-----------------|-----------------|--------|--------|---------|------|-----|-----|
| STM32G071... | STM32G071RBx  |        | 0.0                 | OPBG04        | LQFP64           | 128 kB... 36 kB | 60              | 64 MHz | 0.0    | 0       | 0    | 0   | 0   |
| STM32G071... | STM32G071RBTx | Active | 1.49                | NUCLEO-G071RB | STM32G071B-DISCO | LQFP64          | 128 kB... 36 kB | 60     | 64 MHz | 0.0     | 0    | 0   | 0   |

# GPIO Configuration additions

- Click on **LPUART1** dialog (under Connectivity), and select **Asynchronous** mode:



- Use PA2 & PA3 for Tx / Rx pins:
  - These are the alternate mapping pins (PC0/PC1 are default)
  - So need to remap



# Clock Configuration

162

- Run the STM32G0 at 64 MHz for this lab, the LPUART1 clock also at 64 MHz.



- Click on the Configuration tab and select LPUART1

- Parameter Settings tab

- 115200 Bits/s
- 8-bit word length
- No parity bit
- 1 Stop bit
- Keep Default settings for the rest



# Generate Source Code

164

- Open Project Manager



- Set the project name (`printf`) and the project location  
**(C:\STM32G0Workshop\STM32G0\HandsOn)**
- Set the IDE Toolchain to **MDK-ARM V5**



- Generate Code
- Click Open Project



# Adding printf redirecting code in main.c

165

## 1- Add the stdio include:

```
/* USER CODE BEGIN Includes */  
#include <stdio.h>  
/* USER CODE END Includes */
```

```
/* Private includes -----  
/* USER CODE BEGIN Includes */  
#include <stdio.h>  
/* USER CODE END Includes */
```

## 2- Add following code in the section below:

```
/* USER CODE BEGIN PFP */  
/* Private function prototypes -----*/  
#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)  
/* USER CODE END PFP */
```

```
/* USER CODE BEGIN PFP */  
#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)  
/* USER CODE END PFP */
```

## 3- Add following function in the section below:

```
/* USER CODE BEGIN 4 */  
PUTCHAR_PROTOTYPE  
{  
    HAL_UART_Transmit(&hlpuart1, (uint8_t *)&ch, 1, 0xFFFF);  
    return ch;  
}  
/* USER CODE END 4 */
```

```
/* USER CODE BEGIN 4 */  
PUTCHAR_PROTOTYPE  
{  
    HAL_UART_Transmit(&hlpuart1, (uint8_t *)&ch, 1, 0xFFFF);  
    return ch;  
}  
/* USER CODE END 4 */
```

# Adding application code in main.c

166

Add application code in main loop:

```
/* USER CODE BEGIN WHILE */
while (1)
{
    printf("** Hello World ** \n\r");
    HAL_Delay(1000);
/* USER CODE END WHILE */
```

```
/* Infinite loop */
/* USER CODE BEGIN WHILE */
while (1)
{
    printf("** Hello World ** \n\r");
    HAL_Delay(1000);

    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
}
/* USER CODE END 3 */
```

# Build the Project and run the application

- Click the “Build” button; or use menu Project > Build target.
- Click the “Start/Stop Debug Session” button
- Click “Run” button
- Open a Terminal emulator like Teraterm, using LPUART1 settings, connect ST-LINK Virtual COM port xx



- You should see the printf message being displayed.



# STM32Cube Low Layer Drivers



- STM32Cube HAL & LL are complementary and covers a wide range of applications requirements:
  - HAL offers high level and functionalities oriented APIs, with high portability level and hide product/IPs complexity to end user
  - LL offers low level APIs at registers level, w/ better optimization but less portability and require deep knowledge of the product/IPs specification

# Low Layer (LL) Library Features

170

- The Low Layer (LL) Library offers the following services:
  - Set of static inline function for direct register access (provided in \*.h files only)
  - One-shot operations that can be used by the HAL drivers or from application level.
  - Independent from HAL and can be used standalone (without HAL drivers)
  - Full feature coverage of the supported peripherals
- The LL APIs are Not Fully Portable across the STM32 families; the availability of some macros depends on the physical availability of the relative feature on the product
- Most STM32 Peripherals covered
- Same standard compliancy as HAL (MISRA-C, ANSIC...)
- Low Layer (LL) is available in STM32CubeMX i.e. user can choose between HAL and LL by Peripheral

# STM32Cube FW package block view

171



# Benchmark- USART transmit Example

172

- The below data are based on the “USART Transmitter IT” example:
  - Configure GPIO & USART peripheral for sending characters to HyperTerminal (PC) in Asynchronous mode using IT
  - Using below configuration:
    - Platform: STM32L486xx
    - Compiler : IAR
    - Optimization : High Size
    - Heap Size = 512 Bytes / Stack Size = 512 Bytes

|                                       | HAL Drivers | Low layer<br>Drivers |
|---------------------------------------|-------------|----------------------|
| read-only code memory<br>(Bytes)      | 7206        | 2154                 |
| read-only data memory<br>(Bytes)      | 204         | 94                   |
| read write data memory<br>(Bytes) (*) | 1408        | 1093                 |

ROM Size  
divided by ~4

RAM Size  
reduction

- LL offer smaller footprint & high performance but less portability & require expertise
- HAL offer high level API (hide complexity) & portability but higher footprint & less performance

(\*) to add Heap and Stack size for total RAM

# Optional Lab: Using the Low Layer (LL) Drivers



## Objective:

- Generate a project with STM32CubeMX using the Low Layer Drivers and check how much improvement we get compared to a HAL project in term of Flash and RAM usage

- Close Keil uVision5 IDE if it is open; In STM32CubeMX Open the project (“**blinky**”) and save it as a new project name like “**blinky\_ll**” through File -> Save Project As

# Configuration

176



- In Project Manager Tab 1
- In the Advanced Settings Tab 2
- Instead of HAL drivers select LL 3 (Low Level) for both RCC and GPIO

# Generate Source Code

177

- Generate Code



- Click Open Project



# Step 4: Toggle The LED

178

- In Keil uVision5 IDE
- Expand the “Drivers” and notice that now the drivers are low layer (\_LL):



- Expand the file tree and open the **main.c** file
- Add the following code **inside the while(1) loop**
  - Add within “USER CODE BEGIN WHILE” / “USER CODE END WHILE” section (this will preserve your code after code regeneration)



```
LL_GPIO_TogglePin(GPIOA, LL_GPIO_PIN_5);
// Delay 100 ms
LL_mDelay(100);
```

```
/* Infinite loop */
/* USER CODE BEGIN WHILE */
while (1)
{
    LL_GPIO_TogglePin(GPIOA, LL_GPIO_PIN_5);
    // Delay 100 ms
    LL_mDelay(100);
    /* USER CODE END WHILE */
```

# Build the Project

179

- Click the “Build” button



- Click the “Start/Stop Debug Session” button



- Click “Run” button



- The Green LED (LD4) should be blinking just like the blinky example with the HAL drivers

# Let's compare the map files between HAL and LL projects

180

Use a text editor to open the map file for the “blink” project that is using HAL:”blinky.map” located here:



# Let's compare the map files between HAL and LL projects

181

Open the map file for the “blinky\_ll” project that is using LL: “blinky\_ll.map” located here:



# Let's compare the Flash and RAM size first

Using HAL:

| blinky.map - Notepad                      |         |         |         |                |                     |
|-------------------------------------------|---------|---------|---------|----------------|---------------------|
| File                                      | Edit    | Format  | View    | Help           |                     |
| 44                                        | 0       | 0       | 0       | 0              | 72 uidiv.o          |
| -                                         | -       | -       | -       | -              | -                   |
| 168                                       | 16      | 0       | 0       | 0              | 240 Library         |
| Totals                                    |         |         |         |                |                     |
| 2                                         | 0       | 0       | 0       | 0              | 0 (incl. Padding)   |
| -                                         | -       | -       | -       | -              | -                   |
| Code (inc. data)                          | RO Data | RW Data | ZI Data | Debug          | Library Name        |
| 166                                       | 16      | 0       | 0       | 0              | 240 mc_p.l          |
| -                                         | -       | -       | -       | -              | -                   |
| 168                                       | 16      | 0       | 0       | 0              | 240 Library         |
| Totals                                    |         |         |         |                |                     |
| -                                         | -       | -       | -       | -              | -                   |
| Code (inc. data)                          | RO Data | RW Data | ZI Data | Debug          |                     |
| 2532                                      | 174     | 284     | 16      | 1024           | 415174 Grand Totals |
| 2532                                      | 174     | 284     | 16      | 1024           | 415174 ELF Image    |
| Totals                                    |         |         |         |                |                     |
| 2532                                      | 174     | 284     | 16      | 0              | 0 ROM Totals        |
| -                                         | -       | -       | -       | -              | -                   |
| Total RO Size (Code + RO Data)            |         |         |         | 2816 ( 2.75kB) |                     |
| Total RW Size (RW Data + ZI Data)         |         |         |         | 1040 ( 1.02kB) |                     |
| Total ROM Size (Code + RO Data + RW Data) |         |         |         | 2832 ( 2.77kB) |                     |

Using LL:

| blinky_ll.map - Notepad                   |         |         |         |                |                     |
|-------------------------------------------|---------|---------|---------|----------------|---------------------|
| File                                      | Edit    | Format  | View    | Help           |                     |
| 30                                        | 0       | 0       | 0       | 0              | 0 handlers.o        |
| -                                         | -       | -       | -       | -              | -                   |
| 36                                        | 8       | 0       | 0       | 0              | 68 init.o           |
| -                                         | -       | -       | -       | -              | -                   |
| 36                                        | 0       | 0       | 0       | 0              | 100 memseta.o       |
| -                                         | -       | -       | -       | -              | -                   |
| 44                                        | 0       | 0       | 0       | 0              | 72 uidiv.o          |
| -                                         | -       | -       | -       | -              | -                   |
| 168                                       | 16      | 0       | 0       | 0              | 240 Library Totals  |
| 2                                         | 0       | 0       | 0       | 0              | 0 (incl. Padding)   |
| -                                         | -       | -       | -       | -              | -                   |
| Code (inc. data)                          | RO Data | RW Data | ZI Data | Debug          | Library Name        |
| 166                                       | 16      | 0       | 0       | 0              | 240 mc_p.l          |
| -                                         | -       | -       | -       | -              | -                   |
| 168                                       | 16      | 0       | 0       | 0              | 240 Library Totals  |
| -                                         | -       | -       | -       | -              | -                   |
| Code (inc. data)                          | RO Data | RW Data | ZI Data | Debug          |                     |
| 680                                       | 66      | 220     | 4       | 1028           | 376886 Grand Totals |
| 680                                       | 66      | 220     | 4       | 1028           | 376886 ELF Image    |
| Totals                                    |         |         |         |                |                     |
| 680                                       | 66      | 220     | 4       | 0              | 0 ROM Totals        |
| -                                         | -       | -       | -       | -              | -                   |
| Total RO Size (Code + RO Data)            |         |         |         | 900 ( 0.88kB)  |                     |
| Total RW Size (RW Data + ZI Data)         |         |         |         | 1032 ( 1.01kB) |                     |
| Total ROM Size (Code + RO Data + RW Data) |         |         |         | 904 ( 0.88kB)  |                     |

Scroll to the bottom of the files



# Comparison table between HAL and LL for our “Blinky” code

183

- Using below configuration:

- Heap Size = 512 Bytes / Stack Size = 512 Bytes
- STM32Cube G0 1.0.0
- uVision 5.26
- CubeMX 5.0.1

|                                               | HAL Drivers      | Low layer Drivers |
|-----------------------------------------------|------------------|-------------------|
| <b>read-only code memory<br/>(Bytes)</b>      | 2816             | 900               |
| <b>read write data memory<br/>(Bytes) (*)</b> | 1040-1024(**)=16 | 1032-1024(**)=8   |

ROM Size  
divided by ~3

RAM Size  
reduction  
divided by 2

- LL** offer **smaller footprint & high performance** but **less portability & require expertise**
- HAL** offer **high level API (hide complexity) & portability** but **higher footprint & less performance**

(\*) to add Heap and Stack size for total RAM

(\*\*)  $1024 = 512 \text{ bytes Heap size} + 512 \text{ bytes Stack size}$

# STM32G0 – DMA



# DMA - Overview

185





- DMA features

- AHB master bus
- Flexible configuration
- Hardware and software priority management
- Configurable data transfer modes
  - Peripheral-to-Peripheral, Peripheral-to-Memory, Memory-to-Peripheral, and Memory-to-Memory modes

## Application benefits

- DMA support for timers, ADC, and communication peripherals
- Offloads CPU from data transfer management
- Simple integration

- STM32G0 DMA features

- 1x DMA controller
  - Programmable block transfers with 7 concurrent channels, independently configurable
  - Programmable channel-based priority
  - Data transfers via the AHB master port (connected to the bus matrix)
- 1x new DMA request multiplexer (DMAMUX)
  - Programmable mapping of a DMA request e.g. from any peripheral
  - Event-triggered & synchronized DMA request generation



# DMA - Main differences with STM32F0

188

- The DMA Controller is similar to the one implemented in STM32F0 microcontrollers, but with the additional DMA request multiplexer (DMAMUX)

|              | STM32F0 | STM32G0 |
|--------------|---------|---------|
| DMA          | 2 DMAs  | 1 DMA   |
| DMA Features |         | Same    |
| DMAMUX       | No      | Yes     |



- The DMA request router (DMAMUX) manages:
  - The assignment of DMA request lines to peripherals
  - The request forwarding synchronization with events on synchronization inputs
  - The request chaining using the DMA request counter and Event generator for DMA

## Application benefits

- High flexibility in choice of DMA request mapping
- External and internal DMA request management
- Request synchronization
- Request chaining capability

- DMAMUX is a DMA request multiplexer/router
  - DMAMUX provides a programmable routing of any of the 7 DMA (hardware) requests from any peripheral request
- Additionally, there are 4 request generator channels
  - Software can configure a DMA request to be generated by the DMAMUX itself, upon a trigger input
  - Are programmable:
    - The trigger selection: EXTI0..15, LPTIM1/2OUT, TIM14\_OC, or any of the 4 generated DMAMUX events
    - The trigger event: rising edge, falling edge or either edge
    - The number of generated DMA requests upon the trigger event
  - There is a trigger overrun flag & interrupt in order to alert the software when the number of generated DMA requests (as paced by the DMA) have not been completed before a next trigger event

# STM32G0 DMA & DMAMUX instance

191

| DMAMUX features                      | DMAMUX |
|--------------------------------------|--------|
| Number of peripheral requests        | 57     |
| Number of request generator channels | 4      |
| Number of trigger inputs             | 23     |
| Number of synchronization inputs     | 23     |
| Number of output DMA requests        | 7      |

| DMA features       | DMA |
|--------------------|-----|
| Number of channels | 7   |

# Optional Lab: DMA



## Objective:

- Open a provided STM32CubeMX project (\*.ioc) from our STM32CubeG0 Library examples and review the configuration.
- Run the Keil uVision5 (ARM-MDK) project example for the DMA configured as a memory to memory to transfer a buffer from Flash to internal SRAM.

- Close Keil uVision5 IDE if it is open and Close STM32CubeMX if it is open
- In a Windows Explorer window open the following location:

**C:\Users\ST\STM32Cube\Repository\STM32Cube\_FW\_G0\_V1.x.0\Projects\NUCLEO-G071RB\Examples\DMA\DMA\_FLASHToRAM**

**Where “ST” is your Windows username and where 1.x .0 is the version of the STM32CubeG) Library that you have installed**



# Open the ioc file

195

- Double click on the ioc file (DMA\_FLASHToRAM.ioc) to open the configuration file with STM32CubeMX:



# Check the DMA configuration in STM32CubeMX

196

- In STM32CubeMX click on “**System View**” and then “**DMA**”



# Check the DMA configuration in STM32CubeMX

197

- Review the DMA configuration by clicking on the “**MEM2MEM**” under “DMA Request” as shown below:



## DMA Configuration:

- DMA1 Channel 1
- Memory to Memory
- Priority: Low
- Normal mode
- Incremental Address for source et destination
- Data Width: Word

# Check the DMA configuration in STM32CubeMX

198

- In STM32CubeMX click on “**System View**” and then “**NVIC**”



# Check the DMA configuration in STM32CubeMX

199

- Notice that the Interrupt is enabled for the DMA1 Channel1:



NVIC Mode and Configuration

Configuration

NVIC     Code generation

Sort by Preemption Priority and Sub Priority

Search

Show only enabled interrupts

| NVIC Interrupt Table                    | Enabled                             | Preemption Priority |
|-----------------------------------------|-------------------------------------|---------------------|
| Non maskable interrupt                  | <input checked="" type="checkbox"/> | 0                   |
| Hard fault interrupt                    | <input checked="" type="checkbox"/> | 0                   |
| System service call via SWI instruction | <input checked="" type="checkbox"/> | 0                   |
| Pendable request for system service     | <input checked="" type="checkbox"/> | 0                   |
| Time base: System tick timer            | <input checked="" type="checkbox"/> | 0                   |
| PVD interrupt through EXTI line 16      | <input type="checkbox"/>            | 0                   |
| Flash global interrupt                  | <input type="checkbox"/>            | 0                   |
| RCC global interrupt                    | <input type="checkbox"/>            | 0                   |
| DMA1 channel 1 interrupt                | <input checked="" type="checkbox"/> | 0                   |

- In a Windows Explorer window open the following location where the ARM-MDK (Keil uVision5) project is located and double click on the “DMA\_FLASHToRam.uvprojx” file:

**C:\Users\ST\STM32Cube\Repository\STM32Cube\_FW\_G0\_V1.x\Projects\NUCLEO-G071RB\Examples\DMA\DMA\_FLASHToRAM\MDK-ARM**



# Check the DMA configuration in the ARM-MDK project

201

- Open main.c and look for the function MX\_DMA\_Init() and notice that the configuration is the same as in STM3CubeMX:



```
static void MX_DMA_Init(void)
{
    /* DMA controller clock enable */
    __HAL_RCC_DMA1_CLK_ENABLE();

    /* Configure DMA request hdma_memtomem_dmal_channell on DMA1_Channell */
    hdma_memtomem_dmal_channell.Instance = DMA1_Channell;
    hdma_memtomem_dmal_channell.Init.Request = DMA_REQUEST_MEM2MEM;
    hdma_memtomem_dmal_channell.Init.Direction = DMA_MEMORY_TO_MEMORY;
    hdma_memtomem_dmal_channell.Init.PeriphInc = DMA_PINC_ENABLE;
    hdma_memtomem_dmal_channell.Init.MemInc = DMA_MINC_ENABLE;
    hdma_memtomem_dmal_channell.InitPeriphDataAlignment = DMA_PDATAALIGN_WORD;
    hdma_memtomem_dmal_channell.Init.MemDataAlignment = DMA_MDATAALIGN_WORD;
    hdma_memtomem_dmal_channell.Init.Mode = DMA_NORMAL;
    hdma_memtomem_dmal_channell.Init.Priority = DMA_PRIORITY_LOW;
    if (HAL_DMA_Init(&hdma_memtomem_dmal_channell) != HAL_OK)
    {
        Error_Handler();
    }

    /* DMA interrupt init */
    /* DMA1_Channell_IRQn interrupt configuration */
    HAL_NVIC_SetPriority(DMA1_Channell_IRQn, 0, 0);
    HAL_NVIC_EnableIRQ(DMA1_Channell_IRQn);

    /* USER CODE BEGIN 4 */
}
```

# Build the Project

202

- Click the “Build” button



- Click the “Start/Stop Debug Session” button



# Add 2 variables to the watch window

- Add “aSRC\_Const\_Buffer” (Source buffer located in Flash) to Watch 1 as shown below:



- Do the same thing for “aDST\_Buffer” (Destination Buffer located in internal SRAM)

# Add 2 breakpoints in main.c

204

- Add the first breakpoint at this location in main.c just before the execution of the code that will start the DMA transfer:



```
/* Configure the source, destination and buffer size DMA fields and Start DMA Channel/Stream transfer */
/* Enable All the DMA interrupts */
if (HAL_DMA_Start_IT(&hdma_memtomem_dmam1_channell, (uint32_t)&aSRC_Const_Buffer, (uint32_t)&aDST_Buffer, BUFFER_SIZE) != HAL_OK)
{
    /* Transfer Error */
    Error_Handler();
}
```

- Add another breakpoint at this code location which will be hit when the DMA transfer has been completed successfully:



```
if (transferCompleteDetected == 1)
{
    /* Turn LED4 on*/
    BSP_LED_On(LED4);
    transferCompleteDetected = 0;
}
/* USER CODE END 3 */
```

# Execute the code until it reaches the first breakpoint

205

- Run the code:



- Once the first breakpoint is hit, notice in the Watch 1 window that the Destination Buffer (aDST\_Buffer) is filled with '0'



# Execute the code until it reaches the first breakpoint

206

- Now Continue executing the code until it reaches the second breakpoint, press “Run” again:



- Now the destination buffer is filled with values that are the same as the source buffer:

| Name        | Value                   | Type             |
|-------------|-------------------------|------------------|
| aDST_Buffer | 0x2000007C aDST_Buff... | unsigned int[32] |
| [0]         | 0x01020304              | unsigned int     |
| [1]         | 0x05060708              | unsigned int     |
| [2]         | 0x090A0B0C              | unsigned int     |
| [3]         | 0x0D0E0F10              | unsigned int     |
| [4]         | 0x11121314              | unsigned int     |
| [5]         | 0x15161718              | unsigned int     |
| [6]         | 0x191A1B1C              | unsigned int     |
| [7]         | 0x1D1E1F20              | unsigned int     |
| [8]         | 0x21222324              | unsigned int     |
| [9]         | 0x25262728              | unsigned int     |
| [10]        | 0x292A2B2C              | unsigned int     |
| [11]        | 0x2D2E2F30              | unsigned int     |
| [12]        | 0x31323334              | unsigned int     |
| [13]        | 0x35363738              | unsigned int     |
| [14]        | 0x393A3B3C              | unsigned int     |
| [15]        | 0x3D3E3F40              | unsigned int     |
| [16]        | 0x41424344              | unsigned int     |
| [17]        | 0x45464748              | unsigned int     |

# Flashing code into the STM32

- Up to 128 Kbytes of single-bank Flash memory
- 2-Kbyte page granularity
- Fast erase (22 ms) and fast programming time (82  $\mu$ s for double-words)
- Prefetch & Instruction Cache
- Error Code Correction (ECC): 8 bits for 64-bit double-words
  - Single-bit error detection and correction, notification through a maskable interrupt
  - Double-bit error detection and notification through assertion of the NMI

# Flash memory organization

209

| Flash area        | Flash memory address      | Size      | Name          | Operation                           | Granularity      |
|-------------------|---------------------------|-----------|---------------|-------------------------------------|------------------|
| Main memory       | 0x0800 0000 – 0x0800 07FF | 2 Kbytes  | Page 0        | Programming                         | 8-Byte           |
|                   | ...                       | ...       | ...           | Fast-programming                    | Row of 256 Bytes |
|                   | 0x0801 F800 – 0x0801 FFFF | 2 Kbytes  | Page 63       | Erase                               | 2-Kbyte page     |
| Information block | 0x1FFF 0000 – 0x1FFF 6FFF | 28 Kbytes | System memory | Securable memory                    |                  |
|                   | 0x1FFF 7000 – 0x1FFF 73FF | 1 Kbyte   | OTP area      | Write protection                    |                  |
|                   | 0x1FFF 7800 – 0x1FFF 787F | 128 bytes | Option bytes  | Read protection                     | Global           |
|                   |                           |           |               | Proprietary Code Readout Protection | 512 Bytes        |

# Flash memory features (1/2)

210

## Robust memory integrity and safety

- **ECC (Error Code Correction): 8 bits long for a 64-bit word**
  - Single error correction: ECCC bit set in FLASH\_ECCR, optional interrupt generation
  - Double error detection: ECCD bit set in FLASH\_ECCR => NMI
  - **Failure address saved in FLASH\_ECCR register**

### Programming



### Reading



## Robust memory integrity and safety

- Programming granularity is 64 bits (really 72 bits incl. 8-bit ECC)
- 2 programming modes :
  - Standard (for main memory and OTP)
  - Fast (main memory only)
    - Programs 64 double-words without verifying the Flash memory location

| Boot mode configuration |            |           |               |            | Selected boot area       |
|-------------------------|------------|-----------|---------------|------------|--------------------------|
| BOOT_LOCK bit           | nBOOT1 bit | BOOT0 pin | nBOOT_SEL bit | nBOOT0 bit |                          |
| 0                       | x          | 0         | 0             | x          | Main Flash memory        |
| 0                       | 1          | 1         | 0             | x          | System memory            |
| 0                       | 0          | 1         | 0             | x          | Embedded SRAM            |
| 0                       | x          | x         | 1             | 1          | Main Flash memory        |
| 0                       | 1          | x         | 1             | 0          | System memory            |
| 0                       | 0          | x         | 1             | 0          | Embedded SRAM            |
| 1                       | x          | x         | x             | x          | Main Flash memory forced |

- BOOT\_LOCK Forcing boot from Flash memory
  - It is possible to force booting from Main Flash memory regardless the other boot options
- The Empty bit is added in Flash memory register to check if programmed

# Lab: Flashing code into the STM32

213

## Objective:

- The objective of this lab is to show you how to flash code into the STM32 by restoring the “out-of-the-box” firmware demonstration code that we saved at the beginning of the workshop using 3 different methods:
  - 1<sup>st</sup> method: using SWD (Serial Wire Debug)
  - 2<sup>nd</sup> method: using ST-LINK Mass Storage Feature
  - 3<sup>rd</sup> method: using the STM32G0 System Memory Bootloader

# 1<sup>st</sup> method: using SWD (Serial Wire Debug)



# In STM32CubeProgrammer, Connect to the ST-LINK

215



# Program the flash

216

- Click on the icon 1
- Select the path of the original code saved at the beginning of the workshop 2
- Uncheck this box so that the code won't run after programming 3
- Press **Start Programming** 4



# Flash Programmed

217



# Disconnect to the ST-LINK

218



Now press reset on the board to run the original code



2nd method: using ST-LINK Mass Storage Feature of the Nucleo board

# Prepare the copy of binary code to the NUCLEO drive

220

Open the  
Nucleo Drive  
on your  
computer



Open the location on your  
computer where you saved the  
original code at the beginning of  
the workshop

# Drag and drop the binary code to the NUCLEO drive



The original code will run after the copy has been done



## 3rd method: using the STM32G0 System Memory Bootloader



# Connect to the ST-LINK

223



# Change the option byte to boot from System Memory

224

The screenshot shows the 'User Configuration' section of the ST-LINK V2 Option bytes configuration tool. The table lists various option bytes with their current values and descriptions.

| Name             | Value                               | Description                                                                                                                                                                                    |
|------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| nRST_STOP        | <input checked="" type="checkbox"/> | Unchecked : Reset generated when entering Stop mode<br>Checked : No reset generated when entering Stop mode                                                                                    |
| nRST_STDBY       | <input checked="" type="checkbox"/> | Unchecked : Reset generated when entering Standby mode<br>Checked : No reset generated when entering Standby mode                                                                              |
| nRST_SHDW        | <input checked="" type="checkbox"/> | Unchecked : Reset generated when entering the Shutdown mode<br>Checked : No reset generated when entering the Shutdown mode                                                                    |
| IWDG_SW          | <input checked="" type="checkbox"/> | Unchecked : Hardware independant watchdog<br>Checked : Software independant watchdog                                                                                                           |
| IWDG_STOP        | <input checked="" type="checkbox"/> | Unchecked : Freeze IWDG counter in stop mode<br>Checked : IWDG counter active in stop mode                                                                                                     |
| IWDG_STDBY       | <input checked="" type="checkbox"/> | Unchecked : Freeze IWDG counter in standby mode<br>Checked : IWDG counter active in standby mode                                                                                               |
| WWDG_SW          | <input checked="" type="checkbox"/> | Unchecked : Hardware window watchdog<br>Checked : Software window watchdog                                                                                                                     |
| RAM_PARITY_CHECK | <input checked="" type="checkbox"/> | Unchecked : SRAM2 parity check enable<br>Checked : SRAM2 parity check disable                                                                                                                  |
| nBOOT_SEL        | <input checked="" type="checkbox"/> | Unchecked : BOOT0 signal is defined by BOOT0 pin value (legacy mode)<br>Checked : BOOT0 signal is defined by nBOOT0 option bit                                                                 |
| nBOOT1           | <input checked="" type="checkbox"/> | Unchecked : Boot from Flash if BOOT0 = 0, otherwise Embedded SRAM1<br>Checked : Boot from Flash if BOOT0 = 0, otherwise system memory                                                          |
| nBOOT0           | <input type="checkbox"/>            | Unchecked : nBOOT0=0<br>Checked : nBOOT0=1<br>0 : Reserved                                                                                                                                     |
| NRST_MODE        | 3                                   | 1 : Reset Input only; a low level on the NRST pin generates system reset, internal RESET not propagated to the NSRT<br>2 : GPIO: standard GPIO pad functionality, only internal RESET possible |

Annotations:

- 1: A blue circle with 'OB' is on the left sidebar next to the 'User Configuration' section.
- 2: A blue arrow points to the 'nBOOT0' row, which is highlighted with a red box. The '0 : Reserved' entry below it is also highlighted.
- 3: A blue circle with '3' is at the bottom right of the table.

Buttons at the bottom right: Apply, Read.

Uncheck  
**nBoot0** to  
boot from  
System  
Memory  
Bootloader



life.augmented

# Disconnect to the ST-LINK and reset the board

225



Once disconnected is clicked, unplug and replug the Nucleo board's USB cable

# With STM32 Cube Programmer connect to the System Memory trough UART

226

Instead of “ST-LINK” use “UART” to connect to the System Memory Bootloader through UART mode



# Program the binary code

227



Restore the option bytes to boot from internal flash

# Connect to the ST-LINK through SWD

229



# Change the option byte to boot from the Flash Memory

230

The screenshot shows the STM32CubeProgrammer interface with the 'User Configuration' tab selected under 'Option bytes'. The 'OB' icon in the sidebar is highlighted with a pink box and a blue circle labeled '1'. The 'nBOOT0' row is highlighted with a red box and a blue circle labeled '2'. The 'Apply' button at the bottom is highlighted with a pink box and a blue circle labeled '3'.

| Name             | Value                               | Description                                                                                                                           |
|------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| nRST_STOP        | <input checked="" type="checkbox"/> | Unchecked : Reset generated when entering Stop mode<br>Checked : No reset generated when entering Stop mode                           |
| nRST_STDBY       | <input checked="" type="checkbox"/> | Unchecked : Reset generated when entering Standby mode<br>Checked : No reset generated when entering Standby mode                     |
| nRST_SHDW        | <input checked="" type="checkbox"/> | Unchecked : Reset generated when entering the Shutdown mode<br>Checked : No reset generated when entering the Shutdown mode           |
| IWDG_SW          | <input checked="" type="checkbox"/> | Unchecked : Hardware independant watchdog<br>Checked : Software independant watchdog                                                  |
| IWDG_STOP        | <input checked="" type="checkbox"/> | Unchecked : Freeze IWDG counter in stop mode<br>Checked : IWDG counter active in stop mode                                            |
| IWDG_STDBY       | <input checked="" type="checkbox"/> | Unchecked : Freeze IWDG counter in standby mode<br>Checked : IWDG counter active in standby mode                                      |
| WWDG_SW          | <input checked="" type="checkbox"/> | Unchecked : Hardware window watchdog<br>Checked : Software window watchdog                                                            |
| RAM_PARITY_CHECK | <input checked="" type="checkbox"/> | Unchecked : SRAM2 parity check enable<br>Checked : SRAM2 parity check disable                                                         |
| nBOOT_SEL        | <input checked="" type="checkbox"/> | Unchecked : BOOT0 signal is defined by BOOT0 pin value (legacy mode)<br>Checked : BOOT0 signal is defined by nBOOT0 option bit        |
| nBOOT1           | <input checked="" type="checkbox"/> | Unchecked : Boot from Flash if BOOT0 = 0, otherwise Embedded SRAM1<br>Checked : Boot from Flash if BOOT0 = 0, otherwise system memory |
| nBOOT0           | <input checked="" type="checkbox"/> | Unchecked : nBOOT0=0<br>Checked : nBOOT0=1<br>0 : Reserved                                                                            |

NRST\_MODE: 3

Log:

```
22:18:46 : Bank : 0x01
22:18:46 : Address : 0x40022080
22:18:46 : Size : 4 Bytes
22:18:46 : OPTION BYTE PROGRAMMING VERIFICATION:
22:18:46 : Option Bytes successfully programmed
```

ST-LINK configuration:

- Serial number: 066FFF48495171786711...
- Port: SWD
- Frequency (kHz): 4000
- Mode: Normal
- Access port: 0
- Reset mode: Software reset
- Shared: Disabled
- External loader: -
- Target voltage: 3.23 V
- Firmware version: V2J31M21

Firmware upgrade

Device information:

- Device: -
- Type: -
- Device ID: -
- Flash size: -
- CPU: -

# Disconnect to the ST-LINK

231



Click On “Disconnect”

Reset the board and the original code will run



- 1 **Efficient** (Power, Performance and Cost)
- 2 **Robust** (EMS, ECC, Clock Monitoring/Watchdogs, Security)
- 3 **Simple** (Easy to configure and develop code)

[www.st.com/stm32g0](http://www.st.com/stm32g0)



# We Greatly Value Your Feedback

Use your phone to scan the QR code or type the link into your browser.



<https://www.surveymonkey.com/r/8WPJFF>

# Thank you

234



 [/STM32](#)

 [@ST\\_World](#)

 [community.st.com](#)