

Hello, and welcome to this presentation of the STM32 general-purpose IO interface. It covers the general-purpose input and output interface and how it allows connectivity to the environment around the microcontroller.

## Overview •

- Provides interface for interaction with external environment
  - · Fully configurable
  - · With interrupt and wake-up capability
  - · Direct connection to AHB2 bridge



#### Application benefits

- Direct Microcontroller wake-up
- Supports a wide range of supply voltages
- Direct connection to AHB2 allows fast toggle response

General-purpose IO pins of STM32 products provide an interface with the external environment. This configurable interface is used by the MCU and also all other embedded peripherals to interface with both digital and analog signals. Application benefits include a wide range of supported IO supply voltages, as well as the ability to externally wake up the MCU from low power modes.

# Key features ==

- Bi-directional operation of up to 114\* I/O pins
  - · Shared across 8 GPIOx ports named GPIOA to GPIOH, with up to 16 I/O pins per port
  - · All with external interrupt and wake-up capabilities
  - · Atomic bit set and bit reset using BSRR and BRR registers
  - · Independent configuration for each I/O pin
- GPIOx directly connected to AHB2 bus
- Most I/O pins are 5 V tolerant when VDDIOx is above 1.6 V
- Independent I/O supply down to 1.08 V
  - Up to 14\* I/O pins under VDDIO2 domain



\*: depends on part numbers and packages

General-purpose I/O provides bidirectional operation – input and output – with independent configuration for each I/O pin. They are shared across up to 9 ports named GPIOA to GPIOI, each of them hosting up to 16 I/O pins. I/O ports support atomic bit set and reset operation through BSSRR and BRR registers and support the use of bit banding in the memory map.

I/O ports are directly connected to the AHB2 bus. This allows fast I/O pin operations, e.g. toggling of the pin every 2 clock cycles.

Most of the I/O pins are 5 V tolerant when supplied from VDDIOx above 1.6 V.

Up to 14 I/O pins are supplied by externally providing a voltage within the VDDIO2 supply domain. This supply is independent of the VDD provided to the part. This functionality allows users to adapt logic levels of the MCU's I/O pins to the levels required by external logic which may be supplied by different voltage domains without need for

external level shifters.

# Operating modes •

#### Flexible operating modes to best fit application needs

- Input mode
  - · Floating (no pull resistor), input with pull-up/down, analog input mode
- Output mode
  - · Push-pull, open drain with optional pull-up/down
- Configurable output slew rate speed up to 80 MHz
- Alternate function mode
- Locking mechanism to freeze the I/O port configuration (GPIOx\_LCKR)



General-purpose I/O pins can be configured into several operating modes.

An I/O pin can be configured in an input mode with floating input, input mode with an internal pull-up or pull-down resistor or as an analog input.

An I/O pin could be also configured in an output mode with a push-pull output or an open-drain output with an internal pull-up or pull-down resistor.

For each I/O pin, the slew rate speed can be selected from 4 ranges to compromise between maximum speed and emissions from the I/O switching and adjust the application's EMI performance.

I/O pins are also used by other integrated peripherals to interface with the external environment. Alternate function registers are used to select the configuration for the peripherals in this case.

Configuration of the I/O ports can be locked to increase

robustness of the application. Once the configuration is locked by applying the correct write sequence to the lock register, the I/O pin's configuration cannot be modified until the next reset.

#### Structure of I/O pins is used as interface by other embedded peripherals

- Several integrated peripherals share the same I/O pins
  - Including USARTx TX, TIMx CHx, SPIx MISO, EVENTOUT, ...
- Alternate function multiplexer selects the peripheral connected to the I/O pin
  - · Only one alternate function is connected to a specific I/O pin at a single time
  - · Configurable through the GPIOx\_AFRL and GPIOx\_AFRH registers





Several integrated peripherals such as the USART, timers, SPI and others share the same I/O pins in order to interface with the external environment.

Peripherals are configured through an alternate function multiplexer which ensures that only one peripheral is connected to the I/O pin at a single time. Of course, this selection can be changed during run time of the application through the GPIOx\_AFRL and AFRH registers.

# Independent VDDIO2 supply

- Independent VDDIO2 brings benefits in a multi-supply environment
- VDDIO2 supply domain is independent of VDD
  - 1.08 < VDDIO2 < 3.6 V</li>
- Pins in the VDDIO2 domain can be used to communicate with other circuits which are supplied by voltage rails other than VDD
- Up to 14 I/O pins

### Application benefits

 Well suited for applications with two different power supplies / supply voltages without need of level shifters



The Independent VDDIO2 supply domain allows operation in an environment with several different logic supply voltages. It allows the STM32 to communicate with logic supplied from 1.08 V, much lower than the VDD supply of the STM32, which can range up to 3.6 V.

Up to 14 I/O pins in this domain can be used to communicate with other logic circuits which are supplied by voltage rails other than VDD.

Independent voltage supplies may allow for the omission of external voltage shifters in the design.

# Special considerations for I/O pins

#### Only debug pins remain in AF mode under reset

- During and after reset, the alternate functions (AF) are not active
  - I/O ports default to Analog mode
  - · Saves current consumption during and after reset (Schmitt trigger is off)
