mirror of
https://github.com/STMicroelectronics/stm32-mw-usb-device.git
synced 2026-02-08 20:18:07 -05:00
Release v2.7.1
This commit is contained in:
@@ -340,6 +340,11 @@ static uint8_t USBD_DFU_Setup(USBD_HandleTypeDef *pdev, USBD_SetupReqTypedef *re
|
||||
uint16_t len = 0U;
|
||||
uint16_t status_info = 0U;
|
||||
|
||||
if (hdfu == NULL)
|
||||
{
|
||||
return (uint8_t)USBD_FAIL;
|
||||
}
|
||||
|
||||
switch (req->bmRequest & USB_REQ_TYPE_MASK)
|
||||
{
|
||||
case USB_REQ_TYPE_CLASS:
|
||||
@@ -498,6 +503,11 @@ static uint8_t USBD_DFU_EP0_TxReady(USBD_HandleTypeDef *pdev)
|
||||
USBD_DFU_HandleTypeDef *hdfu = (USBD_DFU_HandleTypeDef *)pdev->pClassData;
|
||||
USBD_DFU_MediaTypeDef *DfuInterface = (USBD_DFU_MediaTypeDef *)pdev->pUserData;
|
||||
|
||||
if (hdfu == NULL)
|
||||
{
|
||||
return (uint8_t)USBD_FAIL;
|
||||
}
|
||||
|
||||
if (hdfu->dev_state == DFU_STATE_DNLOAD_BUSY)
|
||||
{
|
||||
/* Decode the Special Command */
|
||||
@@ -674,6 +684,11 @@ static void DFU_Detach(USBD_HandleTypeDef *pdev, USBD_SetupReqTypedef *req)
|
||||
{
|
||||
USBD_DFU_HandleTypeDef *hdfu = (USBD_DFU_HandleTypeDef *)pdev->pClassData;
|
||||
|
||||
if (hdfu == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
if ((hdfu->dev_state == DFU_STATE_IDLE) ||
|
||||
(hdfu->dev_state == DFU_STATE_DNLOAD_SYNC) ||
|
||||
(hdfu->dev_state == DFU_STATE_DNLOAD_IDLE) ||
|
||||
@@ -717,6 +732,11 @@ static void DFU_Download(USBD_HandleTypeDef *pdev, USBD_SetupReqTypedef *req)
|
||||
{
|
||||
USBD_DFU_HandleTypeDef *hdfu = (USBD_DFU_HandleTypeDef *)pdev->pClassData;
|
||||
|
||||
if (hdfu == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
/* Data setup request */
|
||||
if (req->wLength > 0U)
|
||||
{
|
||||
@@ -775,6 +795,11 @@ static void DFU_Upload(USBD_HandleTypeDef *pdev, USBD_SetupReqTypedef *req)
|
||||
uint8_t *phaddr;
|
||||
uint32_t addr;
|
||||
|
||||
if (hdfu == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
/* Data setup request */
|
||||
if (req->wLength > 0U)
|
||||
{
|
||||
@@ -866,6 +891,11 @@ static void DFU_GetStatus(USBD_HandleTypeDef *pdev)
|
||||
USBD_DFU_HandleTypeDef *hdfu = (USBD_DFU_HandleTypeDef *)pdev->pClassData;
|
||||
USBD_DFU_MediaTypeDef *DfuInterface = (USBD_DFU_MediaTypeDef *)pdev->pUserData;
|
||||
|
||||
if (hdfu == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
switch (hdfu->dev_state)
|
||||
{
|
||||
case DFU_STATE_DNLOAD_SYNC:
|
||||
@@ -941,6 +971,11 @@ static void DFU_ClearStatus(USBD_HandleTypeDef *pdev)
|
||||
{
|
||||
USBD_DFU_HandleTypeDef *hdfu = (USBD_DFU_HandleTypeDef *)pdev->pClassData;
|
||||
|
||||
if (hdfu == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
if (hdfu->dev_state == DFU_STATE_ERROR)
|
||||
{
|
||||
hdfu->dev_state = DFU_STATE_IDLE;
|
||||
@@ -974,6 +1009,11 @@ static void DFU_GetState(USBD_HandleTypeDef *pdev)
|
||||
{
|
||||
USBD_DFU_HandleTypeDef *hdfu = (USBD_DFU_HandleTypeDef *)pdev->pClassData;
|
||||
|
||||
if (hdfu == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
/* Return the current state of the DFU interface */
|
||||
(void)USBD_CtlSendData(pdev, &hdfu->dev_state, 1U);
|
||||
}
|
||||
@@ -988,6 +1028,10 @@ static void DFU_Abort(USBD_HandleTypeDef *pdev)
|
||||
{
|
||||
USBD_DFU_HandleTypeDef *hdfu = (USBD_DFU_HandleTypeDef *)pdev->pClassData;
|
||||
|
||||
if (hdfu == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
if ((hdfu->dev_state == DFU_STATE_IDLE) ||
|
||||
(hdfu->dev_state == DFU_STATE_DNLOAD_SYNC) ||
|
||||
@@ -1018,6 +1062,11 @@ static void DFU_Leave(USBD_HandleTypeDef *pdev)
|
||||
{
|
||||
USBD_DFU_HandleTypeDef *hdfu = (USBD_DFU_HandleTypeDef *)pdev->pClassData;
|
||||
|
||||
if (hdfu == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
hdfu->manif_state = DFU_MANIFEST_COMPLETE;
|
||||
|
||||
if (((USBD_DFU_CfgDesc[(11U + (9U * USBD_DFU_MAX_ITF_NUM))]) & 0x04U) != 0U)
|
||||
|
||||
Reference in New Issue
Block a user