Frederick Huang / mbed-STM32L452

Dependents:   STM32L452_Nucleo_ticker

Fork of mbed-dev by mbed official

Committer:
Frederick_H
Date:
Fri Dec 15 08:17:23 2017 +0000
Revision:
182:59ec31722650
Parent:
165:e614a9f1c9e2
Modify hal_tick.h of TARGET_STM32L476xG

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