

## STM32WBA

## **SW** architecture



### STM32WBA overall SW Architecture



Multi stack support

BLE 5.3 full features
Zigbee\*
Thread\*
Matter \*

Utilities to ease and secure your design

Low Power Manager Sequencer

Platform resources to address your HW

BSP HAL





STM32WBA (Single core CM33)

BLE User App (ACI interface)

BLE host stack (ACI interface)

BLE link layer

**RFIP** 

STM32WB

CPU1 (CM4)

BLE User App (ACI interface)

==

#

#

BLE Middleware (ACI interface)

**IPCC** Mailbox

CPU2 (CM0+)

BLE host stack (ACI interface)

**BLE link layer** 

**RF IP** 

# STM32WBA layers

#### Comparison with STM32WB

Both the STM32WB and the STM32WBA5X runs the same BLE Host Stack

= The same user ACI interface



Any BLE application based on ACI interface can be running with no modification on both product.

Easy porting between platforms





## **STM32WBA SW architecture**

**BLE stack delivery** 







# STM32WBA BLE stack options

#### Each BLE stack needs to use also appropriate BLE link layer library

| Host stack          | Full         | Basic         | LL_ONLY      | LL_ONLY_BASIC |
|---------------------|--------------|---------------|--------------|---------------|
| Link Layer required | BLE_Full_lib | BLE_Basic_lib | BLE_Full_lib | BLE_Basic_lib |

- Full stack: all the legacy stack supported features plus the extended advertising, GATT caching, ACI HCI flow control, isochronous support for audio, L2CAP connection-oriented channels.
- Basic stack: no extended advertising, neither GATT caching, nor ACI HCI flow control, nor isochronous support, nor L2CAP connection-oriented channels.
- Link Layer Only stack (stm32wba\_ble\_stack\_llo.a) contains all the features supported by the full stack but doesn't include the Host Stack (GATT, GAP and L2CAP features).
- Link Layer Only Basic stack contains all the features supported by the basic stack but doesn't include the Host Stack (GATT, GAP and L2CAP features).



BLE stack content available on associated wiki page https://wiki.st.com/stm32mcu/wiki/Connectivity:STM32WBA\_BLE\_Stack\_Integration



## **STM32WBA SW architecture**

**SW** project organization



# GATT Server code generated

#### Files in STM32WBA project generated by STM32CubeMX





Main applicative part files

Service management

Link layer system integration files

**BLE** libraries

Host stack initialization files



### Flows between GATT Server functions



# **Single Core solution**





# STM32WBA RF scheduling

#### STM32WBA5x is single core hosting application and BLE stack





# STM32WBA RF scheduling Interrupt priority



ISR Process radio events . Is time critical and required highest priority

When the LL\_high\_ISR is not executed on time, the Radio event is skipped

only performances (latency in data transfer) on the communication with

the remote device are impacted, the link is preserved

LL high ISR





## **STM32WBA SW architecture**

FW – intropack utilities



# System Clock Manager

#### Managing CPU system clock source and frequency

Used by default in repository examples
Change clock setting during runtime based on application needs
Main purpose "I power optimization"

|            | purpose                         | VOS* | Flash latency | SRAMs latency |
|------------|---------------------------------|------|---------------|---------------|
| HSE 16 MHz | No radio activity               | 2    | 1             | 1             |
| HSE 32 MHz | Radio activity                  | 1    | 0             | 0             |
| PLL        | High performance<br>(BLE audio) | 1    | 3             | 0             |

<sup>\*</sup>VOS - internal regulator Voltage Scalling







## Sequencer

#### Simple alternative to a real time OS

Sequencer to
ease &
secure
your SW implementation



#### **Features**

- Up to 32 tasks registered
- · Request a task to be executed
- Task pause and resume
- Wait for a specific event (not blocking)
- Priority on tasks
- Allow management of an IDLE task

Does not provide preemption mechanisms
Alternative to ThreadX or FreeRTOS





# Sequencer – implementation

#### Sequencer API

UTIL\_SEQ\_RegTask()



register a function

UTIL\_SEQ\_SetTask()



schedule task for execution

UTIL\_SEQ\_Run()



background while loop, execute scheduled task called in main while loop





#### Time server

#### Timing of events within the system

Facilities to enable application timer



#### **Features**

- Single shot or repeated mode
- Use RTC IP (sourced by LSE)

API (not complete list)

UTIL\_TIMER\_Create()



initialize the timer server

UTIL\_TIMER\_Start()
UTIL\_TIMER\_Stop()



start or stop timeserver

UTIL\_TIMER\_DeInit()



delete a virtual timeserver





# Real time debug

## GPIO real time signalization of events on low layers



#### Signals:

- Start/end of an interrupt
- Start/end of each a process
- Identification of specific procedures and machine states

Association of the SW signal to the desired GPIO at compilation time





# Debug and traces

## Examples in repository are delivered with low power focus

- Low power modes enabled
- Debug pins disabled
- LED signalization disabled
- BLE traces over UART disabled

Setting in app\_conf.h:

CFG\_LPM\_SUPPORTED = 1

CFG\_DBG\_SUPPORTED = 0

CFG\_LED\_SUPPORTED = 0

CFG\_DEBUG\_APP\_TRACE = 0



# Q&A



# Thank you

© STMicroelectronics - All rights reserved.

ST logo is a trademark or a registered trademark of STMicroelectronics International NV or its affiliates in the EU and/or other countries. For additional information about ST trademarks, please refer to <a href="https://www.st.com/trademarks">www.st.com/trademarks</a>.
All other product or service names are the property of their respective owners.

