2018-03-23 12:42:30 +07:00
2014-04-17 13:03:19 +07:00
2018-03-23 12:42:30 +07:00
2018-03-23 12:32:40 +07:00
2018-03-23 12:42:30 +07:00
2018-03-23 12:42:30 +07:00
2014-04-16 12:05:14 +07:00
2018-03-07 15:30:32 +07:00
2014-04-18 22:53:42 +07:00

tinyusb

Table of Contents

tinyusb is an open-source (BSD-licensed) USB Host/Device/OTG stack for embedded micro-controllers, especially ARM MCUs. It is designed to be user-friendly in term of configuration and out-of-the-box running experience.

In addition to running without an RTOS, tinyusb is an OS-awared stack that can run across RTOS vendors. For the purpose of eliminating bugs as soon as possible, the stack is developed using Test-Driven Development (TDD) approach. More documents and API reference can be found at http://docs.tinyusb.org

tinyusb diagram

Features

Host

  • HID Mouse
  • HID Keyboard
  • HID Generic (comming soon)
  • Communication Device Class (CDC)
  • Mass Storage Class (MSC)
  • Hub currnetly only support 1 level of hub (due to my laziness)

Device

  • HID Mouse
  • HID Keyboard
  • HID Generic (comming soon)
  • Communication Class (CDC)
  • Mass Storage Class (MSC)

RTOS

Currently the following OS are supported with tinyusb out of the box with a simple change of TUSB_CFG_OS macro.

  • None OS
  • FreeRTOS
  • CMSIS RTX

Toolchains

You can compile with any of following toolchains, however, the stack requires C99 to build with

  • lpcxpresso
  • Keil MDK
  • IAR Workbench

Supported MCUs

The stack supports the following MCUs

  • LPC11uxx
  • LPC13uxx (12 bit ADC)
  • LPC175x_6x
  • LPC43xx

Here is the list of supported Boards in the code base

Getting Started

Here is the details for getting started with the stack.

License

BSD license for most of the code base, but each file is individually licensed especially those in vendor folder. Please make sure you understand all the license term for files you use in your project. Full license is here

How Can I Help

If you find my little USB stack is useful and want to give something back

Donate Time

You can contribute your time by helping with programming, testing and filing bug reports, improving documentation. Or simply by using tinyusb, giving me some feedback on how to improve it and telling others about it.

Donate Money

If you don't have time but still want to help, then please consider making a financial donation. This will help to pay the (mostly coffee) bills and motivate me to continue working on tinyusb. You can do so using the donation button, or contact me for other payment methods.

Click here to lend your support to tinyusb donation and make a donation at pledgie.com //: # (\endhtmlonly)

Description
一个usb库
Readme MIT 42 MiB
Languages
C 96.6%
Python 1.4%
C++ 1.1%
CMake 0.5%
Makefile 0.2%
Other 0.2%