mirror of
https://github.com/STMicroelectronics/stm32-mw-usb-device.git
synced 2026-02-08 12:08:06 -05:00
284 lines
6.8 KiB
C
284 lines
6.8 KiB
C
/**
|
|
******************************************************************************
|
|
* @file usbd_conf_template.c
|
|
* @author MCD Application Team
|
|
* @brief USB Device configuration and interface file
|
|
* This template should be copied to the user folder,
|
|
* renamed and customized following user needs.
|
|
******************************************************************************
|
|
* @attention
|
|
*
|
|
* Copyright (c) 2015 STMicroelectronics.
|
|
* All rights reserved.
|
|
*
|
|
* This software is licensed under terms that can be found in the LICENSE file
|
|
* in the root directory of this software component.
|
|
* If no LICENSE file comes with this software, it is provided AS-IS.
|
|
*
|
|
******************************************************************************
|
|
*/
|
|
|
|
/* Includes ------------------------------------------------------------------*/
|
|
#include "usbd_core.h"
|
|
#include "usbd_hid.h" /* Include class header file */
|
|
/* Private typedef -----------------------------------------------------------*/
|
|
/* Private define ------------------------------------------------------------*/
|
|
/* Private macro -------------------------------------------------------------*/
|
|
/* Private variables ---------------------------------------------------------*/
|
|
/* Private function prototypes -----------------------------------------------*/
|
|
/* Private functions ---------------------------------------------------------*/
|
|
/**
|
|
* @brief Initializes the Low Level portion of the Device driver.
|
|
* @param pdev: Device handle
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_Init(USBD_HandleTypeDef *pdev)
|
|
{
|
|
UNUSED(pdev);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief De-Initializes the Low Level portion of the Device driver.
|
|
* @param pdev: Device handle
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_DeInit(USBD_HandleTypeDef *pdev)
|
|
{
|
|
UNUSED(pdev);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief Starts the Low Level portion of the Device driver.
|
|
* @param pdev: Device handle
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_Start(USBD_HandleTypeDef *pdev)
|
|
{
|
|
UNUSED(pdev);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief Stops the Low Level portion of the Device driver.
|
|
* @param pdev: Device handle
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_Stop(USBD_HandleTypeDef *pdev)
|
|
{
|
|
UNUSED(pdev);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief Opens an endpoint of the Low Level Driver.
|
|
* @param pdev: Device handle
|
|
* @param ep_addr: Endpoint Number
|
|
* @param ep_type: Endpoint Type
|
|
* @param ep_mps: Endpoint Max Packet Size
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_OpenEP(USBD_HandleTypeDef *pdev, uint8_t ep_addr,
|
|
uint8_t ep_type, uint16_t ep_mps)
|
|
{
|
|
UNUSED(pdev);
|
|
UNUSED(ep_addr);
|
|
UNUSED(ep_type);
|
|
UNUSED(ep_mps);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief Closes an endpoint of the Low Level Driver.
|
|
* @param pdev: Device handle
|
|
* @param ep_addr: Endpoint Number
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_CloseEP(USBD_HandleTypeDef *pdev, uint8_t ep_addr)
|
|
{
|
|
UNUSED(pdev);
|
|
UNUSED(ep_addr);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief Flushes an endpoint of the Low Level Driver.
|
|
* @param pdev: Device handle
|
|
* @param ep_addr: Endpoint Number
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_FlushEP(USBD_HandleTypeDef *pdev, uint8_t ep_addr)
|
|
{
|
|
UNUSED(pdev);
|
|
UNUSED(ep_addr);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief Sets a Stall condition on an endpoint of the Low Level Driver.
|
|
* @param pdev: Device handle
|
|
* @param ep_addr: Endpoint Number
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_StallEP(USBD_HandleTypeDef *pdev, uint8_t ep_addr)
|
|
{
|
|
UNUSED(pdev);
|
|
UNUSED(ep_addr);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief Clears a Stall condition on an endpoint of the Low Level Driver.
|
|
* @param pdev: Device handle
|
|
* @param ep_addr: Endpoint Number
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_ClearStallEP(USBD_HandleTypeDef *pdev,
|
|
uint8_t ep_addr)
|
|
{
|
|
UNUSED(pdev);
|
|
UNUSED(ep_addr);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief Returns Stall condition.
|
|
* @param pdev: Device handle
|
|
* @param ep_addr: Endpoint Number
|
|
* @retval Stall (1: Yes, 0: No)
|
|
*/
|
|
uint8_t USBD_LL_IsStallEP(USBD_HandleTypeDef *pdev, uint8_t ep_addr)
|
|
{
|
|
UNUSED(pdev);
|
|
UNUSED(ep_addr);
|
|
|
|
return 0U;
|
|
}
|
|
|
|
/**
|
|
* @brief Assigns a USB address to the device.
|
|
* @param pdev: Device handle
|
|
* @param dev_addr: Endpoint Number
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_SetUSBAddress(USBD_HandleTypeDef *pdev,
|
|
uint8_t dev_addr)
|
|
{
|
|
UNUSED(pdev);
|
|
UNUSED(dev_addr);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief Transmits data over an endpoint.
|
|
* @param pdev: Device handle
|
|
* @param ep_addr: Endpoint Number
|
|
* @param pbuf: Pointer to data to be sent
|
|
* @param size: Data size
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_Transmit(USBD_HandleTypeDef *pdev, uint8_t ep_addr,
|
|
uint8_t *pbuf, uint32_t size)
|
|
{
|
|
UNUSED(pdev);
|
|
UNUSED(ep_addr);
|
|
UNUSED(pbuf);
|
|
UNUSED(size);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief Prepares an endpoint for reception.
|
|
* @param pdev: Device handle
|
|
* @param ep_addr: Endpoint Number
|
|
* @param pbuf: Pointer to data to be received
|
|
* @param size: Data size
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_PrepareReceive(USBD_HandleTypeDef *pdev,
|
|
uint8_t ep_addr, uint8_t *pbuf,
|
|
uint32_t size)
|
|
{
|
|
UNUSED(pdev);
|
|
UNUSED(ep_addr);
|
|
UNUSED(pbuf);
|
|
UNUSED(size);
|
|
|
|
return USBD_OK;
|
|
}
|
|
|
|
/**
|
|
* @brief Returns the last transferred packet size.
|
|
* @param pdev: Device handle
|
|
* @param ep_addr: Endpoint Number
|
|
* @retval Received Data Size
|
|
*/
|
|
uint32_t USBD_LL_GetRxDataSize(USBD_HandleTypeDef *pdev, uint8_t ep_addr)
|
|
{
|
|
UNUSED(pdev);
|
|
UNUSED(ep_addr);
|
|
|
|
return 0U;
|
|
}
|
|
|
|
#ifdef USBD_HS_TESTMODE_ENABLE
|
|
/**
|
|
* @brief Set High speed Test mode.
|
|
* @param pdev: Device handle
|
|
* @param testmode: test mode
|
|
* @retval USBD Status
|
|
*/
|
|
USBD_StatusTypeDef USBD_LL_SetTestMode(USBD_HandleTypeDef *pdev, uint8_t testmode)
|
|
{
|
|
UNUSED(pdev);
|
|
UNUSED(testmode);
|
|
|
|
return USBD_OK;
|
|
}
|
|
#endif /* USBD_HS_TESTMODE_ENABLE */
|
|
|
|
/**
|
|
* @brief Static single allocation.
|
|
* @param size: Size of allocated memory
|
|
* @retval None
|
|
*/
|
|
void *USBD_static_malloc(uint32_t size)
|
|
{
|
|
UNUSED(size);
|
|
static uint32_t mem[(sizeof(USBD_HID_HandleTypeDef) / 4) + 1]; /* On 32-bit boundary */
|
|
return mem;
|
|
}
|
|
|
|
/**
|
|
* @brief Dummy memory free
|
|
* @param p: Pointer to allocated memory address
|
|
* @retval None
|
|
*/
|
|
void USBD_static_free(void *p)
|
|
{
|
|
UNUSED(p);
|
|
}
|
|
|
|
/**
|
|
* @brief Delays routine for the USB Device Library.
|
|
* @param Delay: Delay in ms
|
|
* @retval None
|
|
*/
|
|
void USBD_LL_Delay(uint32_t Delay)
|
|
{
|
|
UNUSED(Delay);
|
|
}
|
|
|