Нет описания

sakumisu c9625ffa77 docs: release v1.6.1 3 дней назад
.github b9fbfb2999 feat(ci): add rt-thread test 1 месяц назад
class c9625ffa77 docs: release v1.6.1 2 дней назад
common c9625ffa77 docs: release v1.6.1 2 дней назад
core dce7491d17 update(core/usbh_otg): update usbh_initialize param 1 неделя назад
demo 7819186529 update(demo): change string index max to sizeof(string_descriptors) / sizeof(char *)) 3 недель назад
docs c9625ffa77 docs: release v1.6.1 2 дней назад
osal 362fec943a refactor: move cherryrb and cherrymp into common dir, rename with usb_ringbuffer and usb_mempool 2 месяцев назад
platform 58b8ca0244 refactor(platform/rtthread): move rt_usbd_msc here 1 месяц назад
port 9cafc902f9 fix(port/hpm): add sdk version check 2 недель назад
tests c9625ffa77 docs: release v1.6.1 2 дней назад
third_party febe71b30c fix(third_party/bluetooth): fix bugs in USB host BT HCI drivers 1 неделя назад
tools 859db28964 feat(class/display): add usb vendor display device driver 2 месяцев назад
zephyr 43692c0ba2 chore: update zephyr code 11 месяцев назад
.clang-format 8a143df509 first commit 4 лет назад
.cmake-format.json 4c8d448ca2 cmake_format (#305) 1 год назад
.gitattributes 4ef4a9be98 add gitattributes 4 лет назад
.gitignore 0c220ea127 chore: add build ci 5 месяцев назад
CMakeLists.txt c9625ffa77 docs: release v1.6.1 2 дней назад
CherryUSB.svg c51a6f35a6 feat(class/aoa): add usb aoa host 1 год назад
Kconfig 859db28964 feat(class/display): add usb vendor display device driver 2 месяцев назад
Kconfig.rtt 58b8ca0244 refactor(platform/rtthread): move rt_usbd_msc here 1 месяц назад
Kconfig.rttpkg c9625ffa77 docs: release v1.6.1 2 дней назад
LICENSE 8a143df509 first commit 4 лет назад
README.md c9625ffa77 docs: release v1.6.1 2 дней назад
README_zh.md c9625ffa77 docs: release v1.6.1 2 дней назад
SConscript 58b8ca0244 refactor(platform/rtthread): move rt_usbd_msc here 1 месяц назад
VERSION c9625ffa77 docs: release v1.6.1 2 дней назад
cherryusb.cmake 362fec943a refactor: move cherryrb and cherrymp into common dir, rename with usb_ringbuffer and usb_mempool 2 месяцев назад
cherryusb_config_template.h 081c87206f update(xbox): Xbox USB host driver support into build(#407) 2 месяцев назад
idf_component.yml c9625ffa77 docs: release v1.6.1 2 дней назад

README.md

English | 简体中文

CherryUSB

<a href="https://github.com/cherry-embedded/CherryUSB/releases"><img src="https://img.shields.io/github/release/cherry-embedded/CherryUSB.svg"></a>
<a href="https://github.com/cherry-embedded/CherryUSB/blob/master/LICENSE"><img src="https://img.shields.io/github/license/cherry-embedded/CherryUSB.svg?style=flat-square"></a>
<a href="https://github.com/cherry-embedded/CherryUSB/actions/workflows/deploy-docs.yml"><img src="https://github.com/cherry-embedded/CherryUSB/actions/workflows/deploy-docs.yml/badge.svg"> </a>
<a href="https://discord.com/invite/wFfvrSAey8"><img src="https://img.shields.io/badge/Discord-blue?logo=discord&style=flat-square"> </a>

CherryUSB is a tiny and beautiful, high performance and portable USB host and device stack for embedded system with USB IP.

CherryUSB

Why choose CherryUSB

Easy to Learn USB

To facilitate user learning of USB fundamentals, enumeration, driver loading, and IP drivers, the written code has the following advantages:

  • Streamlined code with simple logic and no complex C language syntax
  • Tree-structured programming with progressive code layers
  • Templated and simplified Class drivers and porting drivers
  • Clear API categorization (Device: initialization, class registration, command callbacks, data transmission; Host: initialization, class discovery, data transmission)

Easy to Use USB

To facilitate user interaction with USB interfaces, considering users’ familiarity with UART and DMA, the designed data transmission interface has the following advantages:

  • Equivalent to using UART TX DMA/UART RX DMA
  • No length restrictions on transmission/reception; users don’t need to worry about USB packetization (porting drivers handle packetization)

Easy to Achieve USB Performance

Considering USB performance requirements to reach theoretical USB hardware bandwidth, the designed data transmission interface has the following advantages:

  • Porting drivers directly interface with registers without abstraction layer encapsulation
  • Memory zero copy
  • DMA mode used when IP supports DMA (DMA provides hardware packetization functionality)
  • No length restrictions, facilitating hardware DMA interfacing and maximizing DMA advantages
  • Packetization handled in interrupt context

Performance show:https://cherryusb.cherry-embedded.org/show/

Directory Structure

Directory Description
class usb class driver
common usb spec macros and utils
core usb core implementation
demo usb device and host demo
osal os wrapper
platform class support for other os
docs doc for guiding
port usb dcd and hcd porting
tools tool url

Device Stack Overview

CherryUSB Device Stack provides a unified framework of functions for standard device requests, CLASS requests, VENDOR requests and custom special requests. The object-oriented and chained approach allows the user to quickly get started with composite devices without having to worry about the underlying logic. At the same time, a standard dcd porting interface has been standardised for adapting different USB IPs to achieve ip-oriented programming.

CherryUSB Device Stack has the following functions:

  • Support USB2.0 full and high speed(USB3.0 super speed TODO)
  • Support endpoint irq callback register by users, let users do whatever they wants in endpoint irq callback.
  • Support Composite Device
  • Support Communication Device Class (CDC_ACM, CDC_ECM)
  • Support Human Interface Device (HID)
  • Support Mass Storage Class (MSC)
  • Support USB VIDEO CLASS (UVC1.0, UVC1.5)
  • Support USB AUDIO CLASS (UAC1.0, UAC2.0)
  • Support Remote NDIS (RNDIS)
  • Support Device Firmware Upgrade CLASS (DFU)
  • Support USB MIDI CLASS (MIDI)
  • Support Media Transfer Protocol (MTP)
  • Support Test and Measurement Class (TMC)
  • Support WINUSB1.0, WINUSB2.0, WEBUSB, BOS
  • Support Vendor display (xfz1986_usb_graphic_driver)
  • Support Vendor class
  • Support UF2
  • Support Android Debug Bridge (Only support shell)
  • Support multi device with the same USB IP

CherryUSB Device Stack resource usage (GCC 10.2 with -O2, disable log):

file FLASH (Byte) No Cache RAM (Byte) RAM (Byte) Heap (Byte)
usbd_core.c ~4000 (512(default) + 320) * bus 8 0
usbd_cdc_acm.c ~400 0 0 0
usbd_msc.c ~3200 (128 + 512(default)) * bus 16 * bus 0
usbd_hid.c ~200 0 0 0
usbd_audio.c ~1300 0 8 * bus 0
usbd_video.c ~2500 0 124 * bus 0
usbd_rndis.c ~2000 2 * 1580(default)+156+8 76 0
usbd_cdc_ecm.c ~1500 2 * 1514(default)+16 42 0
usbd_mtp.c ~9000 2048(default)+128 sizeof(struct mtp_object) * n 0
usbd_dfu.c ~800 0 1 0

usbdevice_usage

Host Stack Overview

The CherryUSB Host Stack has a standard enumeration implementation for devices mounted on root hubs and external hubs, and a standard interface for different Classes to indicate what the Class driver needs to do after enumeration and after disconnection. A standard hcd porting interface has also been standardised for adapting different USB IPs for IP-oriented programming. Finally, the host stack is managed using os, and provides osal to make a adaptation for different os.

CherryUSB Host Stack has the following functions:

  • Support low speed, full speed, high speed and super speed devices
  • Automatic loading of supported Class drivers
  • Support blocking transfers and asynchronous transfers
  • Support Composite Device
  • Multi-level HUB support, expandable up to 7 levels(Testing hub with 10 ports works well,only support dwc2/ehci/xhci/rp2040)
  • Support Communication Device Class (CDC_ACM, CDC_ECM, CDC_NCM)
  • Support Human Interface Device (HID)
  • Support Mass Storage Class (MSC)
  • Support USB Video CLASS (UVC1.0, UVC1.5)
  • Support USB Audio CLASS (UAC1.0)
  • Support Remote NDIS (RNDIS)
  • Support Device Firmware Upgrade CLASS (DFU)
  • Support USB Bluetooth class (support nimble and zephyr bluetooth stack, support CLASS:0xE0 or vendor class like cdc acm)
  • Support Vendor Serial Class(CH34X、CP210X、PL2303、FTDI、GSM)
  • Support Vendor network Class(RTL8152、AX88772)
  • Support USB modeswitch
  • Support Android Open Accessory
  • Support multi host with the same USB IP

The CherryUSB Host stack also provides the lsusb function, which allows you to view information about all mounted devices, including those on external hubs, with the help of a shell plugin.

CherryUSB Host Stack resource usage (GCC 10.2 with -O2, disable log):

file FLASH (Byte) No Cache RAM (Byte) RAM (Byte) Heap (Byte)
usbh_core.c ~4000 (512(default) + 8 * (1+x) *n) * bus sizeof(struct usbh_hub) * bus raw_config_desc
usbh_hub.c ~3000 (32 + 4 * (1+x)) * bus 12 + sizeof(struct usbh_hub) * x 0
usbh_msc.c ~1500 128 * x 4 + sizeof(struct usbh_msc) * x 0
usbh_hid.c ~2000 64 * x 4 + sizeof(struct usbh_hid) * x 0
usbh_video.c ~2500 128 * x 4 + sizeof(struct usbh_video) * x 0
usbh_audio.c ~3000 128 * x 4 + sizeof(struct usbh_audio) * x 0
usbh_rndis.c ~3000 512 + 2 * 2048(default) sizeof(struct usbh_rndis) * 1 0
usbh_cdc_ecm.c ~1500 2 * 1514 + 16 sizeof(struct usbh_cdc_ecm) * 1 0
usbh_cdc_ncm.c ~2000 2 * 2048(default) + 16 + 32 sizeof(struct usbh_cdc_ncm) * 1 0
usbh_bluetooth.c ~1000 2 * 2048(default) sizeof(struct usbh_bluetooth) * 1 0
usbh_asix.c ~3500 2 * 2048(default) + 16 + 32 sizeof(struct usbh_asix) * 1 0
usbh_rtl8152.c ~5500 16K+ 2K(default) + 2 + 32 sizeof(struct usbh_rtl8152) * 1 0
usbh_serial.c ~3000 (512 * 2 + 32 * 2) * x sizeof(struct usbh_serial) * x (2048 default) 0
usbh_cdc_acm.c ~1000 0 0 0
usbh_ch340.c ~1200 0 0 0
usbh_ftdi.c ~1200 0 0 0
usbh_cp2102.c ~2200 0 0 0
usbh_pl2303.c ~2500 0 0 0
usbh_gsm.c ~300 0 0 0

usbhost_usage

Among them, sizeof(struct usbh_hub) and sizeof(struct usbh_hubport) are affected by the following macros:

#define CONFIG_USBHOST_MAX_EXTHUBS          1
#define CONFIG_USBHOST_MAX_EHPORTS          4
#define CONFIG_USBHOST_MAX_INTERFACES       8
#define CONFIG_USBHOST_MAX_INTF_ALTSETTINGS 2
#define CONFIG_USBHOST_MAX_ENDPOINTS        4

x is affected by the following macros:

#define CONFIG_USBHOST_MAX_SERIAL_CLASS  4
#define CONFIG_USBHOST_MAX_HID_CLASS     4
#define CONFIG_USBHOST_MAX_MSC_CLASS     2
#define CONFIG_USBHOST_MAX_AUDIO_CLASS   1
#define CONFIG_USBHOST_MAX_VIDEO_CLASS   1

USB IP Support

Only standard and commercial USB IP are listed.

IP device host Support status
OHCI(intel) none OHCI
EHCI(intel) none EHCI
XHCI(intel) none XHCI
UHCI(intel) none UHCI ×
DWC2(synopsys) DWC2 DWC2
MUSB(mentor) MUSB MUSB
FOTG210(faraday) FOTG210 EHCI
CHIPIDEA(synopsys) CHIPIDEA EHCI
CDNS2(cadence) CDNS2 CDNS2
CDNS3(cadence) CDNS3 XHCI ×
DWC3(synopsys) DWC3 XHCI ×

Resources

Getting Started

Tools

Community Or Commercial Support

Package Support

Mirror URL

Company Support

Thanks to the following companies for their support (in no particular order):