migration.rst 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. 部分改动迁移指南
  2. ========================
  3. usbh_initialize
  4. ------------------
  5. usbh_initialize 从 v1.6.0 开始新增 event_handler 参数,通常不需要使用,可以传入 NULL。
  6. dwc2 glue st
  7. ----------------
  8. dwc2 从 v1.5.0 开始 glue 文件内置底层初始化,比如 `usb_dc_low_level_init`,底层依赖 `HAL_PCD_MspInit` 和 `HAL_HCD_MspInit`,必须使用 stm32cubemx 生成。第三方平台不保证有这些函数实现,自行检查。
  9. dwc2 glue
  10. ----------------
  11. dwc2 从 v1.5.1 开始新增 `struct dwc2_user_params`,用于实现多 dwc2 port 不同配置。并替代 `usbd_get_dwc2_gccfg_conf` 和 `usbh_get_dwc2_hccfg_conf` 函数,
  12. 并增加 `dwc2_get_user_params` 函数实现,举例如下:
  13. .. code-block:: C
  14. #ifndef CONFIG_USB_DWC2_CUSTOM_PARAM
  15. void dwc2_get_user_params(uint32_t reg_base, struct dwc2_user_params *params)
  16. {
  17. memcpy(params, &param_common, sizeof(struct dwc2_user_params));
  18. #ifdef CONFIG_USB_DWC2_CUSTOM_FIFO
  19. struct usb_dwc2_user_fifo_config s_dwc2_fifo_config;
  20. dwc2_get_user_fifo_config(reg_base, &s_dwc2_fifo_config);
  21. params->device_rx_fifo_size = s_dwc2_fifo_config.device_rx_fifo_size;
  22. for (uint8_t i = 0; i < MAX_EPS_CHANNELS; i++) {
  23. params->device_tx_fifo_size[i] = s_dwc2_fifo_config.device_tx_fifo_size[i];
  24. }
  25. #endif
  26. }
  27. #endif
  28. host serial
  29. ----------------
  30. 从 v1.6.0 开始,主机增加 host serial 框架,用于统一所有类串口设备。以下 API 需要使用新 serial API 替换:
  31. .. code-block:: C
  32. int usbh_xxx_set_line_coding(struct usbh_xxx *xxx_class, struct cdc_line_coding *line_coding);
  33. int usbh_xxx_get_line_coding(struct usbh_xxx *xxx_class, struct cdc_line_coding *line_coding);
  34. int usbh_xxx_set_line_state(struct usbh_xxx *xxx_class, bool dtr, bool rts);
  35. int usbh_xxx_bulk_in_transfer(struct usbh_xxx *xxx_class, uint8_t *buffer, uint32_t buflen, uint32_t timeout);
  36. int usbh_xxx_bulk_out_transfer(struct usbh_xxx *xxx_class, uint8_t *buffer, uint32_t buflen, uint32_t timeout);
  37. 替换为:
  38. .. code-block:: C
  39. struct usbh_serial *usbh_serial_open(const char *devname, uint32_t open_flags);
  40. int usbh_serial_close(struct usbh_serial *serial);
  41. int usbh_serial_control(struct usbh_serial *serial, int cmd, void *arg);
  42. int usbh_serial_write(struct usbh_serial *serial, const void *buffer, uint32_t buflen);
  43. int usbh_serial_read(struct usbh_serial *serial, void *buffer, uint32_t buflen);