======== STM32WL5 ======== The STM32WL5 is a dual CPU (not core!) chip based on ARM Cortex-M4 and Cortex-M0 with integrated sub-GHz radio for LoRa (G)FSK, (G)MSK and BPSK modulations. Only Cortex-M0 has access to radio peripheral. Pipe between CPUs exists so that radio packets can be exchanged between CPUs. Chip was designed so that Cortex-M0 cpu handles radio traffic while Cortex-M4 cpu handles actions based on traffic received. All other peripherals are shared (like uart, spi, i2c) and both CPUs can initiate them, but it's required to be done only by one of them. Supported MCUs ============= STM32WL5 has only two chips in family. STM32WL55 and STM32WL54. Only difference between them is that STM32WL55 has support for LoRa while Stm32WL54 does not. Peripheral Support ================== The following list indicates peripherals supported in NuttX: ========== ======= ===== Peripheral Support Notes ========== ======= ===== IRQs Yes GPIO Yes EXTI Yes HSE Yes PLL Yes Tested @ 48MHz HSI Yes Not tested MSI Yes Not tested LSE Yes Not tested RCC Yes All registers defined, not all peripherals enabled SYSCFG Yes All registers defined, GPIO EXTI works, remapping not tested USART Yes LPUART Yes full speed with HSE works, low power mode with LSE not implemented FLASH Yes Progmem implementation - mtd filesystems like smartfs or nxffs work DMA No SRAM2 No SPI No I2C No RTC No Timers No PM No AES No RNG No CRC No WWDG No IWDG No ADC No DAC No IPCC No Radio@CPU0 No ========== ======= ===== PLL --- PLL is a module that allows MCU to generate higher (or lower) clocks than provided by the source. For example it can be used to drive system clock with 48MHz when 8MHz HSE crystal is installed. LSE --- Low speed external crystal. Can be used to clock RTC and/or independent watchdog (IWDG). LSE is usually 32768Hz high precision crystal. HSI --- High speed internal clock. Can be used as a source for sysclk and internal buses (APB, AHB). This clock source is not as precise or as stable as HSE, but it cuts down costs by avoiding external hardware (crystal and capacitors) and is usually good enough if operating temperatures are stable. It's clock is fixed at 16MHz. MSI --- Adjustable internal clock. Can be adjusted by software, but it's accuracy and stability is even lower than HSI. HSE --- High speed external crystal. Can be used to clock sysclk and internal buses (APB, AHB). External crystal is more precise and more stable than HSI. RCC --- Reset and clock control. Enables or disables specific peripherals. SYSCFG ------ System configuration controller. Can be used to remap memory or manage GPIO multiplexer for EXTI. GPIO ---- Pins can be configured using :c:func:`stm32wl5_configgpio` function. Writing to pins is done by :c:func:`stm32wl5_gpiowrite` function and reading is done by :c:func:`stm32wl5_gpioread`. UART ---- Universal Asynchronous Receiver/Transmitter module. UART is initialized automatically during MCU boot. IPCC ---- Inter-processor communication controller. IPCC is used to exchange data between Cortex-M4 and Cortex-M0 CPUs. EXTI ---- Extended interrupts and event controller. Extends interrupts not provided by NVIC. For example, there is only one interrupt for GPIO5..9 in NVIC, but thanks to EXTI we can differentiate which GPIO caused interrupt. Such interrupt first goes through EXTI and is then forwarded to main NVIC. EXTI for gpio can be enabled via `stm32wl5_gpiosetevent` function. FLASH ----- Place where program code lives. Part of flash can also be used to create small filesystems like nxffs or smartfs to hold persistent data between reboots without the need of attaching external flash or mmc card. Since flash has limited number of erases (writes) it's best to hold there only data that is no frequently updated (so, configuration is ok, logs are not). Supported Boards ================ .. toctree:: :glob: :maxdepth: 1 boards/*/*