rtthread.rst 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. 基于 RT-Thread 软件包开发指南
  2. ===============================
  3. 本节主要介绍使用 RT-Thread 提供的软件包管理器来配置工程,以 env 作为演示。本节操作不同芯片都一样,后续不再重复讲解。打开 env 以后使用 menuconfig 进入包管理器,并在如图所示路径中选择 CherryUSB。
  4. .. figure:: img/env0.png
  5. 从机配置
  6. --------------------------
  7. * 选择 Enable usb device mode 并敲回车进入。
  8. .. figure:: img/env1.png
  9. .. figure:: img/env2.png
  10. * 首先第一个配置是配置 USB 的速度,分为 **FS、HS**,表示使用全速还是高速功能。
  11. .. figure:: img/env3.png
  12. * 其次第二个配置则是选择 USB device ip,不清楚自己芯片是哪个 ip 的可以参考 **port** 目录下对应的 readme。
  13. .. figure:: img/env4.png
  14. * 选择好 USB device ip 以后,还需要选择是哪款芯片,第三个配置则是用来选择芯片,选择以后会配置相应的 ip 的一些信息和 glue 文件
  15. .. figure:: img/env5.png
  16. * 接下来是 class 的选择,用哪个 class 勾选哪个就可以了,使能 class 以后,双击进入可以选择一个 demo 的模板参与编译,当然也可以不选,自己写。
  17. .. figure:: img/env6.png
  18. * 最后退出保存即可。
  19. * 拷贝 `cherryusb_config_template.h` 文件到自己工程目录下,命名为 `usb_config.h`,并添加相应的目录头文件路径,并实现以下内容:
  20. .. figure:: img/config_file.png
  21. * 退出以后不急着编译,需要在代码中实现 `usb_dc_low_level_init` 函数。
  22. * 调用 `usbd_initialize` 并填入 `busid` 和 USB IP 的 `reg base`, `busid` 从 0 开始,不能超过 `CONFIG_USBDEV_MAX_BUS`
  23. * 以上内容我们推荐放在 **board.c** 中,如下代码:
  24. .. code-block:: C
  25. void OTG_HS_IRQHandler(void)
  26. {
  27. extern void USBD_IRQHandler(uint8_t busid);
  28. USBD_IRQHandler(0);
  29. }
  30. int usbd_init(void)
  31. {
  32. xxx_template_init(0, USB_OTG_HS_PERIPH_BASE);
  33. return 0;
  34. }
  35. INIT_APP_EXPORT(usbd_init);
  36. * 使用 `scons --target=mdk5` 或者 `scons` 进行编译,如果是mdk,需要使用 AC6 编译器
  37. 主机配置
  38. --------------------------
  39. * 选择 Enable usb host mode 并敲回车进入。
  40. .. figure:: img/env7.png
  41. * 选择 USB host ip,不清楚自己芯片是哪个 ip 的可以参考 **port** 目录下对应的 readme。选择好 USB host ip 以后,还需要选择是哪款芯片,第二个箭头则是用来选择芯片,选择以后会帮忙配置相对应的 ip 的一些信息,比如 `USB_BASE` 、 `USBH_Handler` 以及特殊的一些配置等等,如果没找到自己的芯片,可以手动在 `usb_hc_xxx.c` 中修改。
  42. .. figure:: img/env8.png
  43. * 根据需要勾选 class 驱动
  44. * 最后退出保存即可。
  45. * 拷贝 `cherryusb_config_template.h` 文件到自己工程目录下,命名为 `usb_config.h`,并添加相应的目录头文件路径,并实现以下内容:
  46. .. figure:: img/config_file.png
  47. * 在代码中实现 `usb_hc_low_level_init` 函数
  48. * 调用 `usbh_initialize` 并填入 `busid` 和 USB IP 的 `reg base`, `busid` 从 0 开始,不能超过 `CONFIG_USBHOST_MAX_BUS`
  49. * 以上内容我们推荐放在 **board.c** 中,如下代码:
  50. .. code-block:: C
  51. void OTG_HS_IRQHandler(void)
  52. {
  53. extern void USBH_IRQHandler(uint8_t busid);
  54. USBH_IRQHandler(0);
  55. }
  56. int usbh_init(void)
  57. {
  58. usbh_initialize(0, USB_OTG_HS_PERIPH_BASE);
  59. return 0;
  60. }
  61. INIT_APP_EXPORT(usbh_init);
  62. * 使用 `scons --target=mdk5` 或者 `scons` 进行编译,如果是mdk,需要使用 AC6 编译器
  63. * 如果使用的是 GCC ,需要在链接脚本(ld)中添加如下代码:
  64. .. code-block:: C
  65. /* section information for usbh class */
  66. . = ALIGN(4);
  67. __usbh_class_info_start__ = .;
  68. KEEP(*(.usbh_class_info))
  69. __usbh_class_info_end__ = .;
  70. 借助 STM32CubeMX 生成 USB 初始化
  71. ----------------------------------
  72. 使用 STM32CubeMX 主要是用来生成 usb 时钟、引脚、中断的配置。我们需要点击如图所示文件,并配置好 USB 的时钟、中断,点击 `Generate Code`。
  73. .. figure:: img/stm32cubemx0.png
  74. .. figure:: img/stm32cubemx1.png
  75. .. figure:: img/stm32cubemx2.png
  76. .. figure:: img/stm32cubemx_clk.png
  77. - 将 `main.c` 中的 `SystemClock_Config` 替换掉 `board.c` 中的配置
  78. .. figure:: img/stm32_init2.png
  79. - 将 `stm32xxxx_hal_msp.c` 中的 `HAL_PCD_MspInit` 或者是 `HAL_HCD_MspInit` 中的内容复制到 `usb_dc_low_level_init` 和 `usb_hc_low_level_init` 函数中,举例如下:
  80. .. figure:: img/stm32_init.png