mirror of
https://gitee.com/Vancouver2017/luban-lite.git
synced 2025-12-23 20:48:55 +00:00
93 lines
2.8 KiB
C
93 lines
2.8 KiB
C
#include "usbh_core.h"
|
|
|
|
#define DEV_FORMAT "/dev/air724"
|
|
|
|
static uint32_t g_devinuse = 0;
|
|
|
|
struct usbh_cdc_custom_air724 {
|
|
struct usbh_hubport *hport;
|
|
|
|
usbh_epinfo_t bulkin; /* Bulk IN endpoint */
|
|
usbh_epinfo_t bulkout; /* Bulk OUT endpoint */
|
|
};
|
|
|
|
int usbh_air724_connect(struct usbh_hubport *hport, uint8_t intf)
|
|
{
|
|
struct usbh_endpoint_cfg ep_cfg = { 0 };
|
|
struct usb_endpoint_descriptor *ep_desc;
|
|
int ret;
|
|
|
|
if (intf != 3) {
|
|
USB_LOG_WRN("ignore intf:%d\r\n", intf);
|
|
return 0;
|
|
}
|
|
struct usbh_cdc_custom_air724 *cdc_custom_class = usb_malloc(sizeof(struct usbh_cdc_custom_air724));
|
|
if (cdc_custom_class == NULL) {
|
|
USB_LOG_ERR("Fail to alloc cdc_custom_class\r\n");
|
|
return -ENOMEM;
|
|
}
|
|
|
|
memset(cdc_custom_class, 0, sizeof(struct usbh_cdc_custom_air724));
|
|
cdc_custom_class->hport = hport;
|
|
|
|
strncpy(hport->config.intf[intf].devname, DEV_FORMAT, CONFIG_USBHOST_DEV_NAMELEN);
|
|
|
|
hport->config.intf[intf].priv = cdc_custom_class;
|
|
|
|
for (uint8_t i = 0; i < hport->config.intf[intf].intf_desc.bNumEndpoints; i++) {
|
|
ep_desc = &hport->config.intf[intf].ep[i].ep_desc;
|
|
|
|
ep_cfg.ep_addr = ep_desc->bEndpointAddress;
|
|
ep_cfg.ep_type = ep_desc->bmAttributes & USB_ENDPOINT_TYPE_MASK;
|
|
ep_cfg.ep_mps = ep_desc->wMaxPacketSize;
|
|
ep_cfg.ep_interval = ep_desc->bInterval;
|
|
ep_cfg.hport = hport;
|
|
if (ep_desc->bEndpointAddress & 0x80) {
|
|
usbh_ep_alloc(&cdc_custom_class->bulkin, &ep_cfg);
|
|
} else {
|
|
usbh_ep_alloc(&cdc_custom_class->bulkout, &ep_cfg);
|
|
}
|
|
}
|
|
|
|
USB_LOG_INFO("Register air724 Class:%s\r\n", hport->config.intf[intf].devname);
|
|
uint8_t cdc_buffer[32] = {0X41,0X54,0x0d,0x0a};
|
|
ret = usbh_ep_bulk_transfer(cdc_custom_class->bulkout, cdc_buffer, 4, 3000);
|
|
if (ret < 0) {
|
|
USB_LOG_ERR("bulk out error,ret:%d\r\n", ret);
|
|
} else {
|
|
USB_LOG_RAW("send over:%d\r\n", ret);
|
|
}
|
|
ret = usbh_ep_bulk_transfer(cdc_custom_class->bulkin, cdc_buffer, 10, 3000);
|
|
if (ret < 0) {
|
|
USB_LOG_ERR("bulk in error,ret:%d\r\n", ret);
|
|
} else {
|
|
USB_LOG_RAW("recv over:%d\r\n", ret);
|
|
for (size_t i = 0; i < ret; i++) {
|
|
USB_LOG_RAW("0x%02x ", cdc_buffer[i]);
|
|
}
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
int usbh_air724_disconnect(struct usbh_hubport *hport, uint8_t intf)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
const struct usbh_class_driver cdc_custom_class_driver = {
|
|
.driver_name = "cdc_acm",
|
|
.connect = usbh_air724_connect,
|
|
.disconnect = usbh_air724_disconnect
|
|
};
|
|
|
|
CLASS_INFO_DEFINE const struct usbh_class_info cdc_custom_class_info = {
|
|
.match_flags = USB_CLASS_MATCH_INTF_CLASS | USB_CLASS_MATCH_INTF_SUBCLASS | USB_CLASS_MATCH_INTF_PROTOCOL,
|
|
.class = 0xff,
|
|
.subclass = 0,
|
|
.protocol = 0,
|
|
.vid = 0x1782,
|
|
.pid = 0x4e00,
|
|
.class_driver = &cdc_custom_class_driver
|
|
};
|