rt-thread/bsp/phytium/doc/use_cherryusb.md

120 lines
4.6 KiB
Markdown
Raw Normal View History

# CherryUSB 的使用
- CherryUSB 是一个小而美的、可移植性高的、用于嵌入式系统(带 USB IP)的 USB 主从协议栈
- Phytium 系列 CPU 相关 BSP 通过 CherryUSB 支持下列功能
- 1. USB 主机XHCI, 可以识别 U 盘/鼠标/键盘等设备,但是设备需要插在主机侧的 USB 插槽上,暂不支持通过 HUB 扩展连接设备
- 2. USB 主机 (PUSB2), 可以识别 U 盘/鼠标/键盘等设备
- 3. USB 从机 (PUSB2), 可以将开发板作为一个 USB 设备U 盘)运行,连接 Windows/Ubuntu 等主机进行识别和访问
> Note: 目前 CherryUSB 没有适配 RT-Smart, 只能在 RT-Thread 模式下使用
> Note: CherryUSB 不支持同时使用不同类型的控制器PUSB2 和 XHCI 只能选择一种工作
## 使用 USB 3.0 控制器 (XHCI)
> Note: 飞腾派上只有CPU 正面侧靠网口的插槽是 USB 3.0 XHCI 接口,飞腾派中只引出了 USB 3.0 0 号控制器
> Note: 飞腾派上 USB 3.0 控制器引脚和 PWM 及 GPIO 有复用关系,不能同时使用,具体的可以查阅数据手册
- 如果是在 E2000 D/Q Demo 板上,如下图所示连接 USB 设备
![](./figs/e2000_demo_usb3.png)
- 如果是在飞腾派上,如下图所示连接 USB 设备
![](./figs/phytiumpi_usb3.png)
- 加载默认配置 `make load_phytium_pi_rtthread`或者使能下面的配置USB 3.0 控制器可以识别键盘鼠标、U盘和外扩HUB
```
RT_USING_CHERRYUSB
RT_CHERRYUSB_HOST
RT_CHERRYUSB_HOST_XHCI
RT_CHERRYUSB_HOST_HID
RT_CHERRYUSB_HOST_MSC
```
- 编译镜像后加载到开发板中启动,然后输入下面的命令启动 CherryUSB
```
usb_host_init 0
```
> 如果需要使用 1 号控制器,输入 `usb_host_init 1`
- 之后输入命令可以看到挂载的设备,可以看到 0 号 bus 和 1 号 bus 上通过 Hub 挂载了若干设备
```
lsusb -t
```
![](./figs/e2000_demo_devices.png)
- 具体的 USB 设备使用可以参考 CherryUSB 使用说明,以及 [Phytium FreeRTOS SDK 的使用键盘、鼠标和U盘](https://gitee.com/phytium_embedded/phytium-free-rtos-sdk/blob/master/example/peripheral/usb/xhci_platform),以及[在 LVGL 中使用鼠标键盘](https://gitee.com/phytium_embedded/phytium-free-rtos-sdk/tree/master/example/peripheral/media/lvgl_indev)
## 使用 USB 2.0 控制器PUSB2 Device 模式)
> Note: 固件会配置 USB 2.0 控制器的的工作模式默认地E2000 D/Q Demo 板工作为 Device 模式,飞腾派工作为 Host 模式,本例程不支持切换工作模式,修改默认工作模式需要联系 FAE 更换固件或修改电路
- 如图所示将 E2000 D/Q Demo 板的 USB_OTG 接口和一台 Windows PC 连接
> E2000 D/Q Demo 板只引出 USB 2.0 0 号控制器,使用其它控制器需要修改代码
![](./figs/e2000d_demo_usb2.png)
- 使能下面的配置USB 2.0 控制器会模拟出一个 MSC 设备U 盘)给连接的上位机识别
> U 盘的存储空间用开发板的内存空间实现,所以掉电之后 U 盘中的数据就没有了,如果有需要持久保存数据的需要,可以修改例程用 SD 卡或者 Flash 存储空间实现 U 盘
```
RT_USING_CHERRYUSB
RT_CHERRYUSB_DEVICE
RT_CHERRYUSB_DEVICE_SPEED_HS
RT_CHERRYUSB_DEVICE_PUSB2
RT_CHERRYUSB_DEVICE_MSC
RT_CHERRYUSB_DEVICE_TEMPLATE_MSC
```
- 编译镜像后加载到开发板中启动,然后输入下面的命令启动 CherryUSB
```
usb_device_init
```
- 之后会在 PC 端识别出一个 U 盘,之后可以对 U 盘进行读写
![](./figs/msc_device.png)
![](./figs/msc_rw.png)
> 如果需要修改 U 盘的容量,可以在 msc_ram_template.c 中指定 BLOCK_COUNT 的值
## 使用 USB 2.0 控制器 PUSB2 Host 模式)
> Note: USB 2.0 控制器 Host 模式硬件上不支持使用 Hub 扩展插槽
- 如图所示,在飞腾派引出的三个 USB 2.0 插槽上接上鼠标、键盘和 U 盘,注意 CPU 正面侧靠网口的插槽是 USB 3.0 XHCI 接口,其余 USB 接口是 USB 2.0 接口
![](./figs/phytiumpi_usb2.jpg)
- 加载配置 `make load_phytium_pi_rtthread_pusb2_hc` 或者使能下面的配置USB 2.0 控制器作为 Host 工作,能够识别 HID 和 MSC 设备
```
RT_USING_CHERRYUSB
RT_CHERRYUSB_HOST
RT_CHERRYUSB_HOST_PUSB2
RT_CHERRYUSB_HOST_HID
RT_CHERRYUSB_HOST_MSC
```
- 编译镜像后加载到开发板中启动,随后输入命令,初始化三个 USB 2.0 控制器,初始化完成后可以看到枚举到的三个设备,两个 HID 设备对应鼠标和键盘,一个 MSC 设备对应 U 盘,由于 U 盘没有文件系统udisk 尝试挂载 U 盘失败
```
usb_host_init 0
usb_host_init 1
usb_host_init 2
```
![](./figs/usb2_host_init.png)