index.rst 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. .. CherryUSB 使用指南 documentation master file, created by
  2. sphinx-quickstart on Thu Nov 21 10:50:33 2019.
  3. You can adapt this file completely to your liking, but it should at least
  4. contain the root `toctree` directive.
  5. CherryUSB 使用指南
  6. ======================================================
  7. CherryUSB 是一个小而美的、可移植性高的、用于嵌入式系统的 USB 主从协议栈。同时 CherryUSB 具有以下优点:
  8. **易于学习 USB**
  9. 为了方便用户学习 USB 基本知识、枚举、驱动加载、IP 驱动,因此,编写的代码具备以下优点:
  10. - 代码精简,逻辑简单,无复杂 C 语言语法
  11. - 树状化编程,代码层层递进
  12. - Class 驱动和 porting 驱动模板化、精简化
  13. - API 分类清晰(从机:初始化、注册类、命令回调类、数据收发类;主机:初始化、查找类、数据收发类)
  14. **易于使用 USB**
  15. 为了方便用户使用 USB 接口,考虑到用户学习过 uart 和 dma,因此,设计的数据收发类接口具备以下优点:
  16. - 等价于使用 uart tx dma/uart rx dma
  17. - 收发长度没有限制,用户不需要关心 USB 分包过程(porting 驱动做分包过程)
  18. **易于发挥 USB 性能**
  19. 考虑到 USB 性能问题,尽量达到 USB 硬件理论带宽,因此,设计的数据收发类接口具备以下优点:
  20. - Porting 驱动直接对接寄存器,无抽象层封装
  21. - Memory zero copy
  22. - IP 如果带 DMA 则使用 DMA 模式(DMA 带硬件分包功能)
  23. - 长度无限制,方便对接硬件 DMA 并且发挥 DMA 的优势
  24. - 分包功能在中断中处理
  25. **从机协议栈整体执行流程**
  26. .. figure:: usbdev.svg
  27. **主机协议栈整体执行流程**
  28. .. figure:: usbhost.svg
  29. **其他相关链接**
  30. - **CherryUSB 大纲** https://www.bilibili.com/video/BV1st4y1H7K2
  31. - **CherryUSB 从机协议栈视频教程** https://www.bilibili.com/video/BV1Ef4y1t73d
  32. - **CherryUSB 腾讯会议** https://www.bilibili.com/video/BV16x421y7mM
  33. - **github** https://github.com/sakumisu/CherryUSB
  34. .. toctree::
  35. :maxdepth: 1
  36. :caption: 快速上手
  37. quick_start/start
  38. quick_start/demo
  39. quick_start/transplant
  40. quick_start/rtthread
  41. quick_start/esp
  42. q&a
  43. .. toctree::
  44. :maxdepth: 1
  45. :caption: USB 基本知识点
  46. usb/usb2.0_basic
  47. usb/usb3.0_basic
  48. usb/usb_desc
  49. usb/usb_request
  50. usb/usb_enum
  51. usb/usb_ext
  52. .. toctree::
  53. :maxdepth: 1
  54. :caption: API 手册
  55. api/api_device
  56. api/api_host
  57. api/api_port
  58. api/api_config
  59. .. toctree::
  60. :maxdepth: 1
  61. :caption: Class 指南
  62. class/class_cdc
  63. class/class_hid
  64. class/class_msc
  65. class/class_audio
  66. class/class_video
  67. class/winusb
  68. .. toctree::
  69. :maxdepth: 1
  70. :caption: 例程说明
  71. demo/usbd_cdc_acm
  72. demo/usbd_hid
  73. demo/usbd_msc
  74. demo/usbd_rndis
  75. demo/usbd_ecm
  76. demo/usbd_audiov1
  77. demo/usbd_audiov2
  78. demo/usbd_video
  79. demo/usbd_winusb
  80. demo/usbd_webusb
  81. demo/usbh_serial
  82. demo/usbh_hid
  83. demo/usbh_msc
  84. demo/usbh_net
  85. demo/usbh_bluetooth
  86. demo/usbh_wifi
  87. .. toctree::
  88. :maxdepth: 1
  89. :caption: USBIP 介绍
  90. usbip/ohci
  91. usbip/ehci
  92. usbip/xhci
  93. usbip/chipidea
  94. usbip/dwc2
  95. usbip/musb
  96. usbip/fotg210
  97. usbip/cdns2
  98. usbip/cdns3
  99. usbip/dwc3
  100. .. toctree::
  101. :maxdepth: 1
  102. :caption: 工具使用
  103. tools/index
  104. .. toctree::
  105. :maxdepth: 1
  106. :caption: 版本说明
  107. version
  108. .. toctree::
  109. :maxdepth: 1
  110. :caption: 商业支持
  111. support/index