api_config.rst 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. USB CONFIG 宏
  2. =========================
  3. 通用 CONFIG 宏
  4. ---------------------
  5. CONFIG_USB_PRINTF
  6. ^^^^^^^^^^^^^^^^^^^^
  7. USB log 功能,默认重定向到 printf,需要注意,USB log 会在中断中使用,因此重定向的 api 不允许阻塞。举例,如果使用的是 rt-thread,请更换成 rt-kprintf
  8. CONFIG_USB_DBG_LEVEL
  9. ^^^^^^^^^^^^^^^^^^^^^^
  10. 控制 log 的打印级别
  11. CONFIG_USB_PRINTF_COLOR_ENABLE
  12. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  13. 控制 log 颜色打印,默认开启
  14. CONFIG_USB_ALIGN_SIZE
  15. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  16. USB buffer 的对齐大小,默认是 4。IP 在 dma 模式下可能对输入的 buffer有对齐要求,一般是4,如果是其他对齐方式,请修改此值。
  17. USB_NOCACHE_RAM_SECTION
  18. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  19. 如果芯片没有 cache 功能,此宏无效。如果有,则 USB 的输入输出 buffer 必须放在 nocache ram 中,保证数据一致性。
  20. 设备相关 CONFIG 宏
  21. ---------------------
  22. CONFIG_USBDEV_REQUEST_BUFFER_LEN
  23. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  24. 控制传输接收和发送的 buffer 最大长度,默认是 256。
  25. CONFIG_USBDEV_SETUP_LOG_PRINT
  26. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  27. 使能或者关闭 setup 包的 dump 信息,默认关闭。
  28. CONFIG_USBDEV_DESC_CHECK
  29. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  30. 暂时没有实现
  31. CONFIG_USBDEV_TEST_MODE
  32. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  33. 使能或者关闭 usb test mode
  34. CONFIG_USBDEV_MSC_MAX_BUFSIZE
  35. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  36. msc 缓存的最大长度,缓存越大,USB 的速度越高,因为介质一般多个 block 读写速度比单个 block 高很多,比如 sd 卡。
  37. 默认 512 ,如果是 flash 需要改成 4K, 缓存的大小需要是 介质的一个 block size 的整数倍。
  38. CONFIG_USBDEV_MSC_MANUFACTURER_STRING
  39. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  40. CONFIG_USBDEV_MSC_PRODUCT_STRING
  41. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  42. CONFIG_USBDEV_MSC_VERSION_STRING
  43. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  44. CONFIG_USBDEV_MSC_THREAD
  45. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  46. 使能或者关闭 msc 线程,默认关闭。usbd_msc_sector_read 和 usbd_msc_sector_write 默认是在中断中执行,所以如果开启了 os 建议开启此宏,那么,
  47. usbd_msc_sector_read 和 usbd_msc_sector_write 就会在线程中执行。
  48. CONFIG_USBDEV_MSC_PRIO
  49. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  50. MSC 读写线程的优先级,默认是 4,数值越小,优先级越高
  51. CONFIG_USBDEV_MSC_STACKSIZE
  52. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  53. MSC 读写线程的堆栈大小,默认 2K 字节
  54. CONFIG_USBDEV_RNDIS_RESP_BUFFER_SIZE
  55. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  56. rndis 控制传输最大接收和发送的长度,根据 RNDIS options list 决定最小长度,默认要大于等于 156
  57. CONFIG_USBDEV_RNDIS_ETH_MAX_FRAME_SIZE
  58. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  59. rndis 以太网帧的最大长度,默认 1536
  60. CONFIG_USBDEV_RNDIS_VENDOR_ID
  61. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  62. CONFIG_USBDEV_RNDIS_VENDOR_DESC
  63. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  64. CONFIG_USBDEV_RNDIS_USING_LWIP
  65. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  66. rndis 与 lwip 接口的对接
  67. 主机相关 CONFIG 宏
  68. ---------------------
  69. 以下参数决定了支持的最大外部hub数量,接口数,每个接口的端点数和 altsetting 数量,更改此值会影响 ram 的大小,建议根据实际情况更改。
  70. .. code-block:: C
  71. #define CONFIG_USBHOST_MAX_RHPORTS 1
  72. #define CONFIG_USBHOST_MAX_EXTHUBS 1
  73. #define CONFIG_USBHOST_MAX_EHPORTS 4
  74. #define CONFIG_USBHOST_MAX_INTERFACES 6
  75. #define CONFIG_USBHOST_MAX_INTF_ALTSETTINGS 1
  76. #define CONFIG_USBHOST_MAX_ENDPOINTS 4
  77. 以下参数决定了支持的 class 数目,更改此值会影响 ram 的大小,建议根据实际情况更改。
  78. .. code-block:: C
  79. #define CONFIG_USBHOST_MAX_CDC_ACM_CLASS 4
  80. #define CONFIG_USBHOST_MAX_HID_CLASS 4
  81. #define CONFIG_USBHOST_MAX_MSC_CLASS 2
  82. #define CONFIG_USBHOST_MAX_AUDIO_CLASS 1
  83. #define CONFIG_USBHOST_MAX_VIDEO_CLASS 1
  84. CONFIG_USBHOST_PSC_PRIO
  85. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  86. 主机插拔线程的优先级,默认是 0,数值越小,优先级越高
  87. CONFIG_USBHOST_PSC_STACKSIZE
  88. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  89. 主机插拔线程的堆栈大小,默认 2K 字节
  90. CONFIG_USBHOST_REQUEST_BUFFER_LEN
  91. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  92. 控制传输能够接收或者发送的最大长度
  93. CONFIG_USBHOST_CONTROL_TRANSFER_TIMEOUT
  94. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  95. 控制传输发送或者接收的超时时间,默认 1s
  96. CONFIG_USBHOST_MSC_TIMEOUT
  97. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  98. MSC 读写传输的超时时间,默认 5s