From 5b35bc5becd3de51911dc80887d8beb17b2d0395 Mon Sep 17 00:00:00 2001 From: Hubert Denkmair Date: Sun, 17 Apr 2016 22:24:28 +0200 Subject: [PATCH] add MS DeviceInterfaceGUIDs {c15b4308-04d3-11e6-b3ea-6057189e6443} --- include/usbd_gs_can.h | 1 + src/usbd_conf.c | 4 ++ src/usbd_gs_can.c | 97 +++++++++++++++++++++++++++++++++++-------- 3 files changed, 84 insertions(+), 18 deletions(-) diff --git a/include/usbd_gs_can.h b/include/usbd_gs_can.h index 1ba7d2c..a36aa9f 100644 --- a/include/usbd_gs_can.h +++ b/include/usbd_gs_can.h @@ -39,3 +39,4 @@ bool USBD_GS_CAN_TxReady(USBD_HandleTypeDef *pdev); uint8_t USBD_GS_CAN_Transmit(USBD_HandleTypeDef *pdev, uint8_t *buf, uint16_t len); uint8_t USBD_GS_CAN_PrepareReceive(USBD_HandleTypeDef *pdev); bool USBD_GS_CAN_CustomDeviceRequest(USBD_HandleTypeDef *pdev, USBD_SetupReqTypedef *req); +bool USBD_GS_CAN_CustomInterfaceRequest(USBD_HandleTypeDef *pdev, USBD_SetupReqTypedef *req); diff --git a/src/usbd_conf.c b/src/usbd_conf.c index 1aeb83d..f9b26b7 100644 --- a/src/usbd_conf.c +++ b/src/usbd_conf.c @@ -58,6 +58,10 @@ void HAL_PCD_SetupStageCallback(PCD_HandleTypeDef *hpcd) request_was_handled = USBD_GS_CAN_CustomDeviceRequest(pdev, &pdev->request); } + if ((pdev->request.bmRequest & 0x1F) == USB_REQ_RECIPIENT_INTERFACE ) { // interface request + request_was_handled = USBD_GS_CAN_CustomInterfaceRequest(pdev, &pdev->request); + } + if (!request_was_handled) { USBD_LL_SetupStage((USBD_HandleTypeDef*)hpcd->pData, (uint8_t *)hpcd->Setup); } diff --git a/src/usbd_gs_can.c b/src/usbd_gs_can.c index 6ed76a1..813a16a 100644 --- a/src/usbd_gs_can.c +++ b/src/usbd_gs_can.c @@ -180,6 +180,52 @@ static __ALIGN_BEGIN uint8_t USBD_MS_COMP_ID_FEATURE_DESC[] __ALIGN_END = { 0x00, 0x00 }; +/* Microsoft Extended Properties Feature Descriptor */ +static __ALIGN_BEGIN uint8_t USBD_MS_EXT_PROP_FEATURE_DESC[] __ALIGN_END = { + 0x92, 0x00, 0x00, 0x00, /* length */ + 0x00, 0x01, /* version 1.0 */ + 0x05, 0x00, /* descr index (0x0005) */ + 0x01, 0x00, /* number of sections */ + 0x88, 0x00, 0x00, 0x00, /* property section size */ + 0x07, 0x00, 0x00, 0x00, /* property data type 7: Unicode REG_MULTI_SZ */ + 0x2a, 0x00, /* property name length */ + + 0x44, 0x00, 0x65, 0x00, /* property name "DeviceInterfaceGUIDs" */ + 0x76, 0x00, 0x69, 0x00, + 0x63, 0x00, 0x65, 0x00, + 0x49, 0x00, 0x6e, 0x00, + 0x74, 0x00, 0x65, 0x00, + 0x72, 0x00, 0x66, 0x00, + 0x61, 0x00, 0x63, 0x00, + 0x65, 0x00, 0x47, 0x00, + 0x55, 0x00, 0x49, 0x00, + 0x44, 0x00, 0x73, 0x00, + 0x00, 0x00, + + 0x50, 0x00, 0x00, 0x00, /* property data length */ + + 0x7b, 0x00, 0x63, 0x00, /* property name: "{c15b4308-04d3-11e6-b3ea-6057189e6443}\0\0" */ + 0x31, 0x00, 0x35, 0x00, + 0x62, 0x00, 0x34, 0x00, + 0x33, 0x00, 0x30, 0x00, + 0x38, 0x00, 0x2d, 0x00, + 0x30, 0x00, 0x34, 0x00, + 0x64, 0x00, 0x33, 0x00, + 0x2d, 0x00, 0x31, 0x00, + 0x31, 0x00, 0x65, 0x00, + 0x36, 0x00, 0x2d, 0x00, + 0x62, 0x00, 0x33, 0x00, + 0x65, 0x00, 0x61, 0x00, + 0x2d, 0x00, 0x36, 0x00, + 0x30, 0x00, 0x35, 0x00, + 0x37, 0x00, 0x31, 0x00, + 0x38, 0x00, 0x39, 0x00, + 0x65, 0x00, 0x36, 0x00, + 0x34, 0x00, 0x34, 0x00, + 0x33, 0x00, 0x7d, 0x00, + 0x00, 0x00, 0x00, 0x00 +}; + // device info static const struct gs_device_config USBD_GS_CAN_dconf = { @@ -354,6 +400,39 @@ static uint8_t USBD_GS_CAN_Vendor_Request(USBD_HandleTypeDef *pdev, USBD_SetupRe return USBD_OK; } +bool USBD_GS_CAN_CustomDeviceRequest(USBD_HandleTypeDef *pdev, USBD_SetupReqTypedef *req) +{ + uint16_t len = 0; + uint8_t *pbuf; + + if (req->bRequest == USBD_GS_CAN_VENDOR_CODE) { + + switch (req->wIndex) { + + case 0x0004: + pbuf = USBD_MS_COMP_ID_FEATURE_DESC; + len = sizeof(USBD_MS_COMP_ID_FEATURE_DESC); + USBD_CtlSendData(pdev, pbuf, MIN(len, req->wLength)); + return true; + + case 0x0005: + pbuf = USBD_MS_EXT_PROP_FEATURE_DESC; + len = sizeof(USBD_MS_EXT_PROP_FEATURE_DESC); + USBD_CtlSendData(pdev, pbuf, MIN(len, req->wLength)); + return true; + + } + + } + + return false; +} + +bool USBD_GS_CAN_CustomInterfaceRequest(USBD_HandleTypeDef *pdev, USBD_SetupReqTypedef *req) +{ + return USBD_GS_CAN_CustomDeviceRequest(pdev, req); +} + static uint8_t USBD_GS_CAN_Setup(USBD_HandleTypeDef *pdev, USBD_SetupReqTypedef *req) { static uint8_t ifalt = 0; @@ -452,21 +531,3 @@ uint8_t *USBD_GS_CAN_GetStrDesc(USBD_HandleTypeDef *pdev, uint8_t index, uint16_ return 0; } } - -bool USBD_GS_CAN_CustomDeviceRequest(USBD_HandleTypeDef *pdev, USBD_SetupReqTypedef *req) -{ - uint16_t len = 0; - uint8_t *pbuf; - - if (req->bRequest == USBD_GS_CAN_VENDOR_CODE) { - switch (req->wIndex) { - case 0x0004: - pbuf = USBD_MS_COMP_ID_FEATURE_DESC; - len = sizeof(USBD_MS_COMP_ID_FEATURE_DESC); - USBD_CtlSendData(pdev, pbuf, MIN(len, req->wLength)); - return true; - } - } - - return false; -}