CherryUSB 是一个小而美的、可移植性高的、用于嵌入式系统(带 USB ip)的 USB 主从协议栈。
.
├── class
├── common
├── core
├── demo
├── docs
├── osal
├── packet capture
└── port
└── tools
| 目录名 | 描述 |
|---|---|
| class | usb class 类主从驱动 |
| common | usb spec 定义、常用宏、标准接口定义 |
| core | usb 主从协议栈核心实现 |
| demo | 示例 |
| docs | 文档 |
| osal | os 封装层 |
| packet capture | 抓包文件(需要使用力科软件打开) |
| 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) | RAM (Byte) |
|---|---|---|
| usbd_core.c | 3045 | 373 |
| usbd_cdc.c | 302 | 20 |
| usbd_msc.c | 2452 | 132 |
| usbd_hid.c | 784 | 201 |
| usbd_audio.c | 438 | 14 |
| usbd_video.c | 402 | 4 |
CherryUSB Host 协议栈对挂载在 roothub、外部 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):
| file | FLASH (Byte) | RAM (Byte) |
|---|---|---|
| usbh_core.c | 7992 | 472 |
| usbh_cdc_acm.c | 1208 | 4 |
| usbh_msc.c | 2239 | 4 |
| usbh_hid.c | 930 | 4 |
| usbh_hub.c | 3878 | 14 |
CherryUSB 快速入门、USB 基本概念,API 手册,Class 基本概念和例程,参考 CherryUSB 文档教程
USB 基本知识点与 CherryUSB Device 协议栈是如何编写的,参考 CherryUSB Device 协议栈教程.
chryusb_configurator 采用 electron + vite2 + ts 框架编写,当前用于自动化生成描述符数组,后续会增加其他功能。
| 厂商 | 芯片或者系列 | USB IP | 仓库链接 |
|---|---|---|---|
| Bouffalolab | BL702 | bouffalolab | bl_mcu_sdk |
| Essemi | ES32F36xx | musb | es32f369_repo |
| AllwinnerTech | F1C100S | musb | cherryusb_rtt_f1c100s |
| ST | STM32F103C8T6 | fsdev | stm32f103_repo |
| ST | STM32F4 | dwc2 | stm32f429_device_repo stm32f429_host_repo |
| ST | STM32H7 | dwc2 | stm32h743_device_repo stm32h743_host_repo |
| WCH | CH32V307 | ch32_usbfs/ch32_usbhs | ch32v307_repo |
| WCH | CH57x | ch58x | ch57x_repo |
| Nuvoton | Nuc442 | nuvoton | nuc442_repo |
| Nordicsemi | Nrf52840 | nrf5x | nrf5x_repo |
| Geehy | APM32E10x APM32F0xx | fsdev | apm32_repo |
| Mindmotion | MM32L3xx | mm32 | mm32_repo |
| Espressif | esp32 | dwc2 | esp32_repo |
QQ 群:642693751