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

120 lines
4.6 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# 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)