freertos fatfs usb_device usb_host lwip
STM32Cube is an STMicroelectronics original initiative to ease developers' life by reducing efforts, time and cost.
Classic CoreMW is a collection of middleware stacks and associated applications allowing RTOS management, File System operations and connectivity through USB and Ethernet. It is based on:
- ST's proprietary stacks: ST USB Device and ST USB Host
- Third parties' stacks: FreeRTOS, FatFS, and LwIP
- FreeRTOS Middleware and examples are delivered on STM32H5 in the form of X-CUBE-FREERTOS that is available from st.com, from GitHub and from STM32CubeMX.
- Only FatFs_RAMDISK_Standalone application is provided with preconfigured projects for EWARM, Keil MDK-ARM and STM32CubeIDE toolchains. All others are provided only with preconfigured projects for EWARM toolchain.
- Projects in this package have not been generated with STM32CubeMX (i.e., no .iocfiles are delivered).
This package is exclusively published on GitHub (and is neither available in STM32CubeMX nor STM32CubeIDE available on www.st.com). It contains the integration of the Classic CoreMW stacks with STM32H5 devices, allowing users to get quick access to pre-built projects integrating them.
- The repository containing this package has been created using the git submodulecommand. Please refer to the "How to use" section explaining how to clone this repository and how to get the latest updates.
The STM32H5 Classic CoreMW package contains the following applications:
| Middleware | Application | Short Description | 
|---|---|---|
| FatFs | FatFs_RAMDISK_Standalone | Shows how to use STM32Cube firmware with FatFs middleware component as a generic FAT file system module | 
| FatFs | FatFs_MultiAccess | Shows how to use STM32Cube firmware with FatFs middleware component as a generic FAT file system module | 
| FatFs | FatFs_uSD_Standalone | Shows how to use STM32Cube firmware with FatFs middleware component as a generic FAT file system module | 
| ST USB Device | HID_Standalone | Shows a typical application where the STM32 MCU is enumerated as a HID device | 
| ST USB Device | CDC_Standalone | Shows a typical application where the STM32 MCU is enumerated as a CDC device | 
| ST USB Device | DFU_Standalone | Shows a typical application where the STM32 MCU is enumerated as a DFU device | 
| ST USB Device | MSC_Standalone | Shows a typical application where the STM32 MCU is enumerated as a MSC device | 
| ST USB Host | HID_Standalone | Shows how to use USB host application based on the Human Interface Class (HID) to connect a mouse or a keyboard | 
| ST USB Host | MSC_Standalone | Shows how to use USB host application based on the Mass Storage Class (MSC) to communicate with a usb flash disk | 
| ST USB Host | DualClass_Standalone | Shows how to use USB host application based on the Dual Class support feature integrating Mass Storage (MSC) to communicate with a usb flash disk and Human Interface (HID) to connect a mouse or a keyboard | 
| LwIP | LwIP_TCP_Echo_Server | This application guides STM32Cube HAL API users to run TCP Echo Server application based on Raw API of LwIP TCP/IP stack | 
| LwIP | LwIP_TCP_Echo_Client | This application guides STM32Cube HAL API users to run TCP Echo Client application based on Raw API of LwIP TCP/IP stack | 
| LwIP | LwIP_UDP_Echo_Server | This application guides STM32Cube HAL API users to run UDP Echo Server application based on Raw API of LwIP TCP/IP stack | 
| LwIP | LwIP_UDP_Echo_Client | This application guides STM32Cube HAL API users to run UDP Echo Client application based on Raw API of LwIP TCP/IP stack | 
| LwIP | LwIP_HTTP_Server_Raw | This application guides STM32Cube HAL API users to run a http server application based on Raw API of LwIP TCP/IP stack | 
| LwIP | LwIP_HTTP_Server_Socket_RTOS | This application guides STM32Cube HAL API users to run a http server application based on Socket API of LwIP TCP/IP stack | 
| LwIP | LwIP_HTTP_Server_Netconn_RTOS | This application guides STM32Cube HAL API users to run a http server application based on Netconn API of LwIP TCP/IP stack | 
| LwIP | LwIP_UDPTCP_Echo_Server_Netconn_RTOS | This application guides STM32Cube HAL API users to run a UDP/TCP Echo Server application based on Netconn API of LwIP TCP/IP stack | 
| LwIP | LwIP_TFTP_Server | This application guides STM32Cube HAL API users to run a UDP/TCP Echo Server application based on Netconn API of LwIP TCP/IP stack | 
- All examples are provided only with pre-configured projects for EWARM toolchain.
- Projects in this package have not been generated with STM32CubeMX (i.e., no .iocfiles are delivered).
- STM32H5
- NUCLEO-H563ZI RevC
- STM32H573I-DK RevC
 
- IAR Embedded Workbench for ARM (EWARM) toolchain 9.20.4 + ST-LINKV3.Patch available here
- RealView Microcontroller Development Kit (MDK-ARM) toolchain V5.39 + ST-LINKV3.Patch available here
- STM32CubeIDE V1.17.0 + ST-LINKV3
This package has been developed and tested using the list of components detailed in the table below.
| Name | Version | 
|---|---|
| Cortex-M CMSIS | V5.9.0 | 
| STM32H5xx CMSIS | V1.4.0 | 
| STM32H5xx HAL | V1.5.0 | 
| BSP STM32H5xx NUCLEO | V1.1.1 | 
| BSP STM32H573I-DK | V1.1.0 | 
| BSP Common | V7.3.0 | 
| BSP lan8742 | V1.0.4 | 
| BSP tcpp0203 | V1.2.3 | 
| FreeRTOS | V10.6.2 | 
| FatFS | R0.15 | 
| LwIP | V2.2.0 | 
| STM32 USB Device Library | V2.11.3 | 
| STM32 USB Host Library | V3.5.3 | 
| STM32 USBPD Core Library | V4.1.1 | 
| STM32 USBPD Device Library | H5_V1.3.0 | 
This repository intrinsically contains the applications (projects and source files) located under folder ./Projects.
It also contains the CMSIS Core files under folder ./Drivers/CMSIS/Include for size optimization reason.
Other dependencies such as the HAL and BSP drivers, or the middleware libraries themselves are linked using the git submodule command.
Please check the instructions below for a proper use.
- USB-PD library is momentarily contained in this repository pending its publication on GitHub. Once published, it will be added as a submodule like the other components.
- To clone this repository along with the linked submodules, option --recursivehas to be specified as shown below.
git clone --recursive https://github.com/STMicroelectronics/stm32h5-classic-coremw-apps.git
- To get the latest updates, issue the following two commands (with the repository stm32h5-classic-coremw-appsas the current working directory).
git pull
git submodule update --init --recursive
- If GitHub "Download ZIP" option is used instead of the git clonecommand, then the required components have to be collected manually by the user.
- None
Please refer to the CONTRIBUTING.md guide.