tinyusb/hw/mcu/st/README.md
William D. Jones 49aa6ec251 st: Use submodules for system files when possible, use more up to date
files otherwise. Update STM32F4-DISCOVERY demo and board.mk to reflect
changes.
2019-03-04 10:41:05 -05:00

53 lines
2.9 KiB
Markdown

This README describes the layout of system files and headers for
microcontrollers supported by tinyusb from the vendor [ST](www.st.com).
The CMSIS by ARM is an attempt to unify how system initialization and headers
for ARM microcontrollers are handled across vendors. A vendor is expected to
provide a number of files, including vendor-specific device headers,
vendor-specific system init code (in C), vendor-specific startup code (coded in
assembly _and_ meant to make writing C interrupt handlers easy), and ARM
architecture-specific headers. In practice, it's actually difficult to find all
these files in one place.
* stm32cube generates a self-contained application. All the relevant headers,
system init, and startup code are under `Drivers/CMSIS`. The linker script is
stored at the root of your project, _along_ with a copy of the startup code.
Relative to `Drivers/CMSIS`:
* Device header files are stored under `Device/ST/$family/Include`.
* Arm-provided CMSIS headers are stored under `Include`.
* The portable C portion of the startup code, called `system_$family.c`, is
stored under `Device/ST/$family/Source/Templates`. This "system init" code
is required by CMSIS.
* The assembly portion of the startup code, called `startup_$device.c`, is
stored under `Device\ST\STM32F4xx\Source\Templates\gcc`.
* Micropython maintains [a repo](https://github.com/micropython/stm32lib)
with _only_ the device header files. We use that
repo and provide the remaining files ourselves.
* Micropython keeps the linker script and assembly portion of the startup
code under the
[boards](https://github.com/micropython/micropython/tree/master/ports/stm32/boards)
directory in the stm32 port (but the code is board agnostic).
* Micropython also embeds its own
[copy](https://github.com/micropython/micropython/tree/master/lib/cmsis/inc)
of CMSIS headers for all ARM targets into the repo.
* Micropython indeed _does_ use their own custom C startup code (CMSIS system
init) for
[stm32](https://github.com/micropython/micropython/blob/master/ports/stm32/system_stm32.c)
targets. It is
[missing](https://github.com/micropython/micropython/commit/fdbc22e4d27b9d1c686647c9c67a32206f7bc83a)
the `SystemCoreClockUpdate` function.
* TinyUSB uses Micropython's [stm32lib](stm32lib) as a submodule to provide
device headers. The remaining system files can be found in the following
directories:
* C system init code is in the [system-init](system-init) directory.
* Assembly startup code is in the [startup](startup) directory. Each family
gets its own subdirectory under startup (e.g. [stm32f4](startup/stm32f4)).
* ARM-provided headers are stored in the [cmsis](cmsis) directory.
* The linker script for the STM32F4-DISCOVERY board demo is supplied as
part of TinyUSB's
[Board Support Packages](../../bsp/stm32f407g_disc1/STM32F407VGTx_FLASH.ld).
The above files were extracted from a dummy stm32cube project in February
2019.