53 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			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/stm32f407disco/STM32F407VGTx_FLASH.ld).
 | |
|   The above files were extracted from a dummy stm32cube project in February
 | |
|   2019.
 | 
