Files
CherryUSB/README.md

212 lines
12 KiB
Markdown
Raw Permalink Normal View History

**English | [简体中文](README_zh.md)**
2024-12-23 20:04:02 +08:00
<h1 align="center" style="margin: 30px 0 30px; font-weight: bold;">CherryUSB</h1>
<p align="center">
<a href="https://github.com/cherry-embedded/CherryUSB/releases"><img src="https://img.shields.io/github/release/cherry-embedded/CherryUSB.svg"></a>
2024-12-23 20:04:02 +08:00
<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>
</p>
CherryUSB is a tiny and beautiful, high performance and portable USB host and device stack for embedded system with USB IP.
2021-11-30 21:43:33 +08:00
2024-03-08 17:30:21 +08:00
![CherryUSB](CherryUSB.svg)
2022-05-21 16:50:01 +08:00
## Why choose CherryUSB
2022-05-25 11:00:17 +08:00
### Easy to Learn USB
2023-06-03 16:23:16 +08:00
To facilitate user learning of USB fundamentals, enumeration, driver loading, and IP drivers, the written code has the following advantages:
2023-06-03 16:23:16 +08:00
- 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)
2023-06-03 16:23:16 +08:00
### Easy to Use USB
2023-06-03 16:23:16 +08:00
To facilitate user interaction with USB interfaces, considering users familiarity with UART and DMA, the designed data transmission interface has the following advantages:
2023-06-03 16:23:16 +08:00
- Equivalent to using UART TX DMA/UART RX DMA
- No length restrictions on transmission/reception; users dont need to worry about USB packetization (porting drivers handle packetization)
2023-06-03 16:23:16 +08:00
### Easy to Achieve USB Performance
2023-06-03 16:23:16 +08:00
Considering USB performance requirements to reach theoretical USB hardware bandwidth, the designed data transmission interface has the following advantages:
2023-06-03 16:23:16 +08:00
- Porting drivers directly interface with registers without abstraction layer encapsulation
2023-06-03 16:23:16 +08:00
- 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
2022-05-25 11:00:17 +08:00
Performance showhttps://cherryusb.cherry-embedded.org/show/
2024-07-11 17:57:29 +08:00
## Directory Structure
2021-12-04 14:41:09 +08:00
2021-12-12 15:21:56 +08:00
| Directory | Description |
|:-------------:|:---------------------------:|
|class | usb class driver |
|common | usb spec macros and utils |
2023-06-04 14:42:57 +08:00
|core | usb core implementation |
|demo | usb device and host demo |
2023-06-04 14:42:57 +08:00
|osal | os wrapper |
|platform | class support for other os |
2023-06-04 14:42:57 +08:00
|docs | doc for guiding |
|port | usb dcd and hcd porting |
|tools | tool url |
2021-12-12 15:21:56 +08:00
2022-05-25 11:00:17 +08:00
## Device Stack Overview
2021-12-12 15:21:56 +08:00
2022-02-01 23:07:38 +08:00
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.
2021-12-12 15:21:56 +08:00
CherryUSB Device Stack has the following functions:
2021-12-12 15:21:56 +08:00
- Support USB2.0 full and high speed(USB3.0 super speed TODO)
2021-12-12 15:21:56 +08:00
- Support endpoint irq callback register by users, let users do whatever they wants in endpoint irq callback.
2022-04-04 15:54:53 +08:00
- Support Composite Device
2023-11-21 22:23:07 +08:00
- Support Communication Device Class (CDC_ACM, CDC_ECM)
2021-12-12 15:21:56 +08:00
- 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)
2021-12-12 15:21:56 +08:00
- Support Device Firmware Upgrade CLASS (DFU)
- Support USB MIDI CLASS (MIDI)
2022-04-04 15:54:53 +08:00
- Support Remote NDIS (RNDIS)
- Support Media Transfer Protocol (MTP)
- Support WINUSB1.0, WINUSB2.0, WEBUSB, BOS
- Support Vendor display ([xfz1986_usb_graphic_driver](https://github.com/chuanjinpang/win10_idd_xfz1986_usb_graphic_driver_display))
2021-12-12 21:49:21 +08:00
- Support Vendor class
2024-07-23 22:37:27 +08:00
- Support UF2
2024-08-17 20:58:56 +08:00
- Support Android Debug Bridge (Only support shell)
2024-03-17 22:54:04 +08:00
- Support multi device with the same USB IP
2021-12-12 15:21:56 +08:00
CherryUSB Device Stack resource usage (GCC 10.2 with -O2, disable log):
2021-11-30 21:43:33 +08:00
2022-10-20 21:22:08 +08:00
| file | FLASH (Byte) | No Cache RAM (Byte) | RAM (Byte) | Heap (Byte) |
|:-------------:|:--------------:|:-------------------------:|:-------------:|:----------------:|
|usbd_core.c | ~4500 | (512(default) + 320) * bus | 0 | 0 |
|usbd_cdc_acm.c | ~900 | 0 | 0 | 0 |
|usbd_msc.c | ~5000 | (128 + 512(default)) * bus | 16 * bus | 0 |
|usbd_hid.c | ~300 | 0 | 0 | 0 |
|usbd_audio.c | ~4000 | 0 | 0 | 0 |
|usbd_video.c | ~7000 | 0 | 132 * bus | 0 |
|usbd_rndis.c | ~2500 | 2 * 1580(default)+156+8 | 80 | 0 |
|usbd_cdc_ecm.c | ~900 | 2 * 1514(default)+16 | 42 | 0 |
|usbd_mtp.c | ~9000 | 2048(default)+128 | sizeof(struct mtp_object) * n| 0 |
|usbd_dfu.c | ~2200 | 0 | 45 | 0 |
2021-11-30 21:43:33 +08:00
2022-05-25 11:00:17 +08:00
## Host Stack Overview
2021-11-30 21:43:33 +08:00
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.
2022-01-29 23:36:16 +08:00
CherryUSB Host Stack has the following functions:
2022-01-29 23:36:16 +08:00
- Support low speed, full speed, high speed and super speed devices
2022-01-29 23:36:16 +08:00
- Automatic loading of supported Class drivers
- Support blocking transfers and asynchronous transfers
2022-04-04 15:54:53 +08:00
- 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)
2022-01-29 23:36:16 +08:00
- Support Human Interface Device (HID)
- Support Mass Storage Class (MSC)
- Support USB Video CLASS (UVC1.0, UVC1.5)
- Support USB Audio CLASS (UAC1.0)
2022-04-04 15:54:53 +08:00
- Support Remote NDIS (RNDIS)
2024-01-25 22:03:35 +08:00
- 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)
2023-11-21 22:23:07 +08:00
- Support USB modeswitch
2024-10-31 21:43:41 +08:00
- Support Android Open Accessory
2024-01-06 22:16:58 +08:00
- Support multi host with the same USB IP
2022-01-29 23:36:16 +08:00
2022-02-01 23:07:38 +08:00
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.
2022-01-29 23:36:16 +08:00
CherryUSB Host Stack resource usage (GCC 10.2 with -O2, disable log):
2022-06-23 21:30:32 +08:00
2023-12-16 23:19:57 +08:00
| file | FLASH (Byte) | No Cache RAM (Byte) | RAM (Byte) | Heap (Byte) |
|:-------------:|:--------------:|:-------------------------------:|:---------------------------:|:------------:|
|usbh_core.c | ~4500 | (512(default) + 8 * (1+x) *n) * bus | sizeof(struct usbh_hub) * bus | raw_config_desc |
|usbh_hub.c | ~3500 | (32 + 4 * (1+x)) * bus | 12 + sizeof(struct usbh_hub) * x | 0 |
|usbh_cdc_acm.c | ~600 | 7 * x | 4 + sizeof(struct usbh_cdc_acm) * x | 0 |
|usbh_msc.c | ~2000 | 128 * x | 4 + sizeof(struct usbh_msc) * x | 0 |
|usbh_hid.c | ~800 | 64 * x | 4 + sizeof(struct usbh_hid) * x | 0 |
|usbh_video.c | ~5000 | 128 * x | 4 + sizeof(struct usbh_video) * x | 0 |
|usbh_audio.c | ~4000 | 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 | ~7000 | 2 * 2048(default) + 16 + 32 | sizeof(struct usbh_asix) * 1 | 0 |
|usbh_rtl8152.c | ~9000 | 16K+ 2K(default) + 2 + 32 | sizeof(struct usbh_rtl8152) * 1 | 0 |
2022-09-14 20:33:47 +08:00
Among them, `sizeof(struct usbh_hub)` and `sizeof(struct usbh_hubport)` are affected by the following macros:
2022-09-14 20:33:47 +08:00
```
#define CONFIG_USBHOST_MAX_EXTHUBS 1
#define CONFIG_USBHOST_MAX_EHPORTS 4
2023-12-30 15:03:32 +08:00
#define CONFIG_USBHOST_MAX_INTERFACES 8
#define CONFIG_USBHOST_MAX_INTF_ALTSETTINGS 2
2022-09-14 20:33:47 +08:00
#define CONFIG_USBHOST_MAX_ENDPOINTS 4
```
2022-06-23 21:30:32 +08:00
x is affected by the following macros:
2023-07-12 23:01:15 +08:00
```
#define CONFIG_USBHOST_MAX_SERIAL_CLASS 4
2023-07-12 23:01:15 +08:00
#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
```
2024-03-27 19:34:24 +08:00
## USB IP Support
Only standard and commercial USB IP are listed.
| IP | device | host | Support status |
|:----------------:|:----------:|:--------:|:--------------:|
2024-12-09 20:18:07 +08:00
| OHCI(intel) | none | OHCI | √ |
2024-03-27 19:34:24 +08:00
| EHCI(intel) | none | EHCI | √ |
| XHCI(intel) | none | XHCI | √ |
2024-06-15 21:12:03 +08:00
| UHCI(intel) | none | UHCI | × |
2024-03-27 19:34:24 +08:00
| DWC2(synopsys) | DWC2 | DWC2 | √ |
| MUSB(mentor) | MUSB | MUSB | √ |
| FOTG210(faraday)| FOTG210 | EHCI | √ |
2024-08-21 20:04:18 +08:00
| CHIPIDEA(synopsys)| CHIPIDEA | EHCI | √ |
2024-03-27 19:34:24 +08:00
| CDNS2(cadence) | CDNS2 | CDNS2 | √ |
| CDNS3(cadence) | CDNS3 | XHCI | × |
| DWC3(synopsys) | DWC3 | XHCI | × |
## Resources
2021-11-30 21:43:33 +08:00
### Getting Started
2021-11-30 21:43:33 +08:00
- 📖 [CherryUSB Documentation](https://cherryusb.readthedocs.io/en/latest/)
- 💻 [CherryUSB Demo Repo](https://cherryusb.readthedocs.io/en/latest/quick_start/demo.html)
- 📺 [CherryUSB Cheese(>= V1.4.3)](https://www.bilibili.com/cheese/play/ss707687201)
2021-11-30 21:43:33 +08:00
### Package Support
2024-08-21 20:04:18 +08:00
- [RT-Thread](https://packages.rt-thread.org/detail.html?package=CherryUSB)
- [YOC](https://www.xrvm.cn/document?temp=usb-host-protocol-stack-device-driver-adaptation-instructions&slug=yocbook)
- [ESP-Registry](https://components.espressif.com/components/cherry-embedded/cherryusb)
### Descriptor Generator Tool
2024-05-31 23:01:12 +08:00
Cherry Descriptor: https://desc.cherry-embedded.org/en
### Contact
2024-05-31 23:01:12 +08:00
CherryUSB discord: https://discord.com/invite/wFfvrSAey8
## Commercial Support
2022-06-05 16:45:39 +08:00
Refer to https://cherryusb.readthedocs.io/en/latest/support/index.html
2024-05-05 12:04:08 +08:00
## Company Support
Thanks to the following companies for their support (in no particular order):
2024-05-05 12:04:08 +08:00
<img src="docs/assets/bouffalolab.jpg" width="100" height="80"/> <img src="docs/assets/hpmicro.jpg" width="100" height="80" /> <img src="docs/assets/eastsoft.jpg" width="100" height="80" /> <img src="docs/assets/rtthread.jpg" width="100" height="80" /> <img src="docs/assets/sophgo.jpg" width="100" height="80" /> <img src="docs/assets/phytium.jpg" width="100" height="80" /> <img src="docs/assets/thead.jpg" width="100" height="80" /> <img src="docs/assets/nuvoton.jpg" width="100" height="80" /> <img src="docs/assets/artinchip.jpg" width="100" height="80" /> <img src="docs/assets/bekencorp.jpg" width="100" height="80" /> <img src="docs/assets/nxp.png" width="100" height="80" /> <img src="docs/assets/espressif.png" width="100" height="80" /> <img src="docs/assets/canaan.jpg" width="100" height="80" /> <img src="docs/assets/actions.jpg" width="100" height="80" /> <img src="docs/assets/sifli.jpg" width="100" height="80" /> <img src="docs/assets/nationstech.jpg" width="100" height="80" />