English | 简体中文
<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 是一个小而美的、可移植性高的、用于嵌入式系统(带 USB IP)的高性能 USB 主从协议栈。
为了方便用户学习 USB 基本知识、枚举、驱动加载、IP 驱动,因此,编写的代码具备以下优点:
为了方便用户使用 USB 接口,考虑到用户学习过 uart 和 dma,因此,设计的数据收发类接口具备以下优点:
考虑到 USB 性能问题,尽量达到 USB 硬件理论带宽,因此,设计的数据收发类接口具备以下优点:
性能展示:https://cherryusb.cherry-embedded.org/show/
| 目录名 | 描述 |
|---|---|
| class | usb class 类主从驱动 |
| common | usb spec 定义、常用宏、标准接口定义 |
| core | usb 主从协议栈核心实现 |
| demo | 主从 class demo |
| docs | 文档 |
| osal | os 封装层 |
| platform | 其他 os 全家桶适配 |
| port | usb 主从需要实现的 porting 接口 |
| tools | 工具链接 |
CherryUSB Device 协议栈对标准设备请求、CLASS 请求、VENDOR 请求以及 custom 特殊请求规范了一套统一的函数框架,采用面向对象和链表的方式,能够使得用户快速上手复合设备,不用管底层的逻辑。同时,规范了一套标准的 dcd porting 接口,用于适配不同的 USB IP,达到面向 ip 编程。
CherryUSB Device 协议栈当前实现以下功能:
CherryUSB Device 协议栈资源占用说明(GCC 10.2 with -O2):
| 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 |
CherryUSB Host 协议栈对挂载在 root hub、外部 hub 上的设备规范了一套标准的枚举实现,对不同的 Class 类也规范了一套标准接口,用来指示在枚举后和断开连接后该 Class 驱动需要做的事情。同时,规范了一套标准的 hcd porting 接口,用于适配不同的 USB IP,达到面向 IP 编程。最后,协议栈使用 OS 管理,并提供了 osal 用来适配不同的 os。
CherryUSB Host 协议栈当前实现以下功能:
同时,CherryUSB Host 协议栈还提供了 lsusb 的功能,借助 shell 插件可以查看所有挂载设备的信息,包括外部 hub 上的设备的信息。
CherryUSB Host 协议栈资源占用说明(GCC 10.2 with -O2,关闭 log):
| 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 |
其中,sizeof(struct usbh_hub) 和 sizeof(struct usbh_hubport) 受以下宏影响:
#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 受以下宏影响:
#define CONFIG_USBHOST_MAX_CDC_ACM_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 和商业性 USB IP
| 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 | × |
CherryUSB 快速入门、USB 基本概念、API 手册、Class 基本概念和例程,参考 CherryUSB Documentation Tutorial。
CherryUSB 课程(基于 V1.4.3):https://www.bilibili.com/cheese/play/ss707687201 。
TODO
| Manufacturer | CHIP or Series | USB IP | Repo Url | Support version | Note |
|---|---|---|---|---|---|
| Bouffalolab | BL702/BL616/BL808 | bouffalolab/ehci | bouffalo_sdk | <= latest | Official |
| ST | STM32F1x/STM32F4/STM32H7 | fsdev/dwc2 | stm32_repo | <= latest | Community |
| HPMicro | HPM6000/HPM5000 | hpm/ehci | hpm_sdk | <= latest | Official |
| Essemi | ES32F36xx | musb | es32f369_repo | <= latest | Official |
| Phytium | e2000 | pusb2/xhci | phytium_repo | >=1.4.0 | Official |
| Artinchip | d12x/d13x/d21x | aic/ehci/ohci | luban-lite | <= latest | Official |
| Espressif | esp32s2/esp32s3/esp32p4 | dwc2 | esp32_repo | <= latest | Official ongoing |
| Kendryte | k230 | dwc2 | k230_repo | v1.2.0 | Official |
| Actionstech | ATS30xx | dwc2 | action_zephyr_repo | >=1.4.0 | Official |
| SiFli | SF32LB5x | musb | SiFli_sdk | >=1.5.0 | Official |
| NXP | mcx | kinetis/chipidea/ehci | nxp_mcx_repo | <= latest | Community |
| Nationstech | n32h4x | dwc2 | nation_repo | >=1.5.0 | Official ongoing |
| Raspberry pi | rp2040/rp2350 | rp2040 | pico-sdk | <= latest | Official ongoing |
| AllwinnerTech | F1C100S/F1C200S | musb | cherryusb_rtt_f1c100s | <= latest | no more update |
| Bekencorp | bk7256/bk7258 | musb | bk_idk | v0.7.0 | Official |
| Sophgo | cv18xx | dwc2 | cvi_alios_open | v0.7.0 | Official |
| WCH | CH32V307/ch58x | ch32_usbfs/ch32_usbhs/ch58x | wch_repo | <= v0.10.2/>=v1.5.0 | no more update |
CherryUSB 软件包可以通过以下方式获取:
参考 https://cherryusb.readthedocs.io/zh-cn/latest/support/index.html 。
CherryUSB QQ群:642693751
CherryUSB 微信群:与我联系后邀请加入
感谢以下企业支持(顺序不分先后):