- Only JTAG/SWD debug pins remain in AF pull-up/pull-down configuration

· PA13: JTMS/SWDIO

PA14: JTCK/SWCLK

PA15: JTDI

PB3: JTDO

PB4: NJTRST





During and after reset, the alternate functions (AF) are not active, only debug pins remain in AF mode.

JTAG/SWD debug pins remaining in AF configuration mode are listed in this slide.

## Special considerations for HSE/LSI pins

#### Oscillator pins can be used as standard I/O pins

- When the oscillator is switched OFF, related pins behave as I/O pins
  - Valid for both HSE / LSE
  - · This state is the default one after reset
- When user external clock mode is used, the second pin behaves as an I/O pin
  - Only OSC\_IN or OSC32\_IN is used as clock source
  - OSC OUT and OSC32 OUT are standard I/O pins





When the external oscillator is switched off, pins related to this oscillator can be used as standard I/O pins. This is the default state after device reset.

When the external clock source is used instead of a crystal oscillator, only related OSC\_IN or OSC32\_IN pins are used for the clock and OSC\_OUT or OSC32\_OUT pins can be used as standard I/O pins.

# Analog switch control register

- Special GPIOx\_ASCR register present on STM32L47x/48x devices only
- New GPIOx ASCR control register is present on STM32L47x/48x devices
  - Used to enable an analog connection between an I/O pin and ADC input
  - Connection must be enabled before starting ADC conversions
  - Register will be removed on other devices and replaced by an automatic routing configuration



New GPIOx ASCR control register has been introduced on STM32L47x/48x devices to control analog interconnection between an I/O pin and ADC input. This register has to be configured before the ADC conversions are started to correctly bring the signal to the ADC input.

This register is removed on other Categories of STM32L4 devices and the analog interconnection will be enabled automatically when an ADC channel is selected.

# Multi-supply I/O pins 10

#### Some I/O pins can be supplied from different sources

- New I/O pin supply scheme brings new I/O pin structures and names
  - TT and FT definition is extended by new abbreviation suffix
  - Maximum VIN is defined by lowest supply voltage connected to the structure of given I/O
  - For example, formula VIN < min (VDD, VDDA) + 4.0 V applies for FT a pin</li>

| Abbreviation suffix | Description                                     | Example     |
|---------------------|-------------------------------------------------|-------------|
| _f                  | I/O with Fm+ capability, supplied by VDD        | FT_f, FT_fa |
| J                   | I/O with LCD function, supplied by VLCD         | FT_I        |
| _a                  | I/O with analog function, supplied by VDDA      | FT_a, TT_a  |
| _u                  | I/O with USB function, supplied by VDDUSB       | FT_u        |
| _s                  | I/O with independent supply, supplied by VDDIO2 | FT_s, FT_fs |



A new multi-supply scheme of I/O pins brings new I/O pin structures. Previously-used naming – FT, TT – has been extended by abbreviation suffixes to highlight alternate supply sources for each FT and TT I/O pin.

Previously-used name FTf for Fm+ capable pins has been transformed to FT f, the new I suffix has been added to mark pins supplied through LCD supply, suffix \_a marks pins supplied by analog supply, suffix \_u is used for pins supplied from USB supply and suffix \_s now clearly identifies pins within the independent VDDIO2 supply domain.

The absolute maximum rating for each I/O pin is defined by the lowest voltage of the supplies listed for each I/O pin.

# Low-power modes —11

| Mode            | I/O Description                                                                              |  |
|-----------------|----------------------------------------------------------------------------------------------|--|
| Run             | Active.                                                                                      |  |
| Sleep           | Active.                                                                                      |  |
| Low-power run   | Active.                                                                                      |  |
| Low-power sleep | Active.                                                                                      |  |
| Stop0/Stop1     | Active.                                                                                      |  |
| Stop 2          | Active.                                                                                      |  |
| Standby         | Only as input with internal pull-up, pull-down or floating.                                  |  |
| Shutdown        | Only as input with internal pull-up, pull-down or floating. Configuration lost when exiting. |  |
| Reset           | Forced to analog input mode when the MCU is under reset.                                     |  |



I/O pins remain active in all modes except Standby and Shutdown, where the only available configuration is input with internal pull-up, pull-down resistor or floating input. When exiting Shutdown mode, the I/O configuration is lost. When the MCU is under reset, I/O pins are forced into an analog input mode.

### Differences with STM32L47x/48x devices 12

- For STM32L43x/44x/45x/46x devices, the maximum number of GPIO is up to 83.
- For STM32L41x/42x/43x/44x/45x/46x/49x/4Ax devices, the GPIOx\_ASCR register used to enable the analog switches connected to the ADC, is not present.
- No GPIOs can be connected to the independent VDDIO2 power supply for STM32L41x/42x/43x/44x/45x/46x devices.



This slide presents the key differences between baseline STM32L47x/48x devices and other devices.

Compared to STM32L47x/48x devices, STM32L43x/44x/45x/46x devices have up to 83 GPIOs and STM32L41x/42x devices have up to 52 GPIOs. They no longer have GPIOs connected to an independent power supply (VDDIO2), and the GPIOx\_ASCR register, enabling an analog switch connected to the ADC inputs, is no longer present.