| # Boards |
| |
| The board support code is only used for self-contained examples and testing. It is not used when TinyUSB is part of a larger project. It is responsible for getting the MCU started and the USB peripheral clocked with minimal of on-board devices |
| - One LED : for status |
| - One Button : to get input from user |
| - One UART : optional for device, but required for host examples |
| |
| ## Supported Boards |
| |
| This code base already had supported for a handful of following boards (sorted alphabetically) |
| |
| ### Dialog DA146xx |
| |
| - [DA14695 Development Kit – USB](https://www.dialog-semiconductor.com/products/da14695-development-kit-usb) |
| - [DA1469x Development Kit – Pro](https://www.dialog-semiconductor.com/products/da14695-development-kit-pro) |
| |
| ### Espressif ESP32-S2 |
| |
| - Adafruit Feather ESP32-S2 |
| - [Adafruit Magtag 2.9" E-Ink WiFi Display](https://www.adafruit.com/product/4800) |
| - [Adafruit Metro ESP32-S2](https://www.adafruit.com/product/4775) |
| - [ESP32-S2-Kaluga-1](https://docs.espressif.com/projects/esp-idf/en/latest/esp32s2/hw-reference/esp32s2/user-guide-esp32-s2-kaluga-1-kit.html) |
| - [ESP32-S2-Saola-1](https://docs.espressif.com/projects/esp-idf/en/latest/esp32s2/hw-reference/esp32s2/user-guide-saola-1-v1.2.html) |
| |
| ### MicroChip SAMD11 & SAMD21 |
| |
| - [Adafruit Circuit Playground Express](https://www.adafruit.com/product/3333) |
| - [Adafruit Feather M0 Express](https://www.adafruit.com/product/3403) |
| - [Adafruit ItsyBitsy M0 Express](https://www.adafruit.com/product/3727) |
| - [Adafruit Metro M0 Express](https://www.adafruit.com/product/3505) |
| - [Great Scott Gadgets LUNA](https://greatscottgadgets.com/luna/) |
| - [Microchip SAMD11 Xplained Pro](https://www.microchip.com/developmenttools/ProductDetails/atsamd11-xpro) |
| - [Microchip SAMD21 Xplained Pro](https://www.microchip.com/DevelopmentTools/ProductDetails/ATSAMD21-XPRO) |
| - [Seeeduino Xiao](https://www.seeedstudio.com/Seeeduino-XIAO-Arduino-Microcontroller-SAMD21-Cortex-M0+-p-4426.html) |
| |
| ### MicroChip SAMD51 & SAME54 |
| |
| - [Adafruit Feather M4 Express](https://www.adafruit.com/product/3857) |
| - [Adafruit ItsyBitsy M4 Express](https://www.adafruit.com/product/3800) |
| - [Adafruit PyBadge](https://www.adafruit.com/product/4200) |
| - [Adafruit PyPortal](https://www.adafruit.com/product/4116) |
| - [Adafruit Metro M4 Express](https://www.adafruit.com/product/3382) |
| - [D5035-01](https://github.com/RudolphRiedel/USB_CAN-FD) |
| - [Microchip SAME54 Xplained Pro](https://www.microchip.com/developmenttools/productdetails/atsame54-xpro) |
| |
| ### MicroChip SAMG |
| |
| - [Microchip SAMG55 Xplained Pro](https://www.microchip.com/DevelopmentTools/ProductDetails/PartNO/ATSAMG55-XPRO) |
| |
| ### MicroChip SAML2x |
| |
| - [SAML21 Xplaind Pro](https://www.microchip.com/DevelopmentTools/ProductDetails/ATSAML21-XPRO-B) |
| - [SAML22 Feather](https://github.com/joeycastillo/Feather-Projects/tree/main/SAML22%20Feather) |
| - [Sensor Watch](https://github.com/joeycastillo/Sensor-Watch) |
| |
| ### Nordic nRF5x |
| |
| - [Adafruit Circuit Playground Bluefruit](https://www.adafruit.com/product/4333) |
| - [Adafruit CLUE](https://www.adafruit.com/product/4500) |
| - [Adafruit Feather nRF52840 Express](https://www.adafruit.com/product/4062) |
| - [Adafruit Feather nRF52840 Sense](https://www.adafruit.com/product/4516) |
| - [Adafruit ItsyBitsy nRF52840 Express](https://www.adafruit.com/product/4481) |
| - [Arduino Nano 33 BLE](https://store.arduino.cc/usa/nano-33-ble) |
| - [Arduino Nano 33 BLE Sense](https://store.arduino.cc/usa/nano-33-ble-sense) |
| - [Maker Diary nRF52840 MDK Dongle](https://wiki.makerdiary.com/nrf52840-mdk-usb-dongle) |
| - [Nordic nRF52840 Development Kit (aka pca10056)](https://www.nordicsemi.com/Software-and-Tools/Development-Kits/nRF52840-DK) |
| - [Nordic nRF52840 Dongle (aka pca10059)](https://www.nordicsemi.com/Software-and-Tools/Development-Kits/nRF52840-Dongle) |
| - [Nordic nRF52833 Development Kit (aka pca10100)](https://www.nordicsemi.com/Software-and-Tools/Development-Kits/nRF52833-DK) |
| - [Raytac MDBT50Q-RX Dongle](https://www.raytac.com/product/ins.php?index_id=89) |
| |
| ### Nuvoton |
| |
| - NuTiny SDK NUC120 |
| - [NuTiny NUC121S](https://direct.nuvoton.com/en/nutiny-nuc121s) |
| - [NuTiny NUC125S](https://direct.nuvoton.com/en/nutiny-nuc125s) |
| - [NuTiny NUC126V](https://direct.nuvoton.com/en/nutiny-nuc126v) |
| - [NuTiny SDK NUC505Y](https://direct.nuvoton.com/en/nutiny-nuc505y) |
| |
| ### NXP iMX RT |
| |
| - [MIMX RT1010 Evaluation Kit](https://www.nxp.com/design/development-boards/i.mx-evaluation-and-development-boards/i.mx-rt1010-evaluation-kit:MIMXRT1010-EVK) |
| - [MIMX RT1015 Evaluation Kit](https://www.nxp.com/design/development-boards/i.mx-evaluation-and-development-boards/i.mx-rt1015-evaluation-kit:MIMXRT1015-EVK) |
| - [MIMX RT1020 Evaluation Kit](https://www.nxp.com/design/development-boards/i.mx-evaluation-and-development-boards/i.mx-rt1020-evaluation-kit:MIMXRT1020-EVK) |
| - [MIMX RT1050 Evaluation Kit](https://www.nxp.com/design/development-boards/i.mx-evaluation-and-development-boards/i.mx-rt1050-evaluation-kit:MIMXRT1050-EVK) |
| - [MIMX RT1060 Evaluation Kit](https://www.nxp.com/design/development-boards/i.mx-evaluation-and-development-boards/mimxrt1060-evk-i.mx-rt1060-evaluation-kit:MIMXRT1060-EVK) |
| - [MIMX RT1064 Evaluation Kit](https://www.nxp.com/design/development-boards/i.mx-evaluation-and-development-boards/mimxrt1064-evk-i.mx-rt1064-evaluation-kit:MIMXRT1064-EVK) |
| - [Teensy 4.0 Development Board](https://www.pjrc.com/store/teensy40.html) |
| |
| ### NXP Kinetis |
| |
| - [FRDM-KL25Z](https://www.nxp.com/design/development-boards/freedom-development-boards/mcu-boards/freedom-development-platform-for-kinetis-kl14-kl15-kl24-kl25-mcus:FRDM-KL25Z) |
| |
| ### NXP LPC 11-13-15 |
| |
| - [LPCXpresso 11u37](https://www.nxp.com/design/microcontrollers-developer-resources/lpcxpresso-boards/lpcxpresso-board-for-lpc11u37h:OM13074) |
| - [LPCXpresso 11u68](https://www.nxp.com/support/developer-resources/evaluation-and-development-boards/lpcxpresso-boards/lpcxpresso-board-for-lpc11u68:OM13058) |
| - [LPCXpresso 1347](https://www.nxp.com/support/developer-resources/evaluation-and-development-boards/lpcxpresso-boards/lpcxpresso-board-for-lpc1347:OM13045) |
| - [LPCXpresso 1549](https://www.nxp.com/products/processors-and-microcontrollers/arm-microcontrollers/general-purpose-mcus/lpc1500-cortex-m3/lpcxpresso-board-for-lpc1549:OM13056) |
| |
| ### NXP LPC 17-40 |
| |
| - [ARM mbed LPC1768](https://www.nxp.com/products/processors-and-microcontrollers/arm-microcontrollers/general-purpose-mcus/lpc1700-cortex-m3/arm-mbed-lpc1768-board:OM11043) |
| - [Embedded Artists LPC4088 Quick Start board](https://www.embeddedartists.com/products/lpc4088-quickstart-board) |
| - [LPCXpresso 1769](https://www.nxp.com/support/developer-resources/evaluation-and-development-boards/lpcxpresso-boards/lpcxpresso-board-for-lpc1769:OM13000) |
| |
| ### NXP LPC 18-43 |
| |
| - [Embedded Artists LPC4357 Developer Kit](http://www.embeddedartists.com/products/kits/lpc4357_kit.php) |
| - [Keil MCB1800 Evaluation Board](http://www.keil.com/mcb1800) |
| - [LPCXpresso18S37 Development Board](https://www.nxp.com/products/processors-and-microcontrollers/arm-microcontrollers/general-purpose-mcus/lpc4000-cortex-m4/lpcxpresso18s37-development-board:OM13076) |
| - [NGX LPC4330-Xplorer](https://www.nxp.com/design/designs/lpc4330-xplorer-board:OM13027) |
| |
| ### NXP LPC 51 |
| - [LPCXpresso 51U68](https://www.nxp.com/products/processors-and-microcontrollers/arm-microcontrollers/general-purpose-mcus/lpcxpresso51u68-for-the-lpc51u68-mcus:OM40005) |
| |
| ### NXP LPC 54 |
| |
| - [LPCXpresso 54114](https://www.nxp.com/design/microcontrollers-developer-resources/lpcxpresso-boards/lpcxpresso54114-board:OM13089) |
| |
| ## NXP LPC55 |
| |
| - [Double M33 Express](https://www.crowdsupply.com/steiert-solutions/double-m33-express) |
| - [LPCXpresso 55s28 EVK](https://www.nxp.com/design/software/development-software/lpcxpresso55s28-development-board:LPC55S28-EVK) |
| - [LPCXpresso 55s69 EVK](https://www.nxp.com/design/development-boards/lpcxpresso-boards/lpcxpresso55s69-development-board:LPC55S69-EVK) |
| - [MCU-Link](https://www.nxp.com/design/development-boards/lpcxpresso-boards/mcu-link-debug-probe:MCU-LINK) |
| |
| ### Renesas RX |
| |
| - [GR-CITRUS](https://www.renesas.com/us/en/products/gadget-renesas/boards/gr-citrus) |
| - [Renesas RX65N Target Board](https://www.renesas.com/us/en/products/microcontrollers-microprocessors/rx-32-bit-performance-efficiency-mcus/rtk5rx65n0c00000br-target-board-rx65n) |
| |
| ### Raspberry Pi RP2040 |
| |
| - [Adafruit Feather RP2040](https://www.adafruit.com/product/4884) |
| - [Adafruit ItsyBitsy RP2040](https://www.adafruit.com/product/4888) |
| - [Adafruit QT Py RP2040](https://www.adafruit.com/product/4900) |
| - [Raspberry Pi Pico](https://www.raspberrypi.org/products/raspberry-pi-pico/) |
| |
| ### Silabs |
| |
| - [EFM32GG12 Thunderboard Kit (SLTB009A)](https://www.silabs.com/development-tools/thunderboard/thunderboard-gg12-kit) |
| |
| ### Sony |
| |
| - [Sony Spresense CXD5602](https://developer.sony.com/develop/spresense) |
| |
| ### ST STM32 |
| |
| - [Adafruit Feather STM32F405](https://www.adafruit.com/product/4382) |
| - [Micro Python PyBoard v1.1](https://store.micropython.org/product/PYBv1.1) |
| - [STLink-V3 Mini](https://www.st.com/en/development-tools/stlink-v3mini.html) |
| - [STM32 L035c8 Discovery](https://www.st.com/en/evaluation-tools/32l0538discovery.html) |
| - [STM32 L4R5zi Nucleo](https://www.st.com/en/evaluation-tools/nucleo-l4r5zi.html) |
| - [STM32 F070rb Nucleo](https://www.st.com/en/evaluation-tools/nucleo-f070rb.html) |
| - [STM32 F072 Evaluation](https://www.st.com/en/evaluation-tools/stm32072b-eval.html) |
| - [STM32 F072rb Discovery](https://www.st.com/en/evaluation-tools/32f072bdiscovery.html) |
| - STM32 F103c Blue Pill |
| - [STM32 F207zg Nucleo](https://www.st.com/en/evaluation-tools/nucleo-f207zg.html) |
| - [STM32 F303vc Discovery](https://www.st.com/en/evaluation-tools/stm32f3discovery.html) |
| - STM32 F401cc Black Pill |
| - [STM32 F407vg Discovery](https://www.st.com/en/evaluation-tools/stm32f4discovery.html) |
| - [STM32 F411ce Black Pill](https://www.adafruit.com/product/4877) |
| - [STM32 F411ve Discovery](https://www.st.com/en/evaluation-tools/32f411ediscovery.html) |
| - [STM32 F412zg Discovery](https://www.st.com/en/evaluation-tools/32f412gdiscovery.html) |
| - [STM32 F723e Discovery](https://www.st.com/en/evaluation-tools/32f723ediscovery.html) |
| - [STM32 F746zg Nucleo](https://www.st.com/en/evaluation-tools/nucleo-f746zg.html) |
| - [STM32 F746g Discovery](https://www.st.com/en/evaluation-tools/32f746gdiscovery.html) |
| - [STM32 F767zi Nucleo](https://www.st.com/en/evaluation-tools/nucleo-f767zi.html) |
| - [STM32 F769i Discovery](https://www.st.com/en/evaluation-tools/32f769idiscovery.html) |
| - [STM32 H743zi Nucleo](https://www.st.com/en/evaluation-tools/nucleo-h743zi.html) |
| - [STM32 H743i Evaluation](https://www.st.com/en/evaluation-tools/stm32h743i-eval.html) |
| - [STM32 H745i Discovery](https://www.st.com/en/evaluation-tools/stm32h745i-disco.html) |
| - [Waveshare OpenH743I-C](https://www.waveshare.com/openh743i-c-standard.htm) |
| |
| ### TI |
| |
| - [MSP430F5529 USB LaunchPad Evaluation Kit](http://www.ti.com/tool/MSP-EXP430F5529LP) |
| |
| ### Tomu |
| |
| - [Fomu](https://www.crowdsupply.com/sutajio-kosagi/fomu) |
| |
| ## Add your own board |
| |
| If you don't possess any of supported board above. Don't worry you can easily implemented your own one by following this guide as long as the mcu is supported. |
| |
| - Create new makefile for your board at `hw/bsp/<board name>/board.mk` and linker file as well if needed. |
| - Create new source file for your board at `hw/bsp/<board name>/<board name>.c` and implement following APIs |
| |
| ### Board APIs |
| |
| #### board_init() |
| |
| Is responsible for starting the MCU, setting up the USB clock and USB pins. It is also responsible for initializing LED and button pins. |
| One useful clock debugging technique is to set up a PWM output at a known value such as 500hz based on the USB clock so that you can verify it is correct with a logic probe or oscilloscope. |
| Setup your USB in a crystal-less mode when available. That makes the code easier to port across boards. |
| |
| #### board_led_write() |
| |
| Set the pin corresponding to the led to output a value that lights the LED when `state` is true. |
| |
| #### board_button_read() |
| |
| Return current state of button, a `1` means active (pressed), a `0` means inactive. |
| |
| #### board_millis() |
| |
| The function returns the elapsed number of milliseconds since startup. On ARM this is commonly done with SysTick or Timer. This provide examples a way to measure time to blink LED or delay properly. It is only required when run examples without RTOS `CFG_TUSB_OS == OPT_OS_NONE`. |
| |
| #### board_uart_read() |
| |
| Get characters from UART peripheral. |
| |
| #### board_uart_write() |
| |
| Send characters to UART peripheral. |