mbed library sources. Supersedes mbed-src.

Dependents:   Nucleo_Hello_Encoder BLE_iBeaconScan AM1805_DEMO DISCO-F429ZI_ExportTemplate1 ... more

Committer:
AnnaBridge
Date:
Wed Feb 20 22:31:08 2019 +0000
Revision:
189:f392fc9709a3
Parent:
187:0387e8f68319
mbed library release version 165

Who changed what in which revision?

UserRevisionLine numberNew contents of line
<> 144:ef7eb2e8f9f7 1 /**
<> 144:ef7eb2e8f9f7 2 ******************************************************************************
<> 144:ef7eb2e8f9f7 3 * @file stm32f1xx_hal_pccard.h
<> 144:ef7eb2e8f9f7 4 * @author MCD Application Team
<> 144:ef7eb2e8f9f7 5 * @brief Header file of PCCARD HAL module.
<> 144:ef7eb2e8f9f7 6 ******************************************************************************
<> 144:ef7eb2e8f9f7 7 * @attention
<> 144:ef7eb2e8f9f7 8 *
<> 144:ef7eb2e8f9f7 9 * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
<> 144:ef7eb2e8f9f7 10 *
<> 144:ef7eb2e8f9f7 11 * Redistribution and use in source and binary forms, with or without modification,
<> 144:ef7eb2e8f9f7 12 * are permitted provided that the following conditions are met:
<> 144:ef7eb2e8f9f7 13 * 1. Redistributions of source code must retain the above copyright notice,
<> 144:ef7eb2e8f9f7 14 * this list of conditions and the following disclaimer.
<> 144:ef7eb2e8f9f7 15 * 2. Redistributions in binary form must reproduce the above copyright notice,
<> 144:ef7eb2e8f9f7 16 * this list of conditions and the following disclaimer in the documentation
<> 144:ef7eb2e8f9f7 17 * and/or other materials provided with the distribution.
<> 144:ef7eb2e8f9f7 18 * 3. Neither the name of STMicroelectronics nor the names of its contributors
<> 144:ef7eb2e8f9f7 19 * may be used to endorse or promote products derived from this software
<> 144:ef7eb2e8f9f7 20 * without specific prior written permission.
<> 144:ef7eb2e8f9f7 21 *
<> 144:ef7eb2e8f9f7 22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
<> 144:ef7eb2e8f9f7 23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
<> 144:ef7eb2e8f9f7 24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
<> 144:ef7eb2e8f9f7 25 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
<> 144:ef7eb2e8f9f7 26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
<> 144:ef7eb2e8f9f7 27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
<> 144:ef7eb2e8f9f7 28 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
<> 144:ef7eb2e8f9f7 29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
<> 144:ef7eb2e8f9f7 30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
<> 144:ef7eb2e8f9f7 31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
<> 144:ef7eb2e8f9f7 32 *
<> 144:ef7eb2e8f9f7 33 ******************************************************************************
<> 144:ef7eb2e8f9f7 34 */
<> 144:ef7eb2e8f9f7 35
<> 144:ef7eb2e8f9f7 36 /* Define to prevent recursive inclusion -------------------------------------*/
<> 144:ef7eb2e8f9f7 37 #ifndef __STM32F1xx_HAL_PCCARD_H
<> 144:ef7eb2e8f9f7 38 #define __STM32F1xx_HAL_PCCARD_H
<> 144:ef7eb2e8f9f7 39
<> 144:ef7eb2e8f9f7 40 #ifdef __cplusplus
<> 144:ef7eb2e8f9f7 41 extern "C" {
<> 144:ef7eb2e8f9f7 42 #endif
<> 144:ef7eb2e8f9f7 43
<> 144:ef7eb2e8f9f7 44 /* Includes ------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 45 #include "stm32f1xx_ll_fsmc.h"
<> 144:ef7eb2e8f9f7 46
<> 144:ef7eb2e8f9f7 47 /** @addtogroup STM32F1xx_HAL_Driver
<> 144:ef7eb2e8f9f7 48 * @{
<> 144:ef7eb2e8f9f7 49 */
<> 144:ef7eb2e8f9f7 50
<> 144:ef7eb2e8f9f7 51 #if defined (STM32F101xE) || defined(STM32F103xE) || defined(STM32F101xG) || defined(STM32F103xG)
<> 144:ef7eb2e8f9f7 52 /** @addtogroup PCCARD
<> 144:ef7eb2e8f9f7 53 * @{
<> 144:ef7eb2e8f9f7 54 */
<> 144:ef7eb2e8f9f7 55
<> 144:ef7eb2e8f9f7 56 /** @addtogroup PCCARD_Private_Constants
<> 144:ef7eb2e8f9f7 57 * @{
<> 144:ef7eb2e8f9f7 58 */
<> 144:ef7eb2e8f9f7 59
<> 144:ef7eb2e8f9f7 60 #define PCCARD_DEVICE_ADDRESS FSMC_BANK4
AnnaBridge 165:e614a9f1c9e2 61 #define PCCARD_ATTRIBUTE_SPACE_ADDRESS ((uint32_t)(FSMC_BANK4 + 0x08000000U)) /* Attribute space size to @0x9BFF FFFF */
<> 144:ef7eb2e8f9f7 62 #define PCCARD_COMMON_SPACE_ADDRESS PCCARD_DEVICE_ADDRESS /* Common space size to @0x93FF FFFF */
AnnaBridge 165:e614a9f1c9e2 63 #define PCCARD_IO_SPACE_ADDRESS ((uint32_t)(FSMC_BANK4 + 0x0C000000U)) /* IO space size to @0x9FFF FFFF */
AnnaBridge 165:e614a9f1c9e2 64 #define PCCARD_IO_SPACE_PRIMARY_ADDR ((uint32_t)(FSMC_BANK4 + 0x0C0001F0U)) /* IO space size to @0x9FFF FFFF */
<> 144:ef7eb2e8f9f7 65
<> 144:ef7eb2e8f9f7 66 /* Compact Flash-ATA registers description */
<> 144:ef7eb2e8f9f7 67 #define ATA_DATA ((uint8_t)0x00) /* Data register */
<> 144:ef7eb2e8f9f7 68 #define ATA_SECTOR_COUNT ((uint8_t)0x02) /* Sector Count register */
<> 144:ef7eb2e8f9f7 69 #define ATA_SECTOR_NUMBER ((uint8_t)0x03) /* Sector Number register */
<> 144:ef7eb2e8f9f7 70 #define ATA_CYLINDER_LOW ((uint8_t)0x04) /* Cylinder low register */
<> 144:ef7eb2e8f9f7 71 #define ATA_CYLINDER_HIGH ((uint8_t)0x05) /* Cylinder high register */
<> 144:ef7eb2e8f9f7 72 #define ATA_CARD_HEAD ((uint8_t)0x06) /* Card/Head register */
<> 144:ef7eb2e8f9f7 73 #define ATA_STATUS_CMD ((uint8_t)0x07) /* Status(read)/Command(write) register */
<> 144:ef7eb2e8f9f7 74 #define ATA_STATUS_CMD_ALTERNATE ((uint8_t)0x0E) /* Alternate Status(read)/Command(write) register */
<> 144:ef7eb2e8f9f7 75 #define ATA_COMMON_DATA_AREA ((uint16_t)0x0400) /* Start of data area (for Common access only!) */
<> 144:ef7eb2e8f9f7 76 #define ATA_CARD_CONFIGURATION ((uint16_t)0x0202) /* Card Configuration and Status Register */
<> 144:ef7eb2e8f9f7 77
<> 144:ef7eb2e8f9f7 78 /* Compact Flash-ATA commands */
<> 144:ef7eb2e8f9f7 79 #define ATA_READ_SECTOR_CMD ((uint8_t)0x20)
<> 144:ef7eb2e8f9f7 80 #define ATA_WRITE_SECTOR_CMD ((uint8_t)0x30)
<> 144:ef7eb2e8f9f7 81 #define ATA_ERASE_SECTOR_CMD ((uint8_t)0xC0)
<> 144:ef7eb2e8f9f7 82 #define ATA_IDENTIFY_CMD ((uint8_t)0xEC)
<> 144:ef7eb2e8f9f7 83
<> 144:ef7eb2e8f9f7 84 /* Compact Flash status */
<> 144:ef7eb2e8f9f7 85 #define PCCARD_TIMEOUT_ERROR ((uint8_t)0x60)
<> 144:ef7eb2e8f9f7 86 #define PCCARD_BUSY ((uint8_t)0x80)
<> 144:ef7eb2e8f9f7 87 #define PCCARD_PROGR ((uint8_t)0x01)
<> 144:ef7eb2e8f9f7 88 #define PCCARD_READY ((uint8_t)0x40)
<> 144:ef7eb2e8f9f7 89
AnnaBridge 165:e614a9f1c9e2 90 #define PCCARD_SECTOR_SIZE 255U /* In half words */
<> 144:ef7eb2e8f9f7 91
<> 144:ef7eb2e8f9f7 92
<> 144:ef7eb2e8f9f7 93 /* Compact Flash redefinition */
<> 144:ef7eb2e8f9f7 94 #define HAL_CF_Read_ID HAL_PCCARD_Read_ID
<> 144:ef7eb2e8f9f7 95 #define HAL_CF_Write_Sector HAL_PCCARD_Write_Sector
<> 144:ef7eb2e8f9f7 96 #define HAL_CF_Read_Sector HAL_PCCARD_Read_Sector
<> 144:ef7eb2e8f9f7 97 #define HAL_CF_Erase_Sector HAL_PCCARD_Erase_Sector
<> 144:ef7eb2e8f9f7 98 #define HAL_CF_Reset HAL_PCCARD_Reset
AnnaBridge 165:e614a9f1c9e2 99
<> 144:ef7eb2e8f9f7 100 #define HAL_CF_GetStatus HAL_PCCARD_GetStatus
<> 144:ef7eb2e8f9f7 101 #define HAL_CF_ReadStatus HAL_PCCARD_ReadStatus
AnnaBridge 165:e614a9f1c9e2 102
<> 144:ef7eb2e8f9f7 103 #define CF_SUCCESS HAL_PCCARD_STATUS_SUCCESS
<> 144:ef7eb2e8f9f7 104 #define CF_ONGOING HAL_PCCARD_STATUS_ONGOING
<> 144:ef7eb2e8f9f7 105 #define CF_ERROR HAL_PCCARD_STATUS_ERROR
<> 144:ef7eb2e8f9f7 106 #define CF_TIMEOUT HAL_PCCARD_STATUS_TIMEOUT
<> 144:ef7eb2e8f9f7 107 #define CF_StatusTypedef HAL_PCCARD_StatusTypeDef
<> 144:ef7eb2e8f9f7 108
AnnaBridge 165:e614a9f1c9e2 109 #define CF_DEVICE_ADDRESS PCCARD_DEVICE_ADDRESS
<> 144:ef7eb2e8f9f7 110 #define CF_ATTRIBUTE_SPACE_ADDRESS PCCARD_ATTRIBUTE_SPACE_ADDRESS
<> 144:ef7eb2e8f9f7 111 #define CF_COMMON_SPACE_ADDRESS PCCARD_COMMON_SPACE_ADDRESS
<> 144:ef7eb2e8f9f7 112 #define CF_IO_SPACE_ADDRESS PCCARD_IO_SPACE_ADDRESS
<> 144:ef7eb2e8f9f7 113 #define CF_IO_SPACE_PRIMARY_ADDR PCCARD_IO_SPACE_PRIMARY_ADDR
<> 144:ef7eb2e8f9f7 114
<> 144:ef7eb2e8f9f7 115 #define CF_TIMEOUT_ERROR PCCARD_TIMEOUT_ERROR
<> 144:ef7eb2e8f9f7 116 #define CF_BUSY PCCARD_BUSY
<> 144:ef7eb2e8f9f7 117 #define CF_PROGR PCCARD_PROGR
<> 144:ef7eb2e8f9f7 118 #define CF_READY PCCARD_READY
<> 144:ef7eb2e8f9f7 119
<> 144:ef7eb2e8f9f7 120 #define CF_SECTOR_SIZE PCCARD_SECTOR_SIZE
<> 144:ef7eb2e8f9f7 121
<> 144:ef7eb2e8f9f7 122 /**
<> 144:ef7eb2e8f9f7 123 * @}
<> 144:ef7eb2e8f9f7 124 */
<> 144:ef7eb2e8f9f7 125
<> 144:ef7eb2e8f9f7 126 /* Exported typedef ----------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 127 /** @defgroup PCCARD_Exported_Types PCCARD Exported Types
<> 144:ef7eb2e8f9f7 128 * @{
<> 144:ef7eb2e8f9f7 129 */
<> 144:ef7eb2e8f9f7 130
<> 144:ef7eb2e8f9f7 131 /**
<> 144:ef7eb2e8f9f7 132 * @brief HAL PCCARD State structures definition
<> 144:ef7eb2e8f9f7 133 */
<> 144:ef7eb2e8f9f7 134 typedef enum
<> 144:ef7eb2e8f9f7 135 {
AnnaBridge 165:e614a9f1c9e2 136 HAL_PCCARD_STATE_RESET = 0x00U, /*!< PCCARD peripheral not yet initialized or disabled */
AnnaBridge 165:e614a9f1c9e2 137 HAL_PCCARD_STATE_READY = 0x01U, /*!< PCCARD peripheral ready */
AnnaBridge 165:e614a9f1c9e2 138 HAL_PCCARD_STATE_BUSY = 0x02U, /*!< PCCARD peripheral busy */
AnnaBridge 165:e614a9f1c9e2 139 HAL_PCCARD_STATE_ERROR = 0x04U /*!< PCCARD peripheral error */
<> 144:ef7eb2e8f9f7 140 }HAL_PCCARD_StateTypeDef;
<> 144:ef7eb2e8f9f7 141
<> 144:ef7eb2e8f9f7 142 typedef enum
<> 144:ef7eb2e8f9f7 143 {
AnnaBridge 165:e614a9f1c9e2 144 HAL_PCCARD_STATUS_SUCCESS = 0U,
<> 144:ef7eb2e8f9f7 145 HAL_PCCARD_STATUS_ONGOING,
<> 144:ef7eb2e8f9f7 146 HAL_PCCARD_STATUS_ERROR,
<> 144:ef7eb2e8f9f7 147 HAL_PCCARD_STATUS_TIMEOUT
<> 144:ef7eb2e8f9f7 148 }HAL_PCCARD_StatusTypeDef;
<> 144:ef7eb2e8f9f7 149
<> 144:ef7eb2e8f9f7 150 /**
<> 144:ef7eb2e8f9f7 151 * @brief FSMC_PCCARD handle Structure definition
<> 144:ef7eb2e8f9f7 152 */
<> 144:ef7eb2e8f9f7 153 typedef struct
<> 144:ef7eb2e8f9f7 154 {
<> 144:ef7eb2e8f9f7 155 FSMC_PCCARD_TypeDef *Instance; /*!< Register base address for PCCARD device */
<> 144:ef7eb2e8f9f7 156
<> 144:ef7eb2e8f9f7 157 FSMC_PCCARD_InitTypeDef Init; /*!< PCCARD device control configuration parameters */
<> 144:ef7eb2e8f9f7 158
<> 144:ef7eb2e8f9f7 159 __IO HAL_PCCARD_StateTypeDef State; /*!< PCCARD device access state */
<> 144:ef7eb2e8f9f7 160
<> 144:ef7eb2e8f9f7 161 HAL_LockTypeDef Lock; /*!< PCCARD Lock */
<> 144:ef7eb2e8f9f7 162
<> 144:ef7eb2e8f9f7 163 }PCCARD_HandleTypeDef;
<> 144:ef7eb2e8f9f7 164 /**
<> 144:ef7eb2e8f9f7 165 * @}
<> 144:ef7eb2e8f9f7 166 */
<> 144:ef7eb2e8f9f7 167
<> 144:ef7eb2e8f9f7 168 /* Exported constants --------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 169 /* Exported macro ------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 170 /** @defgroup PCCARD_Exported_Macros PCCARD Exported Macros
<> 144:ef7eb2e8f9f7 171 * @{
<> 144:ef7eb2e8f9f7 172 */
<> 144:ef7eb2e8f9f7 173
<> 144:ef7eb2e8f9f7 174 /** @brief Reset PCCARD handle state
<> 144:ef7eb2e8f9f7 175 * @param __HANDLE__: specifies the PCCARD handle.
<> 144:ef7eb2e8f9f7 176 * @retval None
<> 144:ef7eb2e8f9f7 177 */
<> 144:ef7eb2e8f9f7 178 #define __HAL_PCCARD_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_PCCARD_STATE_RESET)
<> 144:ef7eb2e8f9f7 179 /**
<> 144:ef7eb2e8f9f7 180 * @}
<> 144:ef7eb2e8f9f7 181 */
<> 144:ef7eb2e8f9f7 182
<> 144:ef7eb2e8f9f7 183 /* Exported functions --------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 184 /** @addtogroup PCCARD_Exported_Functions PCCARD Exported Functions
<> 144:ef7eb2e8f9f7 185 * @{
<> 144:ef7eb2e8f9f7 186 */
<> 144:ef7eb2e8f9f7 187
<> 144:ef7eb2e8f9f7 188 /** @addtogroup PCCARD_Exported_Functions_Group1 Initialization and de-initialization functions
<> 144:ef7eb2e8f9f7 189 * @{
<> 144:ef7eb2e8f9f7 190 */
<> 144:ef7eb2e8f9f7 191 /* Initialization/de-initialization functions **********************************/
<> 144:ef7eb2e8f9f7 192 HAL_StatusTypeDef HAL_PCCARD_Init(PCCARD_HandleTypeDef *hpccard, FSMC_NAND_PCC_TimingTypeDef *ComSpaceTiming, FSMC_NAND_PCC_TimingTypeDef *AttSpaceTiming, FSMC_NAND_PCC_TimingTypeDef *IOSpaceTiming);
<> 144:ef7eb2e8f9f7 193 HAL_StatusTypeDef HAL_PCCARD_DeInit(PCCARD_HandleTypeDef *hpccard);
<> 144:ef7eb2e8f9f7 194 void HAL_PCCARD_MspInit(PCCARD_HandleTypeDef *hpccard);
<> 144:ef7eb2e8f9f7 195 void HAL_PCCARD_MspDeInit(PCCARD_HandleTypeDef *hpccard);
<> 144:ef7eb2e8f9f7 196 /**
<> 144:ef7eb2e8f9f7 197 * @}
<> 144:ef7eb2e8f9f7 198 */
<> 144:ef7eb2e8f9f7 199
<> 144:ef7eb2e8f9f7 200 /** @addtogroup PCCARD_Exported_Functions_Group2 Input Output and memory functions
<> 144:ef7eb2e8f9f7 201 * @{
<> 144:ef7eb2e8f9f7 202 */
<> 144:ef7eb2e8f9f7 203 /* IO operation functions *****************************************************/
<> 144:ef7eb2e8f9f7 204 HAL_StatusTypeDef HAL_PCCARD_Read_ID(PCCARD_HandleTypeDef *hpccard, uint8_t CompactFlash_ID[], uint8_t *pStatus);
<> 144:ef7eb2e8f9f7 205 HAL_StatusTypeDef HAL_PCCARD_Write_Sector(PCCARD_HandleTypeDef *hpccard, uint16_t *pBuffer, uint16_t SectorAddress, uint8_t *pStatus);
<> 144:ef7eb2e8f9f7 206 HAL_StatusTypeDef HAL_PCCARD_Read_Sector(PCCARD_HandleTypeDef *hpccard, uint16_t *pBuffer, uint16_t SectorAddress, uint8_t *pStatus);
<> 144:ef7eb2e8f9f7 207 HAL_StatusTypeDef HAL_PCCARD_Erase_Sector(PCCARD_HandleTypeDef *hpccard, uint16_t SectorAddress, uint8_t *pStatus);
<> 144:ef7eb2e8f9f7 208 HAL_StatusTypeDef HAL_PCCARD_Reset(PCCARD_HandleTypeDef *hpccard);
<> 144:ef7eb2e8f9f7 209 void HAL_PCCARD_IRQHandler(PCCARD_HandleTypeDef *hpccard);
<> 144:ef7eb2e8f9f7 210 void HAL_PCCARD_ITCallback(PCCARD_HandleTypeDef *hpccard);
<> 144:ef7eb2e8f9f7 211
<> 144:ef7eb2e8f9f7 212 /**
<> 144:ef7eb2e8f9f7 213 * @}
<> 144:ef7eb2e8f9f7 214 */
<> 144:ef7eb2e8f9f7 215
<> 144:ef7eb2e8f9f7 216 /** @defgroup PCCARD_Exported_Functions_Group3 Peripheral State functions
<> 144:ef7eb2e8f9f7 217 * @{
<> 144:ef7eb2e8f9f7 218 */
<> 144:ef7eb2e8f9f7 219 /* PCCARD State functions *******************************************************/
<> 144:ef7eb2e8f9f7 220 HAL_PCCARD_StateTypeDef HAL_PCCARD_GetState(PCCARD_HandleTypeDef *hpccard);
<> 144:ef7eb2e8f9f7 221 HAL_PCCARD_StatusTypeDef HAL_PCCARD_GetStatus(PCCARD_HandleTypeDef *hpccard);
<> 144:ef7eb2e8f9f7 222 HAL_PCCARD_StatusTypeDef HAL_PCCARD_ReadStatus(PCCARD_HandleTypeDef *hpccard);
<> 144:ef7eb2e8f9f7 223 /**
<> 144:ef7eb2e8f9f7 224 * @}
<> 144:ef7eb2e8f9f7 225 */
<> 144:ef7eb2e8f9f7 226
<> 144:ef7eb2e8f9f7 227 /**
<> 144:ef7eb2e8f9f7 228 * @}
<> 144:ef7eb2e8f9f7 229 */
<> 144:ef7eb2e8f9f7 230
<> 144:ef7eb2e8f9f7 231 /**
<> 144:ef7eb2e8f9f7 232 * @}
<> 144:ef7eb2e8f9f7 233 */
<> 144:ef7eb2e8f9f7 234
<> 144:ef7eb2e8f9f7 235 #endif /* STM32F101xE || STM32F103xE || STM32F101xG || STM32F103xG */
<> 144:ef7eb2e8f9f7 236 /**
<> 144:ef7eb2e8f9f7 237 * @}
<> 144:ef7eb2e8f9f7 238 */
<> 144:ef7eb2e8f9f7 239
<> 144:ef7eb2e8f9f7 240 #ifdef __cplusplus
<> 144:ef7eb2e8f9f7 241 }
<> 144:ef7eb2e8f9f7 242 #endif
<> 144:ef7eb2e8f9f7 243
<> 144:ef7eb2e8f9f7 244 #endif /* __STM32F1xx_HAL_PCCARD_H */
<> 144:ef7eb2e8f9f7 245
<> 144:ef7eb2e8f9f7 246 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/