/** ****************************************************************************** * @file usbd_dfu_media_template.c * @author MCD Application Team * @brief Memory management layer ****************************************************************************** * @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. * ****************************************************************************** */ /* BSPDependencies - "stm32xxxxx_{eval}{discovery}{nucleo_144}.c" - "stm32xxxxx_{eval}{discovery}_io.c" EndBSPDependencies */ /* Includes ------------------------------------------------------------------*/ #include "usbd_dfu_media_template.h" /* Private typedef -----------------------------------------------------------*/ /* Private define ------------------------------------------------------------*/ /* Private macro -------------------------------------------------------------*/ /* Private variables ---------------------------------------------------------*/ /* Private function prototypes -----------------------------------------------*/ /* Extern function prototypes ------------------------------------------------*/ /* Private functions ---------------------------------------------------------*/ uint16_t MEM_If_Init(void); uint16_t MEM_If_Erase(uint32_t Add); uint16_t MEM_If_Write(uint8_t *src, uint8_t *dest, uint32_t Len); uint8_t *MEM_If_Read(uint8_t *src, uint8_t *dest, uint32_t Len); uint16_t MEM_If_DeInit(void); uint16_t MEM_If_GetStatus(uint32_t Add, uint8_t Cmd, uint8_t *buffer); USBD_DFU_MediaTypeDef USBD_DFU_MEDIA_Template_fops = { (uint8_t *)"DFU MEDIA", MEM_If_Init, MEM_If_DeInit, MEM_If_Erase, MEM_If_Write, MEM_If_Read, MEM_If_GetStatus, }; /** * @brief MEM_If_Init * Memory initialization routine. * @param None * @retval 0 if operation is successful, MAL_FAIL else. */ uint16_t MEM_If_Init(void) { return 0; } /** * @brief MEM_If_DeInit * Memory deinitialization routine. * @param None * @retval 0 if operation is successful, MAL_FAIL else. */ uint16_t MEM_If_DeInit(void) { return 0; } /** * @brief MEM_If_Erase * Erase sector. * @param Add: Address of sector to be erased. * @retval 0 if operation is successful, MAL_FAIL else. */ uint16_t MEM_If_Erase(uint32_t Add) { return 0; } /** * @brief MEM_If_Write * Memory write routine. * @param Add: Address to be written to. * @param Len: Number of data to be written (in bytes). * @retval 0 if operation is successful, MAL_FAIL else. */ uint16_t MEM_If_Write(uint8_t *src, uint8_t *dest, uint32_t Len) { return 0; } /** * @brief MEM_If_Read * Memory read routine. * @param Add: Address to be read from. * @param Len: Number of data to be read (in bytes). * @retval Pointer to the physical address where data should be read. */ uint8_t *MEM_If_Read(uint8_t *src, uint8_t *dest, uint32_t Len) { /* Return a valid address to avoid HardFault */ return (uint8_t *)(0); } /** * @brief Flash_If_GetStatus * Memory read routine. * @param Add: Address to be read from. * @param cmd: Number of data to be read (in bytes). * @retval Pointer to the physical address where data should be read. */ uint16_t MEM_If_GetStatus(uint32_t Add, uint8_t Cmd, uint8_t *buffer) { switch (Cmd) { case DFU_MEDIA_PROGRAM: break; case DFU_MEDIA_ERASE: default: break; } return (0); }