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/stm32f407g_disc1/STM32F407VGTx_FLASH.ld). | ||
|  |   The above files were extracted from a dummy stm32cube project in February | ||
|  |   2019. |