1 /****************************************Copyright (c)**************************************************** 2 ** 3 ** http://www.powermcu.com 4 ** 5 **--------------File Info--------------------------------------------------------------------------------- 6 ** File name: diskio.c 7 ** Descriptions: The FATFS Diskio 8 ** 9 **-------------------------------------------------------------------------------------------------------- 10 ** Created by: AVRman 11 ** Created date: 2010-11-4 12 ** Version: v1.0 13 ** Descriptions: The original version 14 ** 15 **-------------------------------------------------------------------------------------------------------- 16 ** Modified by: 17 ** Modified date: 18 ** Version: 19 ** Descriptions: 20 ** 21 *********************************************************************************************************/ 22 23 /* Includes ------------------------------------------------------------------*/ 24 #include "diskio.h" 25 #include "sdio_sd.h" 26 27 /* Private variables ---------------------------------------------------------*/ 28 extern SD_CardInfo SDCardInfo; 29 30 DSTATUS disk_initialize ( BYTE drv /* Physical drive nmuber (0..) */ ) 31 { 32 SD_Error Status; 33 34 switch ( drv ) 35 { 36 case 0: 37 Status = SD_Init ( ); ; 38 if ( Status == SD_OK ) 39 { 40 return 0; 41 } 42 else 43 { 44 return STA_NOINIT; 45 } 46 47 case 1: 48 return STA_NOINIT; 49 50 case 2: 51 return STA_NOINIT; 52 } 53 return STA_NOINIT; 54 } 55 56 /*-----------------------------------------------------------------------*/ 57 /* Return Disk Status */ 58 59 DSTATUS disk_status ( BYTE drv /* Physical drive nmuber (0..) */ ) 60 { 61 switch ( drv ) 62 { 63 case 0: 64 65 /* translate the reslut code here */ 66 67 return 0; 68 69 case 1: 70 71 /* translate the reslut code here */ 72 73 return 0; 74 75 case 2: 76 77 /* translate the reslut code here */ 78 79 return 0; 80 81 default: 82 83 break; 84 } 85 return STA_NOINIT; 86 } 87 88 /*-----------------------------------------------------------------------*/ 89 /* Read Sector(s) */ 90 91 DRESULT disk_read ( BYTE drv, /* Physical drive nmuber (0..) */ BYTE * buff, 92 /* Data buffer to store read data */ DWORD sector, 93 /* Sector address (LBA) */ BYTE count 94 /* Number of sectors to read (1..255) */ ) 95 { 96 SD_Error Status; 97 if ( !count ) 98 { 99 return RES_PARERR; /* count不能等于0,否则返回参数错误 */ 100 } 101 102 switch ( drv ) 103 { 104 105 case 0: 106 if ( count == 1 ) /* 1个sector的读操作 */ 107 { 108 Status = SD_ReadBlock ( buff, sector << 9, SDCardInfo.CardBlockSize ); 109 } 110 else /* 多个sector的读操作 */ 111 { 112 Status = SD_ReadMultiBlocks ( buff, sector << 9, SDCardInfo.CardBlockSize, 113 count ); 114 } 115 if ( Status == SD_OK ) 116 { 117 return RES_OK; 118 } 119 else 120 { 121 return RES_ERROR; 122 } 123 124 case 1: 125 break; 126 127 case 2: 128 break; 129 130 default: 131 break; 132 133 } 134 135 return RES_ERROR; 136 } 137 138 /*-----------------------------------------------------------------------*/ 139 /* Write Sector(s) */ 140 141 #if _READONLY == 0 142 143 DRESULT disk_write ( BYTE drv, 144 /* Physical drive nmuber (0..) */ const BYTE * buff, 145 /* Data to be written */ DWORD sector, 146 /* Sector address (LBA) */ BYTE count 147 /* Number of sectors to write (1..255) */ ) 148 { 149 SD_Error Status; 150 if ( !count ) 151 { 152 return RES_PARERR; /* count不能等于0,否则返回参数错误 */ 153 } 154 155 switch ( drv ) 156 { 157 case 0: 158 if ( count == 1 ) /* 1个sector的写操作 */ 159 { 160 Status = SD_WriteBlock ( ( uint8_t* )( &buff[ 0 ] ), sector << 9, 161 SDCardInfo.CardBlockSize ); 162 } 163 else /* 多个sector的写操作 */ 164 { 165 Status = SD_WriteMultiBlocks ( ( uint8_t* )( &buff[ 0 ] ), sector << 9, 166 SDCardInfo.CardBlockSize, count ); 167 } 168 if ( Status == SD_OK ) 169 { 170 return RES_OK; 171 } 172 else 173 { 174 return RES_ERROR; 175 } 176 case 2: 177 break; 178 default: 179 break; 180 } 181 return RES_ERROR; 182 } 183 #endif /* _READONLY */ 184 185 /*-----------------------------------------------------------------------*/ 186 /* Miscellaneous Functions */ 187 188 DRESULT disk_ioctl ( BYTE drv, /* Physical drive nmuber (0..) */ BYTE ctrl, 189 /* Control code */ void * buff /* Buffer to send/receive control data */ ) 190 { 191 if ( drv ) 192 { 193 return RES_PARERR; /* 仅支持单磁盘操作,否则返回参数错误 */ 194 } 195 switch ( ctrl ) 196 { 197 case CTRL_SYNC: 198 199 return RES_OK; 200 201 case GET_SECTOR_COUNT: 202 *( DWORD* )buff = SDCardInfo.CardCapacity / SDCardInfo.CardBlockSize; 203 return RES_OK; 204 205 case GET_BLOCK_SIZE: 206 *( WORD* )buff = SDCardInfo.CardBlockSize; 207 return RES_OK; 208 209 case CTRL_POWER: 210 break; 211 212 case CTRL_LOCK: 213 break; 214 215 case CTRL_EJECT: 216 break; 217 218 /* MMC/SDC command */ 219 case MMC_GET_TYPE: 220 break; 221 222 case MMC_GET_CSD: 223 break; 224 225 case MMC_GET_CID: 226 break; 227 228 case MMC_GET_OCR: 229 break; 230 231 case MMC_GET_SDSTAT: 232 break; 233 } 234 return RES_PARERR; 235 } 236 237 /* 得到文件Calendar格式的建立日期,是DWORD get_fattime (void) 逆变换 */ 238 /*-----------------------------------------------------------------------*/ 239 /* User defined function to give a current time to fatfs module */ 240 /* 31-25: Year(0-127 org.1980), 24-21: Month(1-12), 20-16: Day(1-31) */ 241 /* 15-11: Hour(0-23), 10-5: Minute(0-59), 4-0: Second(0-29 *2) */ 242 DWORD get_fattime ( void ) 243 { 244 245 return 0; 246 } 247 248 /********************************************************************************************************* 249 END FILE 250 *********************************************************************************************************/
1 /****************************************Copyright (c)**************************************************** 2 ** 3 ** http://www.powermcu.com 4 ** 5 **--------------File Info--------------------------------------------------------------------------------- 6 ** File name: sdio_sd.h 7 ** Descriptions: sdio sd卡操作函数 8 ** 9 **-------------------------------------------------------------------------------------------------------- 10 ** Created by: AVRman 11 ** Created date: 2010-10-30 12 ** Version: v1.0 13 ** Descriptions: The original version 14 ** 15 **-------------------------------------------------------------------------------------------------------- 16 ** Modified by: 17 ** Modified date: 18 ** Version: 19 ** Descriptions: 20 ** 21 *********************************************************************************************************/ 22 23 /****************************************************************************** 24 * +-----------------------------------------------------------+ 25 * | Pin assignment | 26 * +-----------------------------+---------------+-------------+ 27 * | STM32 SDIO Pins | SD | Pin | 28 * +-----------------------------+---------------+-------------+ 29 * | SDIO D2 | D2 | 1 | 30 * | SDIO D3 | D3 | 2 | 31 * | SDIO CMD | CMD | 3 | 32 * | | VCC | 4 (3.3 V)| 33 * | SDIO CK | CLK | 5 | 34 * | | GND | 6 (0 V) | 35 * | SDIO D0 | D0 | 7 | 36 * | SDIO D1 | D1 | 8 | 37 * +-----------------------------+---------------+-------------+ 38 *****************************************************************************/ 39 40 /* Includes ------------------------------------------------------------------*/ 41 #include "sdio_sd.h" 42 43 /** 44 * @brief SDIO Static flags, TimeOut, FIFO Address 45 */ 46 #define NULL 0 47 #define SDIO_STATIC_FLAGS ((uint32_t)0x000005FF) 48 #define SDIO_CMD0TIMEOUT ((uint32_t)0x00010000) 49 50 /** 51 * @brief Mask for errors Card Status R1 (OCR Register) 52 */ 53 #define SD_OCR_ADDR_OUT_OF_RANGE ((uint32_t)0x80000000) 54 #define SD_OCR_ADDR_MISALIGNED ((uint32_t)0x40000000) 55 #define SD_OCR_BLOCK_LEN_ERR ((uint32_t)0x20000000) 56 #define SD_OCR_ERASE_SEQ_ERR ((uint32_t)0x10000000) 57 #define SD_OCR_BAD_ERASE_PARAM ((uint32_t)0x08000000) 58 #define SD_OCR_WRITE_PROT_VIOLATION ((uint32_t)0x04000000) 59 #define SD_OCR_LOCK_UNLOCK_FAILED ((uint32_t)0x01000000) 60 #define SD_OCR_COM_CRC_FAILED ((uint32_t)0x00800000) 61 #define SD_OCR_ILLEGAL_CMD ((uint32_t)0x00400000) 62 #define SD_OCR_CARD_ECC_FAILED ((uint32_t)0x00200000) 63 #define SD_OCR_CC_ERROR ((uint32_t)0x00100000) 64 #define SD_OCR_GENERAL_UNKNOWN_ERROR ((uint32_t)0x00080000) 65 #define SD_OCR_STREAM_READ_UNDERRUN ((uint32_t)0x00040000) 66 #define SD_OCR_STREAM_WRITE_OVERRUN ((uint32_t)0x00020000) 67 #define SD_OCR_CID_CSD_OVERWRIETE ((uint32_t)0x00010000) 68 #define SD_OCR_WP_ERASE_SKIP ((uint32_t)0x00008000) 69 #define SD_OCR_CARD_ECC_DISABLED ((uint32_t)0x00004000) 70 #define SD_OCR_ERASE_RESET ((uint32_t)0x00002000) 71 #define SD_OCR_AKE_SEQ_ERROR ((uint32_t)0x00000008) 72 #define SD_OCR_ERRORBITS ((uint32_t)0xFDFFE008) 73 74 /** 75 * @brief Masks for R6 Response 76 */ 77 #define SD_R6_GENERAL_UNKNOWN_ERROR ((uint32_t)0x00002000) 78 #define SD_R6_ILLEGAL_CMD ((uint32_t)0x00004000) 79 #define SD_R6_COM_CRC_FAILED ((uint32_t)0x00008000) 80 81 #define SD_VOLTAGE_WINDOW_SD ((uint32_t)0x80100000) 82 #define SD_HIGH_CAPACITY ((uint32_t)0x40000000) 83 #define SD_STD_CAPACITY ((uint32_t)0x00000000) 84 #define SD_CHECK_PATTERN ((uint32_t)0x000001AA) 85 86 #define SD_MAX_VOLT_TRIAL ((uint32_t)0x0000FFFF) 87 #define SD_ALLZERO ((uint32_t)0x00000000) 88 89 #define SD_WIDE_BUS_SUPPORT ((uint32_t)0x00040000) 90 #define SD_SINGLE_BUS_SUPPORT ((uint32_t)0x00010000) 91 #define SD_CARD_LOCKED ((uint32_t)0x02000000) 92 93 #define SD_DATATIMEOUT ((uint32_t)0x000FFFFF) 94 #define SD_0TO7BITS ((uint32_t)0x000000FF) 95 #define SD_8TO15BITS ((uint32_t)0x0000FF00) 96 #define SD_16TO23BITS ((uint32_t)0x00FF0000) 97 #define SD_24TO31BITS ((uint32_t)0xFF000000) 98 #define SD_MAX_DATA_LENGTH ((uint32_t)0x01FFFFFF) 99 100 #define SD_HALFFIFO ((uint32_t)0x00000008) 101 #define SD_HALFFIFOBYTES ((uint32_t)0x00000020) 102 103 /** 104 * @brief Command Class Supported 105 */ 106 #define SD_CCCC_LOCK_UNLOCK ((uint32_t)0x00000080) 107 #define SD_CCCC_WRITE_PROT ((uint32_t)0x00000040) 108 #define SD_CCCC_ERASE ((uint32_t)0x00000020) 109 110 /** 111 * @brief Following commands are SD Card Specific commands. 112 * SDIO_APP_CMD should be sent before sending these commands. 113 */ 114 #define SDIO_SEND_IF_COND ((uint32_t)0x00000008) 115 116 /** 117 * @} 118 */ 119 120 /** @defgroup STM32_EVAL_SDIO_SD_Private_Macros 121 * @{ 122 */ 123 /** 124 * @} 125 */ 126 127 /** @defgroup STM32_EVAL_SDIO_SD_Private_Variables 128 * @{ 129 */ 130 static uint32_t CardType = SDIO_STD_CAPACITY_SD_CARD_V1_1; 131 static uint32_t CSD_Tab[ 4 ], CID_Tab[ 4 ], RCA = 0; 132 static uint32_t DeviceMode = SD_POLLING_MODE; 133 static uint32_t TotalNumberOfBytes = 0, StopCondition = 0; 134 uint32_t * SrcBuffer, *DestBuffer; 135 __IO SD_Error TransferError = SD_OK; 136 __IO uint32_t TransferEnd = 0; 137 __IO uint32_t NumberOfBytes = 0; 138 SD_CardInfo SDCardInfo; 139 SDIO_InitTypeDef SDIO_InitStructure; 140 SDIO_CmdInitTypeDef SDIO_CmdInitStructure; 141 SDIO_DataInitTypeDef SDIO_DataInitStructure; 142 /** 143 * @} 144 */ 145 146 /** @defgroup STM32_EVAL_SDIO_SD_Private_Function_Prototypes 147 * @{ 148 */ 149 static SD_Error CmdError ( void ); 150 static SD_Error CmdResp1Error ( uint8_t cmd ); 151 static SD_Error CmdResp7Error ( void ); 152 static SD_Error CmdResp3Error ( void ); 153 static SD_Error CmdResp2Error ( void ); 154 static SD_Error CmdResp6Error ( uint8_t cmd, uint16_t * prca ); 155 static SD_Error SDEnWideBus ( FunctionalState NewState ); 156 static SD_Error IsCardProgramming ( uint8_t * pstatus ); 157 static SD_Error FindSCR ( uint16_t rca, uint32_t * pscr ); 158 static uint8_t convert_from_bytes_to_power_of_two ( uint16_t NumberOfBytes ); 159 160 /** 161 * @} 162 */ 163 164 /** @defgroup STM32_EVAL_SDIO_SD_Private_Functions 165 * @{ 166 */ 167 168 /** 169 * @brief DeInitializes the SDIO interface. 170 * @param None 171 * @retval None 172 */ 173 void SD_DeInit ( void ) 174 { 175 176 } 177 178 /** 179 * @brief Initializes the SD Card and put it into StandBy State (Ready for 180 * data transfer). 181 * @param None 182 * @retval None 183 */ 184 void SD_LowLevel_Init ( void ) 185 { 186 GPIO_InitTypeDef GPIO_InitStructure; 187 188 /*!< GPIOC and GPIOD Periph clock enable */ 189 RCC_APB2PeriphClockCmd ( RCC_APB2Periph_GPIOC | RCC_APB2Periph_GPIOD | 190 SD_DETECT_GPIO_CLK, ENABLE ); 191 192 /*!< Configure PC.08, PC.09, PC.10, PC.11, PC.12 pin: D0, D1, D2, D3, CLK pin */ 193 GPIO_InitStructure.GPIO_Pin = 194 GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 | GPIO_Pin_11 | GPIO_Pin_12; 195 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; 196 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; 197 GPIO_Init ( GPIOC, & GPIO_InitStructure ); 198 199 /*!< Configure PD.02 CMD line */ 200 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; 201 GPIO_Init ( GPIOD, & GPIO_InitStructure ); 202 203 /*!< Configure SD_CD pin: SD Card detect pin */ 204 GPIO_InitStructure.GPIO_Pin = SD_DETECT_PIN; 205 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; 206 GPIO_Init ( SD_DETECT_GPIO_PORT, & GPIO_InitStructure ); 207 208 /*!< Enable the SDIO AHB Clock */ 209 RCC_AHBPeriphClockCmd ( RCC_AHBPeriph_SDIO, ENABLE ); 210 211 /*!< Enable the DMA2 Clock */ 212 RCC_AHBPeriphClockCmd ( RCC_AHBPeriph_DMA2, ENABLE ); 213 } 214 215 uint32_t SD_DMAEndOfTransferStatus ( void ) 216 { 217 return ( uint32_t )DMA_GetFlagStatus ( DMA2_FLAG_TC4 ); 218 } 219 220 /** 221 * @brief Configures the DMA2 Channel4 for SDIO Rx request. 222 * @param BufferDST: pointer to the destination buffer 223 * @param BufferSize: buffer size 224 * @retval None 225 */ 226 void SD_LowLevel_DMA_RxConfig ( uint32_t * BufferDST, uint32_t BufferSize ) 227 { 228 DMA_InitTypeDef DMA_InitStructure; 229 230 DMA_ClearFlag ( DMA2_FLAG_TC4 | DMA2_FLAG_TE4 | DMA2_FLAG_HT4 | 231 DMA2_FLAG_GL4 ); 232 233 /*!< DMA2 Channel4 disable */ 234 DMA_Cmd ( DMA2_Channel4, DISABLE ); 235 236 /*!< DMA2 Channel4 Config */ 237 DMA_InitStructure.DMA_PeripheralBaseAddr = ( uint32_t )SDIO_FIFO_ADDRESS; 238 DMA_InitStructure.DMA_MemoryBaseAddr = ( uint32_t )BufferDST; 239 DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC; 240 DMA_InitStructure.DMA_BufferSize = BufferSize / 4; 241 DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; 242 DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; 243 DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Word; 244 DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_Word; 245 DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; 246 DMA_InitStructure.DMA_Priority = DMA_Priority_High; 247 DMA_InitStructure.DMA_M2M = DMA_M2M_Disable; 248 DMA_Init ( DMA2_Channel4, & DMA_InitStructure ); 249 250 /*!< DMA2 Channel4 enable */ 251 DMA_Cmd ( DMA2_Channel4, ENABLE ); 252 } 253 254 /** 255 * @brief Configures the DMA2 Channel4 for SDIO Tx request. 256 * @param BufferSRC: pointer to the source buffer 257 * @param BufferSize: buffer size 258 * @retval None 259 */ 260 void SD_LowLevel_DMA_TxConfig ( uint32_t * BufferSRC, uint32_t BufferSize ) 261 { 262 263 DMA_InitTypeDef DMA_InitStructure; 264 265 DMA_ClearFlag ( DMA2_FLAG_TC4 | DMA2_FLAG_TE4 | DMA2_FLAG_HT4 | 266 DMA2_FLAG_GL4 ); 267 268 /*!< DMA2 Channel4 disable */ 269 DMA_Cmd ( DMA2_Channel4, DISABLE ); 270 271 /*!< DMA2 Channel4 Config */ 272 DMA_InitStructure.DMA_PeripheralBaseAddr = ( uint32_t )SDIO_FIFO_ADDRESS; 273 DMA_InitStructure.DMA_MemoryBaseAddr = ( uint32_t )BufferSRC; 274 DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralDST; 275 DMA_InitStructure.DMA_BufferSize = BufferSize / 4; 276 DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; 277 DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; 278 DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Word; 279 DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_Word; 280 DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; 281 DMA_InitStructure.DMA_Priority = DMA_Priority_High; 282 DMA_InitStructure.DMA_M2M = DMA_M2M_Disable; 283 DMA_Init ( DMA2_Channel4, & DMA_InitStructure ); 284 285 /*!< DMA2 Channel4 enable */ 286 DMA_Cmd ( DMA2_Channel4, ENABLE ); 287 } 288 289 /** 290 * @brief Initializes the SD Card and put it into StandBy State (Ready for data 291 * transfer). 292 * @param None 293 * @retval SD_Error: SD Card Error code. 294 */ 295 SD_Error SD_Init ( void ) 296 { 297 SD_Error errorstatus = SD_OK; 298 299 /* SDIO Peripheral Low Level Init */ 300 SD_LowLevel_Init ( ); 301 302 SDIO_DeInit ( ); 303 304 errorstatus = SD_PowerON ( ); 305 306 if ( errorstatus != SD_OK ) 307 { 308 /*!< CMD Response TimeOut (wait for CMDSENT flag) */ 309 return ( errorstatus ); 310 } 311 312 errorstatus = SD_InitializeCards ( ); 313 314 if ( errorstatus != SD_OK ) 315 { 316 /*!< CMD Response TimeOut (wait for CMDSENT flag) */ 317 return ( errorstatus ); 318 } 319 320 /*!< Configure the SDIO peripheral */ 321 /*!< SDIOCLK = HCLK, SDIO_CK = HCLK/(2 + SDIO_TRANSFER_CLK_DIV) */ 322 SDIO_InitStructure.SDIO_ClockDiv = SDIO_TRANSFER_CLK_DIV; 323 SDIO_InitStructure.SDIO_ClockEdge = SDIO_ClockEdge_Rising; 324 SDIO_InitStructure.SDIO_ClockBypass = SDIO_ClockBypass_Disable; 325 SDIO_InitStructure.SDIO_ClockPowerSave = SDIO_ClockPowerSave_Disable; 326 SDIO_InitStructure.SDIO_BusWide = SDIO_BusWide_1b; 327 SDIO_InitStructure.SDIO_HardwareFlowControl = 328 SDIO_HardwareFlowControl_Disable; 329 SDIO_Init ( & SDIO_InitStructure ); 330 331 if ( errorstatus == SD_OK ) 332 { 333 /*----------------- Read CSD/CID MSD registers ------------------*/ 334 errorstatus = SD_GetCardInfo ( &SDCardInfo ); 335 } 336 337 if ( errorstatus == SD_OK ) 338 { 339 /*----------------- Select Card --------------------------------*/ 340 errorstatus = SD_SelectDeselect ( ( uint32_t )( SDCardInfo.RCA << 16 ) ); 341 } 342 343 if ( errorstatus == SD_OK ) 344 { 345 errorstatus = SD_EnableWideBusOperation ( SDIO_BusWide_4b ); 346 } 347 348 /* Set Device Transfer Mode to DMA */ 349 if ( errorstatus == SD_OK ) 350 { 351 errorstatus = SD_SetDeviceMode ( SD_DMA_MODE ); 352 } 353 354 return ( errorstatus ); 355 } 356 357 /** 358 * @brief Gets the cuurent sd card data transfer status. 359 * @param None 360 * @retval SDTransferState: Data Transfer state. 361 * This value can be: 362 * - SD_TRANSFER_OK: No data transfer is acting 363 * - SD_TRANSFER_BUSY: Data transfer is acting 364 */ 365 SDTransferState SD_GetStatus ( void ) 366 { 367 SDCardState cardstate = SD_CARD_TRANSFER; 368 369 cardstate = SD_GetState ( ); 370 371 if ( cardstate == SD_CARD_TRANSFER ) 372 { 373 return ( SD_TRANSFER_OK ); 374 } 375 else if ( cardstate == SD_CARD_ERROR ) 376 { 377 return ( SD_TRANSFER_ERROR ); 378 } 379 else 380 { 381 return ( SD_TRANSFER_BUSY ); 382 } 383 } 384 385 /** 386 * @brief Returns the current card's state. 387 * @param None 388 * @retval SDCardState: SD Card Error or SD Card Current State. 389 */ 390 SDCardState SD_GetState ( void ) 391 { 392 uint32_t resp1 = 0; 393 394 if ( SD_Detect( ) == SD_PRESENT ) 395 { 396 if ( SD_SendStatus( &resp1 ) != SD_OK ) 397 { 398 return SD_CARD_ERROR; 399 } 400 else 401 { 402 return ( SDCardState )( ( resp1 >> 9 ) & 0x0F ); 403 } 404 } 405 else 406 { 407 return SD_CARD_ERROR; 408 } 409 } 410 411 /** 412 * @brief Detect if SD card is correctly plugged in the memory slot. 413 * @param None 414 * @retval Return if SD is detected or not 415 */ 416 uint8_t SD_Detect ( void ) 417 { 418 __IO uint8_t status = SD_PRESENT; 419 420 /*!< Check GPIO to detect SD */ 421 if ( GPIO_ReadInputDataBit( SD_DETECT_GPIO_PORT, SD_DETECT_PIN ) 422 != Bit_RESET ) 423 { 424 status = SD_NOT_PRESENT; 425 } 426 return status; 427 } 428 429 /** 430 * @brief Enquires cards about their operating voltage and configures 431 * clock controls. 432 * @param None 433 * @retval SD_Error: SD Card Error code. 434 */ 435 SD_Error SD_PowerON ( void ) 436 { 437 SD_Error errorstatus = SD_OK; 438 uint32_t response = 0, count = 0, validvoltage = 0; 439 uint32_t SDType = SD_STD_CAPACITY; 440 441 /*!< Power ON Sequence -----------------------------------------------------*/ 442 /*!< Configure the SDIO peripheral */ 443 /*!< SDIOCLK = HCLK, SDIO_CK = HCLK/(2 + SDIO_INIT_CLK_DIV) */ 444 /*!< SDIO_CK for initialization should not exceed 400 KHz */ 445 SDIO_InitStructure.SDIO_ClockDiv = SDIO_INIT_CLK_DIV; 446 SDIO_InitStructure.SDIO_ClockEdge = SDIO_ClockEdge_Rising; 447 SDIO_InitStructure.SDIO_ClockBypass = SDIO_ClockBypass_Disable; 448 SDIO_InitStructure.SDIO_ClockPowerSave = SDIO_ClockPowerSave_Disable; 449 SDIO_InitStructure.SDIO_BusWide = SDIO_BusWide_1b; 450 SDIO_InitStructure.SDIO_HardwareFlowControl = 451 SDIO_HardwareFlowControl_Disable; 452 SDIO_Init ( & SDIO_InitStructure ); 453 454 /*!< Set Power State to ON */ 455 SDIO_SetPowerState ( SDIO_PowerState_ON ); 456 457 /*!< Enable SDIO Clock */ 458 SDIO_ClockCmd ( ENABLE ); 459 460 /*!< CMD0: GO_IDLE_STATE ---------------------------------------------------*/ 461 /*!< No CMD response required */ 462 SDIO_CmdInitStructure.SDIO_Argument = 0x0; 463 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_GO_IDLE_STATE; 464 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_No; 465 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 466 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 467 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 468 469 errorstatus = CmdError ( ); 470 471 if ( errorstatus != SD_OK ) 472 { 473 /*!< CMD Response TimeOut (wait for CMDSENT flag) */ 474 return ( errorstatus ); 475 } 476 477 /*!< CMD8: SEND_IF_COND ----------------------------------------------------*/ 478 /*!< Send CMD8 to verify SD card interface operating condition */ 479 /*!< Argument: - [31:12]: Reserved (shall be set to '0') 480 - [11:8]: Supply Voltage (VHS) 0x1 (Range: 2.7-3.6 V) 481 - [7:0]: Check Pattern (recommended 0xAA) */ 482 /*!< CMD Response: R7 */ 483 SDIO_CmdInitStructure.SDIO_Argument = SD_CHECK_PATTERN; 484 SDIO_CmdInitStructure.SDIO_CmdIndex = SDIO_SEND_IF_COND; 485 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 486 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 487 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 488 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 489 490 errorstatus = CmdResp7Error ( ); 491 492 if ( errorstatus == SD_OK ) 493 { 494 CardType = SDIO_STD_CAPACITY_SD_CARD_V2_0; /*!< SD Card 2.0 */ 495 SDType = SD_HIGH_CAPACITY; 496 } 497 else 498 { 499 /*!< CMD55 */ 500 SDIO_CmdInitStructure.SDIO_Argument = 0x00; 501 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_APP_CMD; 502 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 503 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 504 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 505 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 506 errorstatus = CmdResp1Error ( SD_CMD_APP_CMD ); 507 } 508 /*!< CMD55 */ 509 SDIO_CmdInitStructure.SDIO_Argument = 0x00; 510 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_APP_CMD; 511 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 512 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 513 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 514 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 515 errorstatus = CmdResp1Error ( SD_CMD_APP_CMD ); 516 517 /*!< If errorstatus is Command TimeOut, it is a MMC card */ 518 /*!< If errorstatus is SD_OK it is a SD card: SD card 2.0 (voltage range mismatch) 519 or SD card 1.x */ 520 if ( errorstatus == SD_OK ) 521 { 522 /*!< SD CARD */ 523 /*!< Send ACMD41 SD_APP_OP_COND with Argument 0x80100000 */ 524 while ( ( !validvoltage ) && ( count < SD_MAX_VOLT_TRIAL ) ) 525 { 526 527 /*!< SEND CMD55 APP_CMD with RCA as 0 */ 528 SDIO_CmdInitStructure.SDIO_Argument = 0x00; 529 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_APP_CMD; 530 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 531 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 532 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 533 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 534 535 errorstatus = CmdResp1Error ( SD_CMD_APP_CMD ); 536 537 if ( errorstatus != SD_OK ) 538 { 539 return ( errorstatus ); 540 } 541 SDIO_CmdInitStructure.SDIO_Argument = SD_VOLTAGE_WINDOW_SD | SDType; 542 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SD_APP_OP_COND; 543 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 544 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 545 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 546 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 547 548 errorstatus = CmdResp3Error ( ); 549 if ( errorstatus != SD_OK ) 550 { 551 return ( errorstatus ); 552 } 553 554 response = SDIO_GetResponse ( SDIO_RESP1 ); 555 validvoltage = ( ( ( response >> 31 ) == 1 ) ? 1 : 0 ); 556 count++; 557 } 558 if ( count >= SD_MAX_VOLT_TRIAL ) 559 { 560 errorstatus = SD_INVALID_VOLTRANGE; 561 return ( errorstatus ); 562 } 563 564 if ( response &= SD_HIGH_CAPACITY ) 565 { 566 CardType = SDIO_HIGH_CAPACITY_SD_CARD; 567 } 568 569 } /*!< else MMC Card */ 570 571 return ( errorstatus ); 572 } 573 574 /** 575 * @brief Turns the SDIO output signals off. 576 * @param None 577 * @retval SD_Error: SD Card Error code. 578 */ 579 SD_Error SD_PowerOFF ( void ) 580 { 581 SD_Error errorstatus = SD_OK; 582 583 /*!< Set Power State to OFF */ 584 SDIO_SetPowerState ( SDIO_PowerState_OFF ); 585 586 return ( errorstatus ); 587 } 588 589 /** 590 * @brief Intialises all cards or single card as the case may be Card(s) come 591 * into standby state. 592 * @param None 593 * @retval SD_Error: SD Card Error code. 594 */ 595 SD_Error SD_InitializeCards ( void ) 596 { 597 SD_Error errorstatus = SD_OK; 598 uint16_t rca = 0x01; 599 600 if ( SDIO_GetPowerState( ) == SDIO_PowerState_OFF ) 601 { 602 errorstatus = SD_REQUEST_NOT_APPLICABLE; 603 return ( errorstatus ); 604 } 605 606 if ( SDIO_SECURE_DIGITAL_IO_CARD != CardType ) 607 { 608 /*!< Send CMD2 ALL_SEND_CID */ 609 SDIO_CmdInitStructure.SDIO_Argument = 0x0; 610 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_ALL_SEND_CID; 611 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Long; 612 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 613 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 614 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 615 616 errorstatus = CmdResp2Error ( ); 617 618 if ( SD_OK != errorstatus ) 619 { 620 return ( errorstatus ); 621 } 622 623 CID_Tab[ 0 ] = SDIO_GetResponse ( SDIO_RESP1 ); 624 CID_Tab[ 1 ] = SDIO_GetResponse ( SDIO_RESP2 ); 625 CID_Tab[ 2 ] = SDIO_GetResponse ( SDIO_RESP3 ); 626 CID_Tab[ 3 ] = SDIO_GetResponse ( SDIO_RESP4 ); 627 } 628 if ( ( SDIO_STD_CAPACITY_SD_CARD_V1_1 == CardType ) || 629 ( SDIO_STD_CAPACITY_SD_CARD_V2_0 == CardType ) || 630 ( SDIO_SECURE_DIGITAL_IO_COMBO_CARD == CardType ) || 631 ( SDIO_HIGH_CAPACITY_SD_CARD == CardType ) ) 632 { 633 /*!< Send CMD3 SET_REL_ADDR with argument 0 */ 634 /*!< SD Card publishes its RCA. */ 635 SDIO_CmdInitStructure.SDIO_Argument = 0x00; 636 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SET_REL_ADDR; 637 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 638 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 639 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 640 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 641 642 errorstatus = CmdResp6Error ( SD_CMD_SET_REL_ADDR, &rca ); 643 644 if ( SD_OK != errorstatus ) 645 { 646 return ( errorstatus ); 647 } 648 } 649 650 if ( SDIO_SECURE_DIGITAL_IO_CARD != CardType ) 651 { 652 RCA = rca; 653 654 /*!< Send CMD9 SEND_CSD with argument as card's RCA */ 655 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t )( rca << 16 ); 656 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SEND_CSD; 657 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Long; 658 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 659 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 660 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 661 662 errorstatus = CmdResp2Error ( ); 663 664 if ( SD_OK != errorstatus ) 665 { 666 return ( errorstatus ); 667 } 668 669 CSD_Tab[ 0 ] = SDIO_GetResponse ( SDIO_RESP1 ); 670 CSD_Tab[ 1 ] = SDIO_GetResponse ( SDIO_RESP2 ); 671 CSD_Tab[ 2 ] = SDIO_GetResponse ( SDIO_RESP3 ); 672 CSD_Tab[ 3 ] = SDIO_GetResponse ( SDIO_RESP4 ); 673 } 674 675 errorstatus = SD_OK; /*!< All cards get intialized */ 676 677 return ( errorstatus ); 678 } 679 680 /** 681 * @brief Returns information about specific card. 682 * @param cardinfo: pointer to a SD_CardInfo structure that contains all SD card 683 * information. 684 * @retval SD_Error: SD Card Error code. 685 */ 686 SD_Error SD_GetCardInfo ( SD_CardInfo * cardinfo ) 687 { 688 SD_Error errorstatus = SD_OK; 689 uint8_t tmp = 0; 690 691 cardinfo->CardType = ( uint8_t )CardType; 692 cardinfo->RCA = ( uint16_t )RCA; 693 694 /*!< Byte 0 */ 695 tmp = ( uint8_t )( ( CSD_Tab[ 0 ] & 0xFF000000 ) >> 24 ); 696 cardinfo->SD_csd.CSDStruct = ( tmp & 0xC0 ) >> 6; 697 cardinfo->SD_csd.SysSpecVersion = ( tmp & 0x3C ) >> 2; 698 cardinfo->SD_csd.Reserved1 = tmp & 0x03; 699 700 /*!< Byte 1 */ 701 tmp = ( uint8_t )( ( CSD_Tab[ 0 ] & 0x00FF0000 ) >> 16 ); 702 cardinfo->SD_csd.TAAC = tmp; 703 704 /*!< Byte 2 */ 705 tmp = ( uint8_t )( ( CSD_Tab[ 0 ] & 0x0000FF00 ) >> 8 ); 706 cardinfo->SD_csd.NSAC = tmp; 707 708 /*!< Byte 3 */ 709 tmp = ( uint8_t )( CSD_Tab[ 0 ] & 0x000000FF ); 710 cardinfo->SD_csd.MaxBusClkFrec = tmp; 711 712 /*!< Byte 4 */ 713 tmp = ( uint8_t )( ( CSD_Tab[ 1 ] & 0xFF000000 ) >> 24 ); 714 cardinfo->SD_csd.CardComdClasses = tmp << 4; 715 716 /*!< Byte 5 */ 717 tmp = ( uint8_t )( ( CSD_Tab[ 1 ] & 0x00FF0000 ) >> 16 ); 718 cardinfo->SD_csd.CardComdClasses |= ( tmp & 0xF0 ) >> 4; 719 cardinfo->SD_csd.RdBlockLen = tmp & 0x0F; 720 721 /*!< Byte 6 */ 722 tmp = ( uint8_t )( ( CSD_Tab[ 1 ] & 0x0000FF00 ) >> 8 ); 723 cardinfo->SD_csd.PartBlockRead = ( tmp & 0x80 ) >> 7; 724 cardinfo->SD_csd.WrBlockMisalign = ( tmp & 0x40 ) >> 6; 725 cardinfo->SD_csd.RdBlockMisalign = ( tmp & 0x20 ) >> 5; 726 cardinfo->SD_csd.DSRImpl = ( tmp & 0x10 ) >> 4; 727 cardinfo->SD_csd.Reserved2 = 0; /*!< Reserved */ 728 729 if ( ( CardType == SDIO_STD_CAPACITY_SD_CARD_V1_1 ) || 730 ( CardType == SDIO_STD_CAPACITY_SD_CARD_V2_0 ) ) 731 { 732 cardinfo->SD_csd.DeviceSize = ( tmp & 0x03 ) << 10; 733 734 /*!< Byte 7 */ 735 tmp = ( uint8_t )( CSD_Tab[ 1 ] & 0x000000FF ); 736 cardinfo->SD_csd.DeviceSize |= ( tmp ) << 2; 737 738 /*!< Byte 8 */ 739 tmp = ( uint8_t )( ( CSD_Tab[ 2 ] & 0xFF000000 ) >> 24 ); 740 cardinfo->SD_csd.DeviceSize |= ( tmp & 0xC0 ) >> 6; 741 742 cardinfo->SD_csd.MaxRdCurrentVDDMin = ( tmp & 0x38 ) >> 3; 743 cardinfo->SD_csd.MaxRdCurrentVDDMax = ( tmp & 0x07 ); 744 745 /*!< Byte 9 */ 746 tmp = ( uint8_t )( ( CSD_Tab[ 2 ] & 0x00FF0000 ) >> 16 ); 747 cardinfo->SD_csd.MaxWrCurrentVDDMin = ( tmp & 0xE0 ) >> 5; 748 cardinfo->SD_csd.MaxWrCurrentVDDMax = ( tmp & 0x1C ) >> 2; 749 cardinfo->SD_csd.DeviceSizeMul = ( tmp & 0x03 ) << 1; 750 /*!< Byte 10 */ 751 tmp = ( uint8_t )( ( CSD_Tab[ 2 ] & 0x0000FF00 ) >> 8 ); 752 cardinfo->SD_csd.DeviceSizeMul |= ( tmp & 0x80 ) >> 7; 753 754 cardinfo->CardCapacity = ( cardinfo->SD_csd.DeviceSize + 1 ); 755 cardinfo->CardCapacity *= ( 1 << ( cardinfo->SD_csd.DeviceSizeMul + 2 ) ); 756 cardinfo->CardBlockSize = 1 << ( cardinfo->SD_csd.RdBlockLen ); 757 cardinfo->CardCapacity *= cardinfo->CardBlockSize; 758 } 759 else if ( CardType == SDIO_HIGH_CAPACITY_SD_CARD ) 760 { 761 /*!< Byte 7 */ 762 tmp = ( uint8_t )( CSD_Tab[ 1 ] & 0x000000FF ); 763 cardinfo->SD_csd.DeviceSize = ( tmp & 0x3F ) << 16; 764 765 /*!< Byte 8 */ 766 tmp = ( uint8_t )( ( CSD_Tab[ 2 ] & 0xFF000000 ) >> 24 ); 767 768 cardinfo->SD_csd.DeviceSize |= ( tmp << 8 ); 769 770 /*!< Byte 9 */ 771 tmp = ( uint8_t )( ( CSD_Tab[ 2 ] & 0x00FF0000 ) >> 16 ); 772 773 cardinfo->SD_csd.DeviceSize |= ( tmp ); 774 775 /*!< Byte 10 */ 776 tmp = ( uint8_t )( ( CSD_Tab[ 2 ] & 0x0000FF00 ) >> 8 ); 777 778 cardinfo->CardCapacity = ( cardinfo->SD_csd.DeviceSize + 1 ) * 512 * 1024; 779 cardinfo->CardBlockSize = 512; 780 } 781 782 cardinfo->SD_csd.EraseGrSize = ( tmp & 0x40 ) >> 6; 783 cardinfo->SD_csd.EraseGrMul = ( tmp & 0x3F ) << 1; 784 785 /*!< Byte 11 */ 786 tmp = ( uint8_t )( CSD_Tab[ 2 ] & 0x000000FF ); 787 cardinfo->SD_csd.EraseGrMul |= ( tmp & 0x80 ) >> 7; 788 cardinfo->SD_csd.WrProtectGrSize = ( tmp & 0x7F ); 789 790 /*!< Byte 12 */ 791 tmp = ( uint8_t )( ( CSD_Tab[ 3 ] & 0xFF000000 ) >> 24 ); 792 cardinfo->SD_csd.WrProtectGrEnable = ( tmp & 0x80 ) >> 7; 793 cardinfo->SD_csd.ManDeflECC = ( tmp & 0x60 ) >> 5; 794 cardinfo->SD_csd.WrSpeedFact = ( tmp & 0x1C ) >> 2; 795 cardinfo->SD_csd.MaxWrBlockLen = ( tmp & 0x03 ) << 2; 796 797 /*!< Byte 13 */ 798 tmp = ( uint8_t )( ( CSD_Tab[ 3 ] & 0x00FF0000 ) >> 16 ); 799 cardinfo->SD_csd.MaxWrBlockLen |= ( tmp & 0xC0 ) >> 6; 800 cardinfo->SD_csd.WriteBlockPaPartial = ( tmp & 0x20 ) >> 5; 801 cardinfo->SD_csd.Reserved3 = 0; 802 cardinfo->SD_csd.ContentProtectAppli = ( tmp & 0x01 ); 803 804 /*!< Byte 14 */ 805 tmp = ( uint8_t )( ( CSD_Tab[ 3 ] & 0x0000FF00 ) >> 8 ); 806 cardinfo->SD_csd.FileFormatGrouop = ( tmp & 0x80 ) >> 7; 807 cardinfo->SD_csd.CopyFlag = ( tmp & 0x40 ) >> 6; 808 cardinfo->SD_csd.PermWrProtect = ( tmp & 0x20 ) >> 5; 809 cardinfo->SD_csd.TempWrProtect = ( tmp & 0x10 ) >> 4; 810 cardinfo->SD_csd.FileFormat = ( tmp & 0x0C ) >> 2; 811 cardinfo->SD_csd.ECC = ( tmp & 0x03 ); 812 813 /*!< Byte 15 */ 814 tmp = ( uint8_t )( CSD_Tab[ 3 ] & 0x000000FF ); 815 cardinfo->SD_csd.CSD_CRC = ( tmp & 0xFE ) >> 1; 816 cardinfo->SD_csd.Reserved4 = 1; 817 818 /*!< Byte 0 */ 819 tmp = ( uint8_t )( ( CID_Tab[ 0 ] & 0xFF000000 ) >> 24 ); 820 cardinfo->SD_cid.ManufacturerID = tmp; 821 822 /*!< Byte 1 */ 823 tmp = ( uint8_t )( ( CID_Tab[ 0 ] & 0x00FF0000 ) >> 16 ); 824 cardinfo->SD_cid.OEM_AppliID = tmp << 8; 825 826 /*!< Byte 2 */ 827 tmp = ( uint8_t )( ( CID_Tab[ 0 ] & 0x000000FF00 ) >> 8 ); 828 cardinfo->SD_cid.OEM_AppliID |= tmp; 829 830 /*!< Byte 3 */ 831 tmp = ( uint8_t )( CID_Tab[ 0 ] & 0x000000FF ); 832 cardinfo->SD_cid.ProdName1 = tmp << 24; 833 834 /*!< Byte 4 */ 835 tmp = ( uint8_t )( ( CID_Tab[ 1 ] & 0xFF000000 ) >> 24 ); 836 cardinfo->SD_cid.ProdName1 |= tmp << 16; 837 838 /*!< Byte 5 */ 839 tmp = ( uint8_t )( ( CID_Tab[ 1 ] & 0x00FF0000 ) >> 16 ); 840 cardinfo->SD_cid.ProdName1 |= tmp << 8; 841 842 /*!< Byte 6 */ 843 tmp = ( uint8_t )( ( CID_Tab[ 1 ] & 0x0000FF00 ) >> 8 ); 844 cardinfo->SD_cid.ProdName1 |= tmp; 845 846 /*!< Byte 7 */ 847 tmp = ( uint8_t )( CID_Tab[ 1 ] & 0x000000FF ); 848 cardinfo->SD_cid.ProdName2 = tmp; 849 850 /*!< Byte 8 */ 851 tmp = ( uint8_t )( ( CID_Tab[ 2 ] & 0xFF000000 ) >> 24 ); 852 cardinfo->SD_cid.ProdRev = tmp; 853 854 /*!< Byte 9 */ 855 tmp = ( uint8_t )( ( CID_Tab[ 2 ] & 0x00FF0000 ) >> 16 ); 856 cardinfo->SD_cid.ProdSN = tmp << 24; 857 858 /*!< Byte 10 */ 859 tmp = ( uint8_t )( ( CID_Tab[ 2 ] & 0x0000FF00 ) >> 8 ); 860 cardinfo->SD_cid.ProdSN |= tmp << 16; 861 862 /*!< Byte 11 */ 863 tmp = ( uint8_t )( CID_Tab[ 2 ] & 0x000000FF ); 864 cardinfo->SD_cid.ProdSN |= tmp << 8; 865 866 /*!< Byte 12 */ 867 tmp = ( uint8_t )( ( CID_Tab[ 3 ] & 0xFF000000 ) >> 24 ); 868 cardinfo->SD_cid.ProdSN |= tmp; 869 870 /*!< Byte 13 */ 871 tmp = ( uint8_t )( ( CID_Tab[ 3 ] & 0x00FF0000 ) >> 16 ); 872 cardinfo->SD_cid.Reserved1 |= ( tmp & 0xF0 ) >> 4; 873 cardinfo->SD_cid.ManufactDate = ( tmp & 0x0F ) << 8; 874 875 /*!< Byte 14 */ 876 tmp = ( uint8_t )( ( CID_Tab[ 3 ] & 0x0000FF00 ) >> 8 ); 877 cardinfo->SD_cid.ManufactDate |= tmp; 878 879 /*!< Byte 15 */ 880 tmp = ( uint8_t )( CID_Tab[ 3 ] & 0x000000FF ); 881 cardinfo->SD_cid.CID_CRC = ( tmp & 0xFE ) >> 1; 882 cardinfo->SD_cid.Reserved2 = 1; 883 884 return ( errorstatus ); 885 } 886 887 /** 888 * @brief Enables wide bus opeartion for the requeseted card if supported by 889 * card. 890 * @param WideMode: Specifies the SD card wide bus mode. 891 * This parameter can be one of the following values: 892 * @arg SDIO_BusWide_8b: 8-bit data transfer (Only for MMC) 893 * @arg SDIO_BusWide_4b: 4-bit data transfer 894 * @arg SDIO_BusWide_1b: 1-bit data transfer 895 * @retval SD_Error: SD Card Error code. 896 */ 897 SD_Error SD_EnableWideBusOperation ( uint32_t WideMode ) 898 { 899 SD_Error errorstatus = SD_OK; 900 901 /*!< MMC Card doesn't support this feature */ 902 if ( SDIO_MULTIMEDIA_CARD == CardType ) 903 { 904 errorstatus = SD_UNSUPPORTED_FEATURE; 905 return ( errorstatus ); 906 } 907 else if ( ( SDIO_STD_CAPACITY_SD_CARD_V1_1 == CardType ) || 908 ( SDIO_STD_CAPACITY_SD_CARD_V2_0 == CardType ) || 909 ( SDIO_HIGH_CAPACITY_SD_CARD == CardType ) ) 910 { 911 if ( SDIO_BusWide_8b == WideMode ) 912 { 913 errorstatus = SD_UNSUPPORTED_FEATURE; 914 return ( errorstatus ); 915 } 916 else if ( SDIO_BusWide_4b == WideMode ) 917 { 918 errorstatus = SDEnWideBus ( ENABLE ); 919 920 if ( SD_OK == errorstatus ) 921 { 922 /*!< Configure the SDIO peripheral */ 923 SDIO_InitStructure.SDIO_ClockDiv = SDIO_TRANSFER_CLK_DIV; 924 SDIO_InitStructure.SDIO_ClockEdge = SDIO_ClockEdge_Rising; 925 SDIO_InitStructure.SDIO_ClockBypass = SDIO_ClockBypass_Disable; 926 SDIO_InitStructure.SDIO_ClockPowerSave = SDIO_ClockPowerSave_Disable; 927 SDIO_InitStructure.SDIO_BusWide = SDIO_BusWide_4b; 928 SDIO_InitStructure.SDIO_HardwareFlowControl = 929 SDIO_HardwareFlowControl_Disable; 930 SDIO_Init ( & SDIO_InitStructure ); 931 } 932 } 933 else 934 { 935 errorstatus = SDEnWideBus ( DISABLE ); 936 937 if ( SD_OK == errorstatus ) 938 { 939 /*!< Configure the SDIO peripheral */ 940 SDIO_InitStructure.SDIO_ClockDiv = SDIO_TRANSFER_CLK_DIV; 941 SDIO_InitStructure.SDIO_ClockEdge = SDIO_ClockEdge_Rising; 942 SDIO_InitStructure.SDIO_ClockBypass = SDIO_ClockBypass_Disable; 943 SDIO_InitStructure.SDIO_ClockPowerSave = SDIO_ClockPowerSave_Disable; 944 SDIO_InitStructure.SDIO_BusWide = SDIO_BusWide_1b; 945 SDIO_InitStructure.SDIO_HardwareFlowControl = 946 SDIO_HardwareFlowControl_Disable; 947 SDIO_Init ( & SDIO_InitStructure ); 948 } 949 } 950 } 951 952 return ( errorstatus ); 953 } 954 955 /** 956 * @brief Sets device mode whether to operate in Polling, Interrupt or DMA mode. 957 * @param Mode: Specifies the Data Transfer mode. 958 * This parameter can be one of the following values: 959 * @arg SD_DMA_MODE: Data transfer using DMA. 960 * @arg SD_INTERRUPT_MODE: Data transfer using interrupts. 961 * @arg SD_POLLING_MODE: Data transfer using flags. 962 * @retval SD_Error: SD Card Error code. 963 */ 964 SD_Error SD_SetDeviceMode ( uint32_t Mode ) 965 { 966 SD_Error errorstatus = SD_OK; 967 968 if ( ( Mode == SD_DMA_MODE ) || ( Mode == SD_INTERRUPT_MODE ) || 969 ( Mode == SD_POLLING_MODE ) ) 970 { 971 DeviceMode = Mode; 972 } 973 else 974 { 975 errorstatus = SD_INVALID_PARAMETER; 976 } 977 return ( errorstatus ); 978 979 } 980 981 /** 982 * @brief Selects od Deselects the corresponding card. 983 * @param addr: Address of the Card to be selected. 984 * @retval SD_Error: SD Card Error code. 985 */ 986 SD_Error SD_SelectDeselect ( uint32_t addr ) 987 { 988 SD_Error errorstatus = SD_OK; 989 990 /*!< Send CMD7 SDIO_SEL_DESEL_CARD */ 991 SDIO_CmdInitStructure.SDIO_Argument = addr; 992 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SEL_DESEL_CARD; 993 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 994 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 995 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 996 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 997 998 errorstatus = CmdResp1Error ( SD_CMD_SEL_DESEL_CARD ); 999 1000 return ( errorstatus ); 1001 } 1002 1003 /** 1004 * @brief Allows to read one block from a specified address in a card. 1005 * @param readbuff: pointer to the buffer that will contain the received data 1006 * @param ReadAddr: Address from where data are to be read. 1007 * @param BlockSize: the SD card Data block size. 1008 * @retval SD_Error: SD Card Error code. 1009 */ 1010 SD_Error SD_ReadBlock ( uint8_t * readbuff, uint32_t ReadAddr, 1011 uint16_t BlockSize ) 1012 { 1013 SD_Error errorstatus = SD_OK; 1014 uint32_t count = 0, *tempbuff = ( uint32_t* )readbuff; 1015 uint8_t power = 0; 1016 1017 if ( NULL == readbuff ) 1018 { 1019 errorstatus = SD_INVALID_PARAMETER; 1020 return ( errorstatus ); 1021 } 1022 1023 TransferError = SD_OK; 1024 TransferEnd = 0; 1025 TotalNumberOfBytes = 0; 1026 1027 /*!< Clear all DPSM configuration */ 1028 SDIO_DataInitStructure.SDIO_DataTimeOut = SD_DATATIMEOUT; 1029 SDIO_DataInitStructure.SDIO_DataLength = 0; 1030 SDIO_DataInitStructure.SDIO_DataBlockSize = SDIO_DataBlockSize_1b; 1031 SDIO_DataInitStructure.SDIO_TransferDir = SDIO_TransferDir_ToCard; 1032 SDIO_DataInitStructure.SDIO_TransferMode = SDIO_TransferMode_Block; 1033 SDIO_DataInitStructure.SDIO_DPSM = SDIO_DPSM_Disable; 1034 SDIO_DataConfig ( & SDIO_DataInitStructure ); 1035 SDIO_DMACmd ( DISABLE ); 1036 1037 if ( SDIO_GetResponse( SDIO_RESP1 ) & SD_CARD_LOCKED ) 1038 { 1039 errorstatus = SD_LOCK_UNLOCK_FAILED; 1040 return ( errorstatus ); 1041 } 1042 1043 if ( CardType == SDIO_HIGH_CAPACITY_SD_CARD ) 1044 { 1045 BlockSize = 512; 1046 ReadAddr /= 512; 1047 } 1048 if ( ( BlockSize > 0 ) && ( BlockSize <= 2048 ) && 1049 ( ( BlockSize & ( BlockSize - 1 ) ) == 0 ) ) 1050 { 1051 power = convert_from_bytes_to_power_of_two ( BlockSize ); 1052 1053 /*!< Set Block Size for Card */ 1054 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t ) BlockSize; 1055 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SET_BLOCKLEN; 1056 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1057 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1058 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1059 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1060 1061 errorstatus = CmdResp1Error ( SD_CMD_SET_BLOCKLEN ); 1062 1063 if ( SD_OK != errorstatus ) 1064 { 1065 return ( errorstatus ); 1066 } 1067 } 1068 else 1069 { 1070 errorstatus = SD_INVALID_PARAMETER; 1071 return ( errorstatus ); 1072 } 1073 1074 SDIO_DataInitStructure.SDIO_DataTimeOut = SD_DATATIMEOUT; 1075 SDIO_DataInitStructure.SDIO_DataLength = BlockSize; 1076 SDIO_DataInitStructure.SDIO_DataBlockSize = ( uint32_t ) power << 4; 1077 SDIO_DataInitStructure.SDIO_TransferDir = SDIO_TransferDir_ToSDIO; 1078 SDIO_DataInitStructure.SDIO_TransferMode = SDIO_TransferMode_Block; 1079 SDIO_DataInitStructure.SDIO_DPSM = SDIO_DPSM_Enable; 1080 SDIO_DataConfig ( & SDIO_DataInitStructure ); 1081 1082 TotalNumberOfBytes = BlockSize; 1083 StopCondition = 0; 1084 DestBuffer = ( uint32_t* )readbuff; 1085 1086 /*!< Send CMD17 READ_SINGLE_BLOCK */ 1087 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t )ReadAddr; 1088 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_READ_SINGLE_BLOCK; 1089 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1090 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1091 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1092 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1093 1094 errorstatus = CmdResp1Error ( SD_CMD_READ_SINGLE_BLOCK ); 1095 1096 if ( errorstatus != SD_OK ) 1097 { 1098 return ( errorstatus ); 1099 } 1100 /*!< In case of single block transfer, no need of stop transfer at all.*/ 1101 if ( DeviceMode == SD_POLLING_MODE ) 1102 { 1103 /*!< Polling mode */ 1104 while ( !( SDIO->STA & ( SDIO_FLAG_RXOVERR | SDIO_FLAG_DCRCFAIL | 1105 SDIO_FLAG_DTIMEOUT | SDIO_FLAG_DBCKEND | SDIO_FLAG_STBITERR ) ) ) 1106 { 1107 if ( SDIO_GetFlagStatus( SDIO_FLAG_RXFIFOHF ) != RESET ) 1108 { 1109 for ( count = 0; count < 8; count++ ) 1110 { 1111 *( tempbuff + count ) = SDIO_ReadData ( ); 1112 } 1113 tempbuff += 8; 1114 } 1115 } 1116 1117 if ( SDIO_GetFlagStatus( SDIO_FLAG_DTIMEOUT ) != RESET ) 1118 { 1119 SDIO_ClearFlag ( SDIO_FLAG_DTIMEOUT ); 1120 errorstatus = SD_DATA_TIMEOUT; 1121 return ( errorstatus ); 1122 } 1123 else if ( SDIO_GetFlagStatus( SDIO_FLAG_DCRCFAIL ) != RESET ) 1124 { 1125 SDIO_ClearFlag ( SDIO_FLAG_DCRCFAIL ); 1126 errorstatus = SD_DATA_CRC_FAIL; 1127 return ( errorstatus ); 1128 } 1129 else if ( SDIO_GetFlagStatus( SDIO_FLAG_RXOVERR ) != RESET ) 1130 { 1131 SDIO_ClearFlag ( SDIO_FLAG_RXOVERR ); 1132 errorstatus = SD_RX_OVERRUN; 1133 return ( errorstatus ); 1134 } 1135 else if ( SDIO_GetFlagStatus( SDIO_FLAG_STBITERR ) != RESET ) 1136 { 1137 SDIO_ClearFlag ( SDIO_FLAG_STBITERR ); 1138 errorstatus = SD_START_BIT_ERR; 1139 return ( errorstatus ); 1140 } 1141 while ( SDIO_GetFlagStatus( SDIO_FLAG_RXDAVL ) != RESET ) 1142 { 1143 *tempbuff = SDIO_ReadData ( ); 1144 tempbuff++; 1145 } 1146 1147 /*!< Clear all the static flags */ 1148 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 1149 } 1150 else if ( DeviceMode == SD_INTERRUPT_MODE ) 1151 { 1152 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 1153 SDIO_IT_RXOVERR | SDIO_IT_RXFIFOHF | SDIO_IT_STBITERR, ENABLE ); 1154 while ( ( TransferEnd == 0 ) && ( TransferError == SD_OK ) ) 1155 { 1156 } 1157 if ( TransferError != SD_OK ) 1158 { 1159 return ( TransferError ); 1160 } 1161 } 1162 else if ( DeviceMode == SD_DMA_MODE ) 1163 { 1164 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 1165 SDIO_IT_RXOVERR | SDIO_IT_STBITERR, ENABLE ); 1166 SDIO_DMACmd ( ENABLE ); 1167 SD_LowLevel_DMA_RxConfig ( ( uint32_t * )readbuff, BlockSize ); 1168 while ( ( SD_DMAEndOfTransferStatus( ) == RESET ) && ( TransferEnd == 0 ) && 1169 ( TransferError == SD_OK ) ) 1170 { 1171 } 1172 if ( TransferError != SD_OK ) 1173 { 1174 return ( TransferError ); 1175 } 1176 } 1177 return ( errorstatus ); 1178 } 1179 1180 /** 1181 * @brief Allows to read blocks from a specified address in a card. 1182 * @param readbuff: pointer to the buffer that will contain the received data. 1183 * @param ReadAddr: Address from where data are to be read. 1184 * @param BlockSize: the SD card Data block size. 1185 * @param NumberOfBlocks: number of blocks to be read. 1186 * @retval SD_Error: SD Card Error code. 1187 */ 1188 SD_Error SD_ReadMultiBlocks ( uint8_t * readbuff, uint32_t ReadAddr, 1189 uint16_t BlockSize, uint32_t NumberOfBlocks ) 1190 { 1191 SD_Error errorstatus = SD_OK; 1192 uint32_t count = 0, *tempbuff = ( uint32_t* )readbuff; 1193 uint8_t power = 0; 1194 1195 if ( NULL == readbuff ) 1196 { 1197 errorstatus = SD_INVALID_PARAMETER; 1198 return ( errorstatus ); 1199 } 1200 1201 TransferError = SD_OK; 1202 TransferEnd = 0; 1203 TotalNumberOfBytes = 0; 1204 1205 /*!< Clear all DPSM configuration */ 1206 SDIO_DataInitStructure.SDIO_DataTimeOut = SD_DATATIMEOUT; 1207 SDIO_DataInitStructure.SDIO_DataLength = 0; 1208 SDIO_DataInitStructure.SDIO_DataBlockSize = SDIO_DataBlockSize_1b; 1209 SDIO_DataInitStructure.SDIO_TransferDir = SDIO_TransferDir_ToCard; 1210 SDIO_DataInitStructure.SDIO_TransferMode = SDIO_TransferMode_Block; 1211 SDIO_DataInitStructure.SDIO_DPSM = SDIO_DPSM_Disable; 1212 SDIO_DataConfig ( & SDIO_DataInitStructure ); 1213 SDIO_DMACmd ( DISABLE ); 1214 1215 if ( SDIO_GetResponse( SDIO_RESP1 ) & SD_CARD_LOCKED ) 1216 { 1217 errorstatus = SD_LOCK_UNLOCK_FAILED; 1218 return ( errorstatus ); 1219 } 1220 1221 if ( CardType == SDIO_HIGH_CAPACITY_SD_CARD ) 1222 { 1223 BlockSize = 512; 1224 ReadAddr /= 512; 1225 } 1226 1227 if ( ( BlockSize > 0 ) && ( BlockSize <= 2048 ) && 1228 ( 0 == ( BlockSize & ( BlockSize - 1 ) ) ) ) 1229 { 1230 power = convert_from_bytes_to_power_of_two ( BlockSize ); 1231 1232 /*!< Set Block Size for Card */ 1233 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t ) BlockSize; 1234 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SET_BLOCKLEN; 1235 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1236 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1237 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1238 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1239 1240 errorstatus = CmdResp1Error ( SD_CMD_SET_BLOCKLEN ); 1241 1242 if ( SD_OK != errorstatus ) 1243 { 1244 return ( errorstatus ); 1245 } 1246 } 1247 else 1248 { 1249 errorstatus = SD_INVALID_PARAMETER; 1250 return ( errorstatus ); 1251 } 1252 1253 if ( NumberOfBlocks > 1 ) 1254 { 1255 /*!< Common to all modes */ 1256 if ( NumberOfBlocks * BlockSize > SD_MAX_DATA_LENGTH ) 1257 { 1258 errorstatus = SD_INVALID_PARAMETER; 1259 return ( errorstatus ); 1260 } 1261 1262 TotalNumberOfBytes = NumberOfBlocks * BlockSize; 1263 StopCondition = 1; 1264 DestBuffer = ( uint32_t* )readbuff; 1265 1266 SDIO_DataInitStructure.SDIO_DataTimeOut = SD_DATATIMEOUT; 1267 SDIO_DataInitStructure.SDIO_DataLength = NumberOfBlocks * BlockSize; 1268 SDIO_DataInitStructure.SDIO_DataBlockSize = ( uint32_t ) power << 4; 1269 SDIO_DataInitStructure.SDIO_TransferDir = SDIO_TransferDir_ToSDIO; 1270 SDIO_DataInitStructure.SDIO_TransferMode = SDIO_TransferMode_Block; 1271 SDIO_DataInitStructure.SDIO_DPSM = SDIO_DPSM_Enable; 1272 SDIO_DataConfig ( & SDIO_DataInitStructure ); 1273 1274 /*!< Send CMD18 READ_MULT_BLOCK with argument data address */ 1275 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t )ReadAddr; 1276 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_READ_MULT_BLOCK; 1277 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1278 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1279 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1280 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1281 1282 errorstatus = CmdResp1Error ( SD_CMD_READ_MULT_BLOCK ); 1283 1284 if ( errorstatus != SD_OK ) 1285 { 1286 return ( errorstatus ); 1287 } 1288 1289 if ( DeviceMode == SD_POLLING_MODE ) 1290 { 1291 /*!< Polling mode */ 1292 while ( !( SDIO->STA & 1293 ( SDIO_FLAG_RXOVERR | SDIO_FLAG_DCRCFAIL | SDIO_FLAG_DATAEND | 1294 SDIO_FLAG_DTIMEOUT | SDIO_FLAG_STBITERR ) ) ) 1295 { 1296 if ( SDIO_GetFlagStatus( SDIO_FLAG_RXFIFOHF ) != RESET ) 1297 { 1298 for ( count = 0; count < SD_HALFFIFO; count++ ) 1299 { 1300 *( tempbuff + count ) = SDIO_ReadData ( ); 1301 } 1302 tempbuff += SD_HALFFIFO; 1303 } 1304 } 1305 1306 if ( SDIO_GetFlagStatus( SDIO_FLAG_DTIMEOUT ) != RESET ) 1307 { 1308 SDIO_ClearFlag ( SDIO_FLAG_DTIMEOUT ); 1309 errorstatus = SD_DATA_TIMEOUT; 1310 return ( errorstatus ); 1311 } 1312 else if ( SDIO_GetFlagStatus( SDIO_FLAG_DCRCFAIL ) != RESET ) 1313 { 1314 SDIO_ClearFlag ( SDIO_FLAG_DCRCFAIL ); 1315 errorstatus = SD_DATA_CRC_FAIL; 1316 return ( errorstatus ); 1317 } 1318 else if ( SDIO_GetFlagStatus( SDIO_FLAG_RXOVERR ) != RESET ) 1319 { 1320 SDIO_ClearFlag ( SDIO_FLAG_RXOVERR ); 1321 errorstatus = SD_RX_OVERRUN; 1322 return ( errorstatus ); 1323 } 1324 else if ( SDIO_GetFlagStatus( SDIO_FLAG_STBITERR ) != RESET ) 1325 { 1326 SDIO_ClearFlag ( SDIO_FLAG_STBITERR ); 1327 errorstatus = SD_START_BIT_ERR; 1328 return ( errorstatus ); 1329 } 1330 while ( SDIO_GetFlagStatus( SDIO_FLAG_RXDAVL ) != RESET ) 1331 { 1332 *tempbuff = SDIO_ReadData ( ); 1333 tempbuff++; 1334 } 1335 1336 if ( SDIO_GetFlagStatus( SDIO_FLAG_DATAEND ) != RESET ) 1337 { 1338 /*!< In Case Of SD-CARD Send Command STOP_TRANSMISSION */ 1339 if ( ( SDIO_STD_CAPACITY_SD_CARD_V1_1 == CardType ) || 1340 ( SDIO_HIGH_CAPACITY_SD_CARD == CardType ) || 1341 ( SDIO_STD_CAPACITY_SD_CARD_V2_0 == CardType ) ) 1342 { 1343 /*!< Send CMD12 STOP_TRANSMISSION */ 1344 SDIO_CmdInitStructure.SDIO_Argument = 0x0; 1345 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_STOP_TRANSMISSION; 1346 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1347 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1348 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1349 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1350 1351 errorstatus = CmdResp1Error ( SD_CMD_STOP_TRANSMISSION ); 1352 1353 if ( errorstatus != SD_OK ) 1354 { 1355 return ( errorstatus ); 1356 } 1357 } 1358 } 1359 /*!< Clear all the static flags */ 1360 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 1361 } 1362 else if ( DeviceMode == SD_INTERRUPT_MODE ) 1363 { 1364 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 1365 SDIO_IT_RXOVERR | SDIO_IT_RXFIFOHF | SDIO_IT_STBITERR, ENABLE ); 1366 while ( ( TransferEnd == 0 ) && ( TransferError == SD_OK ) ) 1367 { 1368 } 1369 if ( TransferError != SD_OK ) 1370 { 1371 return ( TransferError ); 1372 } 1373 } 1374 else if ( DeviceMode == SD_DMA_MODE ) 1375 { 1376 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 1377 SDIO_IT_RXOVERR | SDIO_IT_STBITERR, ENABLE ); 1378 SDIO_DMACmd ( ENABLE ); 1379 SD_LowLevel_DMA_RxConfig ( ( uint32_t * )readbuff, 1380 ( NumberOfBlocks * BlockSize ) ); 1381 while ( ( SD_DMAEndOfTransferStatus( ) == RESET ) && ( TransferEnd == 0 ) 1382 && ( TransferError == SD_OK ) ) 1383 { 1384 } 1385 if ( TransferError != SD_OK ) 1386 { 1387 return ( TransferError ); 1388 } 1389 } 1390 } 1391 return ( errorstatus ); 1392 } 1393 1394 /** 1395 * @brief Allows to write one block starting from a specified address in a card. 1396 * @param writebuff: pointer to the buffer that contain the data to be transferred. 1397 * @param WriteAddr: Address from where data are to be read. 1398 * @param BlockSize: the SD card Data block size. 1399 * @retval SD_Error: SD Card Error code. 1400 */ 1401 SD_Error SD_WriteBlock ( uint8_t * writebuff, uint32_t WriteAddr, 1402 uint16_t BlockSize ) 1403 { 1404 SD_Error errorstatus = SD_OK; 1405 uint8_t power = 0, cardstate = 0; 1406 uint32_t timeout = 0, bytestransferred = 0; 1407 uint32_t cardstatus = 0, count = 0, restwords = 0; 1408 uint32_t * tempbuff = ( uint32_t* )writebuff; 1409 1410 if ( writebuff == NULL ) 1411 { 1412 errorstatus = SD_INVALID_PARAMETER; 1413 return ( errorstatus ); 1414 } 1415 1416 TransferError = SD_OK; 1417 TransferEnd = 0; 1418 TotalNumberOfBytes = 0; 1419 1420 SDIO_DataInitStructure.SDIO_DataTimeOut = SD_DATATIMEOUT; 1421 SDIO_DataInitStructure.SDIO_DataLength = 0; 1422 SDIO_DataInitStructure.SDIO_DataBlockSize = SDIO_DataBlockSize_1b; 1423 SDIO_DataInitStructure.SDIO_TransferDir = SDIO_TransferDir_ToCard; 1424 SDIO_DataInitStructure.SDIO_TransferMode = SDIO_TransferMode_Block; 1425 SDIO_DataInitStructure.SDIO_DPSM = SDIO_DPSM_Disable; 1426 SDIO_DataConfig ( & SDIO_DataInitStructure ); 1427 SDIO_DMACmd ( DISABLE ); 1428 1429 if ( SDIO_GetResponse( SDIO_RESP1 ) & SD_CARD_LOCKED ) 1430 { 1431 errorstatus = SD_LOCK_UNLOCK_FAILED; 1432 return ( errorstatus ); 1433 } 1434 1435 if ( CardType == SDIO_HIGH_CAPACITY_SD_CARD ) 1436 { 1437 BlockSize = 512; 1438 WriteAddr /= 512; 1439 } 1440 1441 /*!< Set the block size, both on controller and card */ 1442 if ( ( BlockSize > 0 ) && ( BlockSize <= 2048 ) && 1443 ( ( BlockSize & ( BlockSize - 1 ) ) == 0 ) ) 1444 { 1445 power = convert_from_bytes_to_power_of_two ( BlockSize ); 1446 1447 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t ) BlockSize; 1448 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SET_BLOCKLEN; 1449 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1450 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1451 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1452 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1453 1454 errorstatus = CmdResp1Error ( SD_CMD_SET_BLOCKLEN ); 1455 1456 if ( errorstatus != SD_OK ) 1457 { 1458 return ( errorstatus ); 1459 } 1460 } 1461 else 1462 { 1463 errorstatus = SD_INVALID_PARAMETER; 1464 return ( errorstatus ); 1465 } 1466 1467 /*!< Wait till card is ready for data Added */ 1468 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t )( RCA << 16 ); 1469 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SEND_STATUS; 1470 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1471 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1472 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1473 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1474 1475 errorstatus = CmdResp1Error ( SD_CMD_SEND_STATUS ); 1476 1477 if ( errorstatus != SD_OK ) 1478 { 1479 return ( errorstatus ); 1480 } 1481 1482 cardstatus = SDIO_GetResponse ( SDIO_RESP1 ); 1483 1484 timeout = SD_DATATIMEOUT; 1485 1486 while ( ( ( cardstatus & 0x00000100 ) == 0 ) && ( timeout > 0 ) ) 1487 { 1488 timeout--; 1489 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t )( RCA << 16 ); 1490 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SEND_STATUS; 1491 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1492 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1493 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1494 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1495 1496 errorstatus = CmdResp1Error ( SD_CMD_SEND_STATUS ); 1497 1498 if ( errorstatus != SD_OK ) 1499 { 1500 return ( errorstatus ); 1501 } 1502 cardstatus = SDIO_GetResponse ( SDIO_RESP1 ); 1503 } 1504 1505 if ( timeout == 0 ) 1506 { 1507 return ( SD_ERROR ); 1508 } 1509 1510 /*!< Send CMD24 WRITE_SINGLE_BLOCK */ 1511 SDIO_CmdInitStructure.SDIO_Argument = WriteAddr; 1512 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_WRITE_SINGLE_BLOCK; 1513 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1514 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1515 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1516 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1517 1518 errorstatus = CmdResp1Error ( SD_CMD_WRITE_SINGLE_BLOCK ); 1519 1520 if ( errorstatus != SD_OK ) 1521 { 1522 return ( errorstatus ); 1523 } 1524 1525 TotalNumberOfBytes = BlockSize; 1526 StopCondition = 0; 1527 SrcBuffer = ( uint32_t* )writebuff; 1528 1529 SDIO_DataInitStructure.SDIO_DataTimeOut = SD_DATATIMEOUT; 1530 SDIO_DataInitStructure.SDIO_DataLength = BlockSize; 1531 SDIO_DataInitStructure.SDIO_DataBlockSize = ( uint32_t ) power << 4; 1532 SDIO_DataInitStructure.SDIO_TransferDir = SDIO_TransferDir_ToCard; 1533 SDIO_DataInitStructure.SDIO_TransferMode = SDIO_TransferMode_Block; 1534 SDIO_DataInitStructure.SDIO_DPSM = SDIO_DPSM_Enable; 1535 SDIO_DataConfig ( & SDIO_DataInitStructure ); 1536 1537 /*!< In case of single data block transfer no need of stop command at all */ 1538 if ( DeviceMode == SD_POLLING_MODE ) 1539 { 1540 while ( !( SDIO->STA & ( SDIO_FLAG_DBCKEND | SDIO_FLAG_TXUNDERR | 1541 SDIO_FLAG_DCRCFAIL | SDIO_FLAG_DTIMEOUT | SDIO_FLAG_STBITERR ) ) ) 1542 { 1543 if ( SDIO_GetFlagStatus( SDIO_FLAG_TXFIFOHE ) != RESET ) 1544 { 1545 if ( ( TotalNumberOfBytes - bytestransferred ) < 32 ) 1546 { 1547 restwords = ( ( TotalNumberOfBytes - bytestransferred ) % 4 == 0 ) ? 1548 ( ( TotalNumberOfBytes - bytestransferred ) / 4 ) : 1549 ( ( TotalNumberOfBytes - bytestransferred ) / 4 + 1 ); 1550 1551 for ( count = 0; count < restwords; 1552 count++, tempbuff++, bytestransferred += 4 ) 1553 { 1554 SDIO_WriteData ( * tempbuff ); 1555 } 1556 } 1557 else 1558 { 1559 for ( count = 0; count < 8; count++ ) 1560 { 1561 SDIO_WriteData ( * ( tempbuff + count ) ); 1562 } 1563 tempbuff += 8; 1564 bytestransferred += 32; 1565 } 1566 } 1567 } 1568 if ( SDIO_GetFlagStatus( SDIO_FLAG_DTIMEOUT ) != RESET ) 1569 { 1570 SDIO_ClearFlag ( SDIO_FLAG_DTIMEOUT ); 1571 errorstatus = SD_DATA_TIMEOUT; 1572 return ( errorstatus ); 1573 } 1574 else if ( SDIO_GetFlagStatus( SDIO_FLAG_DCRCFAIL ) != RESET ) 1575 { 1576 SDIO_ClearFlag ( SDIO_FLAG_DCRCFAIL ); 1577 errorstatus = SD_DATA_CRC_FAIL; 1578 return ( errorstatus ); 1579 } 1580 else if ( SDIO_GetFlagStatus( SDIO_FLAG_TXUNDERR ) != RESET ) 1581 { 1582 SDIO_ClearFlag ( SDIO_FLAG_TXUNDERR ); 1583 errorstatus = SD_TX_UNDERRUN; 1584 return ( errorstatus ); 1585 } 1586 else if ( SDIO_GetFlagStatus( SDIO_FLAG_STBITERR ) != RESET ) 1587 { 1588 SDIO_ClearFlag ( SDIO_FLAG_STBITERR ); 1589 errorstatus = SD_START_BIT_ERR; 1590 return ( errorstatus ); 1591 } 1592 } 1593 else if ( DeviceMode == SD_INTERRUPT_MODE ) 1594 { 1595 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 1596 SDIO_FLAG_TXFIFOHE | SDIO_IT_TXUNDERR | SDIO_IT_STBITERR, ENABLE ); 1597 while ( ( TransferEnd == 0 ) && ( TransferError == SD_OK ) ) 1598 { 1599 } 1600 if ( TransferError != SD_OK ) 1601 { 1602 return ( TransferError ); 1603 } 1604 } 1605 else if ( DeviceMode == SD_DMA_MODE ) 1606 { 1607 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 1608 SDIO_IT_TXUNDERR | SDIO_IT_STBITERR, ENABLE ); 1609 SD_LowLevel_DMA_TxConfig ( ( uint32_t * )writebuff, BlockSize ); 1610 SDIO_DMACmd ( ENABLE ); 1611 while ( ( SD_DMAEndOfTransferStatus( ) == RESET ) && ( TransferEnd == 0 ) && 1612 ( TransferError == SD_OK ) ) 1613 { 1614 } 1615 if ( TransferError != SD_OK ) 1616 { 1617 return ( TransferError ); 1618 } 1619 } 1620 1621 /*!< Clear all the static flags */ 1622 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 1623 1624 /*!< Wait till the card is in programming state */ 1625 errorstatus = IsCardProgramming ( &cardstate ); 1626 1627 while ( ( errorstatus == SD_OK ) && ( ( cardstate == SD_CARD_PROGRAMMING ) || 1628 ( cardstate == SD_CARD_RECEIVING ) ) ) 1629 { 1630 errorstatus = IsCardProgramming ( &cardstate ); 1631 } 1632 1633 return ( errorstatus ); 1634 } 1635 1636 /** 1637 * @brief Allows to write blocks starting from a specified address in a card. 1638 * @param WriteAddr: Address from where data are to be read. 1639 * @param writebuff: pointer to the buffer that contain the data to be transferred. 1640 * @param BlockSize: the SD card Data block size. 1641 * @param NumberOfBlocks: number of blocks to be written. 1642 * @retval SD_Error: SD Card Error code. 1643 */ 1644 SD_Error SD_WriteMultiBlocks ( uint8_t * writebuff, uint32_t WriteAddr, 1645 uint16_t BlockSize, uint32_t NumberOfBlocks ) 1646 { 1647 SD_Error errorstatus = SD_OK; 1648 uint8_t power = 0, cardstate = 0; 1649 uint32_t bytestransferred = 0; 1650 uint32_t restwords = 0; 1651 uint32_t * tempbuff = ( uint32_t* )writebuff; 1652 __IO uint32_t count = 0; 1653 1654 if ( writebuff == NULL ) 1655 { 1656 errorstatus = SD_INVALID_PARAMETER; 1657 return ( errorstatus ); 1658 } 1659 1660 TransferError = SD_OK; 1661 TransferEnd = 0; 1662 TotalNumberOfBytes = 0; 1663 1664 SDIO_DataInitStructure.SDIO_DataTimeOut = SD_DATATIMEOUT; 1665 SDIO_DataInitStructure.SDIO_DataLength = 0; 1666 SDIO_DataInitStructure.SDIO_DataBlockSize = SDIO_DataBlockSize_1b; 1667 SDIO_DataInitStructure.SDIO_TransferDir = SDIO_TransferDir_ToCard; 1668 SDIO_DataInitStructure.SDIO_TransferMode = SDIO_TransferMode_Block; 1669 SDIO_DataInitStructure.SDIO_DPSM = SDIO_DPSM_Disable; 1670 SDIO_DataConfig ( & SDIO_DataInitStructure ); 1671 SDIO_DMACmd ( DISABLE ); 1672 1673 if ( SDIO_GetResponse( SDIO_RESP1 ) & SD_CARD_LOCKED ) 1674 { 1675 errorstatus = SD_LOCK_UNLOCK_FAILED; 1676 return ( errorstatus ); 1677 } 1678 1679 if ( CardType == SDIO_HIGH_CAPACITY_SD_CARD ) 1680 { 1681 BlockSize = 512; 1682 WriteAddr /= 512; 1683 } 1684 1685 /*!< Set the block size, both on controller and card */ 1686 if ( ( BlockSize > 0 ) && ( BlockSize <= 2048 ) && 1687 ( ( BlockSize & ( BlockSize - 1 ) ) == 0 ) ) 1688 { 1689 power = convert_from_bytes_to_power_of_two ( BlockSize ); 1690 1691 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t ) BlockSize; 1692 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SET_BLOCKLEN; 1693 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1694 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1695 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1696 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1697 1698 errorstatus = CmdResp1Error ( SD_CMD_SET_BLOCKLEN ); 1699 1700 if ( errorstatus != SD_OK ) 1701 { 1702 return ( errorstatus ); 1703 } 1704 } 1705 else 1706 { 1707 errorstatus = SD_INVALID_PARAMETER; 1708 return ( errorstatus ); 1709 } 1710 1711 /*!< Wait till card is ready for data Added */ 1712 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t )( RCA << 16 ); 1713 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SEND_STATUS; 1714 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1715 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1716 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1717 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1718 1719 errorstatus = CmdResp1Error ( SD_CMD_SEND_STATUS ); 1720 1721 if ( errorstatus != SD_OK ) 1722 { 1723 return ( errorstatus ); 1724 } 1725 1726 if ( NumberOfBlocks > 1 ) 1727 { 1728 /*!< Common to all modes */ 1729 if ( NumberOfBlocks * BlockSize > SD_MAX_DATA_LENGTH ) 1730 { 1731 errorstatus = SD_INVALID_PARAMETER; 1732 return ( errorstatus ); 1733 } 1734 1735 if ( ( SDIO_STD_CAPACITY_SD_CARD_V1_1 == CardType ) || 1736 ( SDIO_STD_CAPACITY_SD_CARD_V2_0 == CardType ) || 1737 ( SDIO_HIGH_CAPACITY_SD_CARD == CardType ) ) 1738 { 1739 /*!< To improve performance */ 1740 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t )( RCA << 16 ); 1741 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_APP_CMD; 1742 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1743 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1744 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1745 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1746 1747 errorstatus = CmdResp1Error ( SD_CMD_APP_CMD ); 1748 1749 if ( errorstatus != SD_OK ) 1750 { 1751 return ( errorstatus ); 1752 } 1753 /*!< To improve performance */ 1754 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t )NumberOfBlocks; 1755 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SET_BLOCK_COUNT; 1756 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1757 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1758 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1759 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1760 1761 errorstatus = CmdResp1Error ( SD_CMD_SET_BLOCK_COUNT ); 1762 1763 if ( errorstatus != SD_OK ) 1764 { 1765 return ( errorstatus ); 1766 } 1767 } 1768 1769 /*!< Send CMD25 WRITE_MULT_BLOCK with argument data address */ 1770 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t )WriteAddr; 1771 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_WRITE_MULT_BLOCK; 1772 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1773 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1774 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1775 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1776 1777 errorstatus = CmdResp1Error ( SD_CMD_WRITE_MULT_BLOCK ); 1778 1779 if ( SD_OK != errorstatus ) 1780 { 1781 return ( errorstatus ); 1782 } 1783 1784 TotalNumberOfBytes = NumberOfBlocks * BlockSize; 1785 StopCondition = 1; 1786 SrcBuffer = ( uint32_t* )writebuff; 1787 1788 SDIO_DataInitStructure.SDIO_DataTimeOut = SD_DATATIMEOUT; 1789 SDIO_DataInitStructure.SDIO_DataLength = NumberOfBlocks * BlockSize; 1790 SDIO_DataInitStructure.SDIO_DataBlockSize = ( uint32_t ) power << 4; 1791 SDIO_DataInitStructure.SDIO_TransferDir = SDIO_TransferDir_ToCard; 1792 SDIO_DataInitStructure.SDIO_TransferMode = SDIO_TransferMode_Block; 1793 SDIO_DataInitStructure.SDIO_DPSM = SDIO_DPSM_Enable; 1794 SDIO_DataConfig ( & SDIO_DataInitStructure ); 1795 1796 if ( DeviceMode == SD_POLLING_MODE ) 1797 { 1798 while ( !( SDIO->STA & 1799 ( SDIO_FLAG_TXUNDERR | SDIO_FLAG_DCRCFAIL | SDIO_FLAG_DATAEND | 1800 SDIO_FLAG_DTIMEOUT | SDIO_FLAG_STBITERR ) ) ) 1801 { 1802 if ( SDIO_GetFlagStatus( SDIO_FLAG_TXFIFOHE ) != RESET ) 1803 { 1804 if ( !( ( TotalNumberOfBytes - bytestransferred ) < 1805 SD_HALFFIFOBYTES ) ) 1806 { 1807 for ( count = 0; count < SD_HALFFIFO; count++ ) 1808 { 1809 SDIO_WriteData ( * ( tempbuff + count ) ); 1810 } 1811 tempbuff += SD_HALFFIFO; 1812 bytestransferred += SD_HALFFIFOBYTES; 1813 } 1814 else 1815 { 1816 restwords = ( ( TotalNumberOfBytes - bytestransferred ) % 4 == 0 ) ? 1817 ( ( TotalNumberOfBytes - bytestransferred ) / 4 ) : 1818 ( ( TotalNumberOfBytes - bytestransferred ) / 4 + 1 ); 1819 1820 for ( count = 0; count < restwords; 1821 count++, tempbuff++, bytestransferred += 4 ) 1822 { 1823 SDIO_WriteData ( * tempbuff ); 1824 } 1825 } 1826 } 1827 } 1828 1829 if ( SDIO_GetFlagStatus( SDIO_FLAG_DTIMEOUT ) != RESET ) 1830 { 1831 SDIO_ClearFlag ( SDIO_FLAG_DTIMEOUT ); 1832 errorstatus = SD_DATA_TIMEOUT; 1833 return ( errorstatus ); 1834 } 1835 else if ( SDIO_GetFlagStatus( SDIO_FLAG_DCRCFAIL ) != RESET ) 1836 { 1837 SDIO_ClearFlag ( SDIO_FLAG_DCRCFAIL ); 1838 errorstatus = SD_DATA_CRC_FAIL; 1839 return ( errorstatus ); 1840 } 1841 else if ( SDIO_GetFlagStatus( SDIO_FLAG_TXUNDERR ) != RESET ) 1842 { 1843 SDIO_ClearFlag ( SDIO_FLAG_TXUNDERR ); 1844 errorstatus = SD_TX_UNDERRUN; 1845 return ( errorstatus ); 1846 } 1847 else if ( SDIO_GetFlagStatus( SDIO_FLAG_STBITERR ) != RESET ) 1848 { 1849 SDIO_ClearFlag ( SDIO_FLAG_STBITERR ); 1850 errorstatus = SD_START_BIT_ERR; 1851 return ( errorstatus ); 1852 } 1853 1854 if ( SDIO_GetFlagStatus( SDIO_FLAG_DATAEND ) != RESET ) 1855 { 1856 if ( ( SDIO_STD_CAPACITY_SD_CARD_V1_1 == CardType ) || 1857 ( SDIO_STD_CAPACITY_SD_CARD_V2_0 == CardType ) || 1858 ( SDIO_HIGH_CAPACITY_SD_CARD == CardType ) ) 1859 { 1860 /*!< Send CMD12 STOP_TRANSMISSION */ 1861 SDIO_CmdInitStructure.SDIO_Argument = 0x0; 1862 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_STOP_TRANSMISSION; 1863 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1864 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1865 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1866 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1867 1868 errorstatus = CmdResp1Error ( SD_CMD_STOP_TRANSMISSION ); 1869 1870 if ( errorstatus != SD_OK ) 1871 { 1872 return ( errorstatus ); 1873 } 1874 } 1875 } 1876 } 1877 else if ( DeviceMode == SD_INTERRUPT_MODE ) 1878 { 1879 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 1880 SDIO_IT_TXFIFOHE | SDIO_IT_TXUNDERR | SDIO_IT_STBITERR, ENABLE ); 1881 while ( ( TransferEnd == 0 ) && ( TransferError == SD_OK ) ) 1882 { 1883 } 1884 if ( TransferError != SD_OK ) 1885 { 1886 return ( TransferError ); 1887 } 1888 } 1889 else if ( DeviceMode == SD_DMA_MODE ) 1890 { 1891 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 1892 SDIO_IT_TXUNDERR | SDIO_IT_STBITERR, ENABLE ); 1893 SDIO_DMACmd ( ENABLE ); 1894 SD_LowLevel_DMA_TxConfig ( ( uint32_t * )writebuff, 1895 ( NumberOfBlocks * BlockSize ) ); 1896 while ( ( SD_DMAEndOfTransferStatus( ) == RESET ) && ( TransferEnd == 0 ) 1897 && ( TransferError == SD_OK ) ) 1898 { 1899 } 1900 if ( TransferError != SD_OK ) 1901 { 1902 return ( TransferError ); 1903 } 1904 } 1905 } 1906 /*!< Clear all the static flags */ 1907 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 1908 1909 /*!< Add some delay before checking the Card Status */ 1910 for ( count = 0; count < 0xFFFF; count++ ) 1911 { 1912 } 1913 /*!< Wait till the card is in programming state */ 1914 errorstatus = IsCardProgramming ( &cardstate ); 1915 1916 while ( ( errorstatus == SD_OK ) && ( ( cardstate == SD_CARD_PROGRAMMING ) || 1917 ( cardstate == SD_CARD_RECEIVING ) ) ) 1918 { 1919 errorstatus = IsCardProgramming ( &cardstate ); 1920 } 1921 1922 return ( errorstatus ); 1923 } 1924 1925 /** 1926 * @brief Gets the cuurent data transfer state. 1927 * @param None 1928 * @retval SDTransferState: Data Transfer state. 1929 * This value can be: 1930 * - SD_TRANSFER_OK: No data transfer is acting 1931 * - SD_TRANSFER_BUSY: Data transfer is acting 1932 */ 1933 SDTransferState SD_GetTransferState ( void ) 1934 { 1935 if ( SDIO->STA & ( SDIO_FLAG_TXACT | SDIO_FLAG_RXACT ) ) 1936 { 1937 return ( SD_TRANSFER_BUSY ); 1938 } 1939 else 1940 { 1941 return ( SD_TRANSFER_OK ); 1942 } 1943 } 1944 1945 /** 1946 * @brief Aborts an ongoing data transfer. 1947 * @param None 1948 * @retval SD_Error: SD Card Error code. 1949 */ 1950 SD_Error SD_StopTransfer ( void ) 1951 { 1952 SD_Error errorstatus = SD_OK; 1953 1954 /*!< Send CMD12 STOP_TRANSMISSION */ 1955 SDIO_CmdInitStructure.SDIO_Argument = 0x0; 1956 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_STOP_TRANSMISSION; 1957 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 1958 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 1959 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 1960 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 1961 1962 errorstatus = CmdResp1Error ( SD_CMD_STOP_TRANSMISSION ); 1963 1964 return ( errorstatus ); 1965 } 1966 1967 /** 1968 * @brief Allows to erase memory area specified for the given card. 1969 * @param startaddr: the start address. 1970 * @param endaddr: the end address. 1971 * @retval SD_Error: SD Card Error code. 1972 */ 1973 SD_Error SD_Erase ( uint32_t startaddr, uint32_t endaddr ) 1974 { 1975 SD_Error errorstatus = SD_OK; 1976 uint32_t delay = 0; 1977 __IO uint32_t maxdelay = 0; 1978 uint8_t cardstate = 0; 1979 1980 /*!< Check if the card coomnd class supports erase command */ 1981 if ( ( ( CSD_Tab[ 1 ] >> 20 ) & SD_CCCC_ERASE ) == 0 ) 1982 { 1983 errorstatus = SD_REQUEST_NOT_APPLICABLE; 1984 return ( errorstatus ); 1985 } 1986 1987 maxdelay = 120000 / ( ( SDIO->CLKCR & 0xFF ) + 2 ); 1988 1989 if ( SDIO_GetResponse( SDIO_RESP1 ) & SD_CARD_LOCKED ) 1990 { 1991 errorstatus = SD_LOCK_UNLOCK_FAILED; 1992 return ( errorstatus ); 1993 } 1994 1995 if ( CardType == SDIO_HIGH_CAPACITY_SD_CARD ) 1996 { 1997 startaddr /= 512; 1998 endaddr /= 512; 1999 } 2000 2001 /*!< According to sd-card spec 1.0 ERASE_GROUP_START (CMD32) and erase_group_end(CMD33) */ 2002 if ( ( SDIO_STD_CAPACITY_SD_CARD_V1_1 == CardType ) || 2003 ( SDIO_STD_CAPACITY_SD_CARD_V2_0 == CardType ) || 2004 ( SDIO_HIGH_CAPACITY_SD_CARD == CardType ) ) 2005 { 2006 /*!< Send CMD32 SD_ERASE_GRP_START with argument as addr */ 2007 SDIO_CmdInitStructure.SDIO_Argument = startaddr; 2008 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SD_ERASE_GRP_START; 2009 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2010 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2011 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2012 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2013 2014 errorstatus = CmdResp1Error ( SD_CMD_SD_ERASE_GRP_START ); 2015 if ( errorstatus != SD_OK ) 2016 { 2017 return ( errorstatus ); 2018 } 2019 2020 /*!< Send CMD33 SD_ERASE_GRP_END with argument as addr */ 2021 SDIO_CmdInitStructure.SDIO_Argument = endaddr; 2022 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SD_ERASE_GRP_END; 2023 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2024 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2025 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2026 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2027 2028 errorstatus = CmdResp1Error ( SD_CMD_SD_ERASE_GRP_END ); 2029 if ( errorstatus != SD_OK ) 2030 { 2031 return ( errorstatus ); 2032 } 2033 } 2034 2035 /*!< Send CMD38 ERASE */ 2036 SDIO_CmdInitStructure.SDIO_Argument = 0; 2037 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_ERASE; 2038 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2039 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2040 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2041 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2042 2043 errorstatus = CmdResp1Error ( SD_CMD_ERASE ); 2044 2045 if ( errorstatus != SD_OK ) 2046 { 2047 return ( errorstatus ); 2048 } 2049 2050 for ( delay = 0; delay < maxdelay; delay++ ) 2051 { 2052 } 2053 2054 /*!< Wait till the card is in programming state */ 2055 errorstatus = IsCardProgramming ( &cardstate ); 2056 2057 while ( ( errorstatus == SD_OK ) && ( ( SD_CARD_PROGRAMMING == cardstate ) || 2058 ( SD_CARD_RECEIVING == cardstate ) ) ) 2059 { 2060 errorstatus = IsCardProgramming ( &cardstate ); 2061 } 2062 2063 return ( errorstatus ); 2064 } 2065 2066 /** 2067 * @brief Returns the current card's status. 2068 * @param pcardstatus: pointer to the buffer that will contain the SD card 2069 * status (Card Status register). 2070 * @retval SD_Error: SD Card Error code. 2071 */ 2072 SD_Error SD_SendStatus ( uint32_t * pcardstatus ) 2073 { 2074 SD_Error errorstatus = SD_OK; 2075 2076 if ( pcardstatus == NULL ) 2077 { 2078 errorstatus = SD_INVALID_PARAMETER; 2079 return ( errorstatus ); 2080 } 2081 2082 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t ) RCA << 16; 2083 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SEND_STATUS; 2084 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2085 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2086 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2087 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2088 2089 errorstatus = CmdResp1Error ( SD_CMD_SEND_STATUS ); 2090 2091 if ( errorstatus != SD_OK ) 2092 { 2093 return ( errorstatus ); 2094 } 2095 2096 *pcardstatus = SDIO_GetResponse ( SDIO_RESP1 ); 2097 2098 return ( errorstatus ); 2099 } 2100 2101 /** 2102 * @brief Returns the current SD card's status. 2103 * @param psdstatus: pointer to the buffer that will contain the SD card status 2104 * (SD Status register). 2105 * @retval SD_Error: SD Card Error code. 2106 */ 2107 SD_Error SD_SendSDStatus ( uint32_t * psdstatus ) 2108 { 2109 SD_Error errorstatus = SD_OK; 2110 uint32_t count = 0; 2111 2112 if ( SDIO_GetResponse( SDIO_RESP1 ) & SD_CARD_LOCKED ) 2113 { 2114 errorstatus = SD_LOCK_UNLOCK_FAILED; 2115 return ( errorstatus ); 2116 } 2117 2118 /*!< Set block size for card if it is not equal to current block size for card. */ 2119 SDIO_CmdInitStructure.SDIO_Argument = 64; 2120 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SET_BLOCKLEN; 2121 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2122 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2123 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2124 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2125 2126 errorstatus = CmdResp1Error ( SD_CMD_SET_BLOCKLEN ); 2127 2128 if ( errorstatus != SD_OK ) 2129 { 2130 return ( errorstatus ); 2131 } 2132 2133 /*!< CMD55 */ 2134 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t ) RCA << 16; 2135 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_APP_CMD; 2136 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2137 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2138 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2139 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2140 errorstatus = CmdResp1Error ( SD_CMD_APP_CMD ); 2141 2142 if ( errorstatus != SD_OK ) 2143 { 2144 return ( errorstatus ); 2145 } 2146 2147 SDIO_DataInitStructure.SDIO_DataTimeOut = SD_DATATIMEOUT; 2148 SDIO_DataInitStructure.SDIO_DataLength = 64; 2149 SDIO_DataInitStructure.SDIO_DataBlockSize = SDIO_DataBlockSize_64b; 2150 SDIO_DataInitStructure.SDIO_TransferDir = SDIO_TransferDir_ToSDIO; 2151 SDIO_DataInitStructure.SDIO_TransferMode = SDIO_TransferMode_Block; 2152 SDIO_DataInitStructure.SDIO_DPSM = SDIO_DPSM_Enable; 2153 SDIO_DataConfig ( & SDIO_DataInitStructure ); 2154 2155 /*!< Send ACMD13 SD_APP_STAUS with argument as card's RCA.*/ 2156 SDIO_CmdInitStructure.SDIO_Argument = 0; 2157 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SD_APP_STAUS; 2158 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2159 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2160 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2161 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2162 errorstatus = CmdResp1Error ( SD_CMD_SD_APP_STAUS ); 2163 2164 if ( errorstatus != SD_OK ) 2165 { 2166 return ( errorstatus ); 2167 } 2168 2169 while ( !( SDIO->STA & ( SDIO_FLAG_RXOVERR | SDIO_FLAG_DCRCFAIL | 2170 SDIO_FLAG_DTIMEOUT | SDIO_FLAG_DBCKEND | SDIO_FLAG_STBITERR ) ) ) 2171 { 2172 if ( SDIO_GetFlagStatus( SDIO_FLAG_RXFIFOHF ) != RESET ) 2173 { 2174 for ( count = 0; count < 8; count++ ) 2175 { 2176 *( psdstatus + count ) = SDIO_ReadData ( ); 2177 } 2178 psdstatus += 8; 2179 } 2180 } 2181 2182 if ( SDIO_GetFlagStatus( SDIO_FLAG_DTIMEOUT ) != RESET ) 2183 { 2184 SDIO_ClearFlag ( SDIO_FLAG_DTIMEOUT ); 2185 errorstatus = SD_DATA_TIMEOUT; 2186 return ( errorstatus ); 2187 } 2188 else if ( SDIO_GetFlagStatus( SDIO_FLAG_DCRCFAIL ) != RESET ) 2189 { 2190 SDIO_ClearFlag ( SDIO_FLAG_DCRCFAIL ); 2191 errorstatus = SD_DATA_CRC_FAIL; 2192 return ( errorstatus ); 2193 } 2194 else if ( SDIO_GetFlagStatus( SDIO_FLAG_RXOVERR ) != RESET ) 2195 { 2196 SDIO_ClearFlag ( SDIO_FLAG_RXOVERR ); 2197 errorstatus = SD_RX_OVERRUN; 2198 return ( errorstatus ); 2199 } 2200 else if ( SDIO_GetFlagStatus( SDIO_FLAG_STBITERR ) != RESET ) 2201 { 2202 SDIO_ClearFlag ( SDIO_FLAG_STBITERR ); 2203 errorstatus = SD_START_BIT_ERR; 2204 return ( errorstatus ); 2205 } 2206 2207 while ( SDIO_GetFlagStatus( SDIO_FLAG_RXDAVL ) != RESET ) 2208 { 2209 *psdstatus = SDIO_ReadData ( ); 2210 psdstatus++; 2211 } 2212 2213 /*!< Clear all the static status flags*/ 2214 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 2215 psdstatus -= 16; 2216 for ( count = 0; count < 16; count++ ) 2217 { 2218 psdstatus[ count ] = ( ( psdstatus[ count ] & SD_0TO7BITS ) << 24 ) | 2219 ( ( psdstatus[ count ] & SD_8TO15BITS ) << 8 ) | 2220 ( ( psdstatus[ count ] & SD_16TO23BITS ) >> 8 ) | 2221 ( ( psdstatus[ count ] & SD_24TO31BITS ) >> 24 ); 2222 } 2223 return ( errorstatus ); 2224 } 2225 2226 /** 2227 * @brief Allows to process all the interrupts that are high. 2228 * @param None 2229 * @retval SD_Error: SD Card Error code. 2230 */ 2231 SD_Error SD_ProcessIRQSrc ( void ) 2232 { 2233 uint32_t count = 0, restwords = 0; 2234 2235 if ( DeviceMode == SD_INTERRUPT_MODE ) 2236 { 2237 if ( SDIO_GetITStatus( SDIO_IT_RXFIFOHF ) != RESET ) 2238 { 2239 for ( count = 0; count < SD_HALFFIFO; count++ ) 2240 { 2241 *( DestBuffer + count ) = SDIO_ReadData ( ); 2242 } 2243 DestBuffer += SD_HALFFIFO; 2244 NumberOfBytes += SD_HALFFIFOBYTES; 2245 } 2246 else if ( SDIO_GetITStatus( SDIO_IT_TXFIFOHE ) != RESET ) 2247 { 2248 if ( ( TotalNumberOfBytes - NumberOfBytes ) < SD_HALFFIFOBYTES ) 2249 { 2250 restwords = ( ( TotalNumberOfBytes - NumberOfBytes ) % 4 == 0 ) ? 2251 ( ( TotalNumberOfBytes - NumberOfBytes ) / 4 ) : 2252 ( ( TotalNumberOfBytes - NumberOfBytes ) / 4 + 1 ); 2253 2254 for ( count = 0; count < restwords; count++, SrcBuffer++, 2255 NumberOfBytes += 4 ) 2256 { 2257 SDIO_WriteData ( * SrcBuffer ); 2258 } 2259 } 2260 else 2261 { 2262 for ( count = 0; count < SD_HALFFIFO; count++ ) 2263 { 2264 SDIO_WriteData ( * ( SrcBuffer + count ) ); 2265 } 2266 2267 SrcBuffer += SD_HALFFIFO; 2268 NumberOfBytes += SD_HALFFIFOBYTES; 2269 } 2270 } 2271 } 2272 2273 if ( SDIO_GetITStatus( SDIO_IT_DATAEND ) != RESET ) 2274 { 2275 if ( DeviceMode != SD_DMA_MODE ) 2276 { 2277 while ( ( SDIO_GetFlagStatus( SDIO_FLAG_RXDAVL ) != RESET ) && 2278 ( NumberOfBytes < TotalNumberOfBytes ) ) 2279 { 2280 *DestBuffer = SDIO_ReadData ( ); 2281 DestBuffer++; 2282 NumberOfBytes += 4; 2283 } 2284 } 2285 2286 if ( StopCondition == 1 ) 2287 { 2288 TransferError = SD_StopTransfer ( ); 2289 } 2290 else 2291 { 2292 TransferError = SD_OK; 2293 } 2294 SDIO_ClearITPendingBit ( SDIO_IT_DATAEND ); 2295 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 2296 SDIO_IT_TXFIFOHE | SDIO_IT_RXFIFOHF | SDIO_IT_TXUNDERR | SDIO_IT_RXOVERR | 2297 SDIO_IT_STBITERR, DISABLE ); 2298 TransferEnd = 1; 2299 NumberOfBytes = 0; 2300 return ( TransferError ); 2301 } 2302 2303 if ( SDIO_GetITStatus( SDIO_IT_DCRCFAIL ) != RESET ) 2304 { 2305 SDIO_ClearITPendingBit ( SDIO_IT_DCRCFAIL ); 2306 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 2307 SDIO_IT_TXFIFOHE | SDIO_IT_RXFIFOHF | SDIO_IT_TXUNDERR | SDIO_IT_RXOVERR | 2308 SDIO_IT_STBITERR, DISABLE ); 2309 NumberOfBytes = 0; 2310 TransferError = SD_DATA_CRC_FAIL; 2311 return ( SD_DATA_CRC_FAIL ); 2312 } 2313 2314 if ( SDIO_GetITStatus( SDIO_IT_DTIMEOUT ) != RESET ) 2315 { 2316 SDIO_ClearITPendingBit ( SDIO_IT_DTIMEOUT ); 2317 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 2318 SDIO_IT_TXFIFOHE | SDIO_IT_RXFIFOHF | SDIO_IT_TXUNDERR | SDIO_IT_RXOVERR | 2319 SDIO_IT_STBITERR, DISABLE ); 2320 NumberOfBytes = 0; 2321 TransferError = SD_DATA_TIMEOUT; 2322 return ( SD_DATA_TIMEOUT ); 2323 } 2324 2325 if ( SDIO_GetITStatus( SDIO_IT_RXOVERR ) != RESET ) 2326 { 2327 SDIO_ClearITPendingBit ( SDIO_IT_RXOVERR ); 2328 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 2329 SDIO_IT_TXFIFOHE | SDIO_IT_RXFIFOHF | SDIO_IT_TXUNDERR | SDIO_IT_RXOVERR | 2330 SDIO_IT_STBITERR, DISABLE ); 2331 NumberOfBytes = 0; 2332 TransferError = SD_RX_OVERRUN; 2333 return ( SD_RX_OVERRUN ); 2334 } 2335 2336 if ( SDIO_GetITStatus( SDIO_IT_TXUNDERR ) != RESET ) 2337 { 2338 SDIO_ClearITPendingBit ( SDIO_IT_TXUNDERR ); 2339 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 2340 SDIO_IT_TXFIFOHE | SDIO_IT_RXFIFOHF | SDIO_IT_TXUNDERR | SDIO_IT_RXOVERR | 2341 SDIO_IT_STBITERR, DISABLE ); 2342 NumberOfBytes = 0; 2343 TransferError = SD_TX_UNDERRUN; 2344 return ( SD_TX_UNDERRUN ); 2345 } 2346 2347 if ( SDIO_GetITStatus( SDIO_IT_STBITERR ) != RESET ) 2348 { 2349 SDIO_ClearITPendingBit ( SDIO_IT_STBITERR ); 2350 SDIO_ITConfig ( SDIO_IT_DCRCFAIL | SDIO_IT_DTIMEOUT | SDIO_IT_DATAEND | 2351 SDIO_IT_TXFIFOHE | SDIO_IT_RXFIFOHF | SDIO_IT_TXUNDERR | SDIO_IT_RXOVERR | 2352 SDIO_IT_STBITERR, DISABLE ); 2353 NumberOfBytes = 0; 2354 TransferError = SD_START_BIT_ERR; 2355 return ( SD_START_BIT_ERR ); 2356 } 2357 2358 return ( SD_OK ); 2359 } 2360 2361 /** 2362 * @brief Checks for error conditions for CMD0. 2363 * @param None 2364 * @retval SD_Error: SD Card Error code. 2365 */ 2366 static SD_Error CmdError ( void ) 2367 { 2368 SD_Error errorstatus = SD_OK; 2369 uint32_t timeout; 2370 2371 timeout = SDIO_CMD0TIMEOUT; /*!< 10000 */ 2372 2373 while ( ( timeout > 0 ) && ( SDIO_GetFlagStatus( SDIO_FLAG_CMDSENT ) 2374 == RESET ) ) 2375 { 2376 timeout--; 2377 } 2378 2379 if ( timeout == 0 ) 2380 { 2381 errorstatus = SD_CMD_RSP_TIMEOUT; 2382 return ( errorstatus ); 2383 } 2384 2385 /*!< Clear all the static flags */ 2386 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 2387 2388 return ( errorstatus ); 2389 } 2390 2391 /** 2392 * @brief Checks for error conditions for R7 response. 2393 * @param None 2394 * @retval SD_Error: SD Card Error code. 2395 */ 2396 static SD_Error CmdResp7Error ( void ) 2397 { 2398 SD_Error errorstatus = SD_OK; 2399 uint32_t status; 2400 uint32_t timeout = SDIO_CMD0TIMEOUT; 2401 2402 status = SDIO->STA; 2403 2404 while ( !( status & ( SDIO_FLAG_CCRCFAIL | SDIO_FLAG_CMDREND | 2405 SDIO_FLAG_CTIMEOUT ) ) && ( timeout > 0 ) ) 2406 { 2407 timeout--; 2408 status = SDIO->STA; 2409 } 2410 2411 if ( ( timeout == 0 ) || ( status & SDIO_FLAG_CTIMEOUT ) ) 2412 { 2413 /*!< Card is not V2.0 complient or card does not support the set voltage range */ 2414 errorstatus = SD_CMD_RSP_TIMEOUT; 2415 SDIO_ClearFlag ( SDIO_FLAG_CTIMEOUT ); 2416 return ( errorstatus ); 2417 } 2418 2419 if ( status & SDIO_FLAG_CMDREND ) 2420 { 2421 /*!< Card is SD V2.0 compliant */ 2422 errorstatus = SD_OK; 2423 SDIO_ClearFlag ( SDIO_FLAG_CMDREND ); 2424 return ( errorstatus ); 2425 } 2426 return ( errorstatus ); 2427 } 2428 2429 /** 2430 * @brief Checks for error conditions for R1 response. 2431 * @param cmd: The sent command index. 2432 * @retval SD_Error: SD Card Error code. 2433 */ 2434 static SD_Error CmdResp1Error ( uint8_t cmd ) 2435 { 2436 SD_Error errorstatus = SD_OK; 2437 uint32_t status; 2438 uint32_t response_r1; 2439 2440 status = SDIO->STA; 2441 2442 while ( !( status & ( SDIO_FLAG_CCRCFAIL | SDIO_FLAG_CMDREND | 2443 SDIO_FLAG_CTIMEOUT ) ) ) 2444 { 2445 status = SDIO->STA; 2446 } 2447 2448 if ( status & SDIO_FLAG_CTIMEOUT ) 2449 { 2450 errorstatus = SD_CMD_RSP_TIMEOUT; 2451 SDIO_ClearFlag ( SDIO_FLAG_CTIMEOUT ); 2452 return ( errorstatus ); 2453 } 2454 else if ( status & SDIO_FLAG_CCRCFAIL ) 2455 { 2456 errorstatus = SD_CMD_CRC_FAIL; 2457 SDIO_ClearFlag ( SDIO_FLAG_CCRCFAIL ); 2458 return ( errorstatus ); 2459 } 2460 2461 /*!< Check response received is of desired command */ 2462 if ( SDIO_GetCommandResponse( ) != cmd ) 2463 { 2464 errorstatus = SD_ILLEGAL_CMD; 2465 return ( errorstatus ); 2466 } 2467 2468 /*!< Clear all the static flags */ 2469 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 2470 2471 /*!< We have received response, retrieve it for analysis */ 2472 response_r1 = SDIO_GetResponse ( SDIO_RESP1 ); 2473 2474 if ( ( response_r1 & SD_OCR_ERRORBITS ) == SD_ALLZERO ) 2475 { 2476 return ( errorstatus ); 2477 } 2478 2479 if ( response_r1 & SD_OCR_ADDR_OUT_OF_RANGE ) 2480 { 2481 return ( SD_ADDR_OUT_OF_RANGE ); 2482 } 2483 2484 if ( response_r1 & SD_OCR_ADDR_MISALIGNED ) 2485 { 2486 return ( SD_ADDR_MISALIGNED ); 2487 } 2488 2489 if ( response_r1 & SD_OCR_BLOCK_LEN_ERR ) 2490 { 2491 return ( SD_BLOCK_LEN_ERR ); 2492 } 2493 2494 if ( response_r1 & SD_OCR_ERASE_SEQ_ERR ) 2495 { 2496 return ( SD_ERASE_SEQ_ERR ); 2497 } 2498 2499 if ( response_r1 & SD_OCR_BAD_ERASE_PARAM ) 2500 { 2501 return ( SD_BAD_ERASE_PARAM ); 2502 } 2503 2504 if ( response_r1 & SD_OCR_WRITE_PROT_VIOLATION ) 2505 { 2506 return ( SD_WRITE_PROT_VIOLATION ); 2507 } 2508 2509 if ( response_r1 & SD_OCR_LOCK_UNLOCK_FAILED ) 2510 { 2511 return ( SD_LOCK_UNLOCK_FAILED ); 2512 } 2513 2514 if ( response_r1 & SD_OCR_COM_CRC_FAILED ) 2515 { 2516 return ( SD_COM_CRC_FAILED ); 2517 } 2518 2519 if ( response_r1 & SD_OCR_ILLEGAL_CMD ) 2520 { 2521 return ( SD_ILLEGAL_CMD ); 2522 } 2523 2524 if ( response_r1 & SD_OCR_CARD_ECC_FAILED ) 2525 { 2526 return ( SD_CARD_ECC_FAILED ); 2527 } 2528 2529 if ( response_r1 & SD_OCR_CC_ERROR ) 2530 { 2531 return ( SD_CC_ERROR ); 2532 } 2533 2534 if ( response_r1 & SD_OCR_GENERAL_UNKNOWN_ERROR ) 2535 { 2536 return ( SD_GENERAL_UNKNOWN_ERROR ); 2537 } 2538 2539 if ( response_r1 & SD_OCR_STREAM_READ_UNDERRUN ) 2540 { 2541 return ( SD_STREAM_READ_UNDERRUN ); 2542 } 2543 2544 if ( response_r1 & SD_OCR_STREAM_WRITE_OVERRUN ) 2545 { 2546 return ( SD_STREAM_WRITE_OVERRUN ); 2547 } 2548 2549 if ( response_r1 & SD_OCR_CID_CSD_OVERWRIETE ) 2550 { 2551 return ( SD_CID_CSD_OVERWRITE ); 2552 } 2553 2554 if ( response_r1 & SD_OCR_WP_ERASE_SKIP ) 2555 { 2556 return ( SD_WP_ERASE_SKIP ); 2557 } 2558 2559 if ( response_r1 & SD_OCR_CARD_ECC_DISABLED ) 2560 { 2561 return ( SD_CARD_ECC_DISABLED ); 2562 } 2563 2564 if ( response_r1 & SD_OCR_ERASE_RESET ) 2565 { 2566 return ( SD_ERASE_RESET ); 2567 } 2568 2569 if ( response_r1 & SD_OCR_AKE_SEQ_ERROR ) 2570 { 2571 return ( SD_AKE_SEQ_ERROR ); 2572 } 2573 return ( errorstatus ); 2574 } 2575 2576 /** 2577 * @brief Checks for error conditions for R3 (OCR) response. 2578 * @param None 2579 * @retval SD_Error: SD Card Error code. 2580 */ 2581 static SD_Error CmdResp3Error ( void ) 2582 { 2583 SD_Error errorstatus = SD_OK; 2584 uint32_t status; 2585 2586 status = SDIO->STA; 2587 2588 while ( !( status & ( SDIO_FLAG_CCRCFAIL | SDIO_FLAG_CMDREND | 2589 SDIO_FLAG_CTIMEOUT ) ) ) 2590 { 2591 status = SDIO->STA; 2592 } 2593 2594 if ( status & SDIO_FLAG_CTIMEOUT ) 2595 { 2596 errorstatus = SD_CMD_RSP_TIMEOUT; 2597 SDIO_ClearFlag ( SDIO_FLAG_CTIMEOUT ); 2598 return ( errorstatus ); 2599 } 2600 /*!< Clear all the static flags */ 2601 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 2602 return ( errorstatus ); 2603 } 2604 2605 /** 2606 * @brief Checks for error conditions for R2 (CID or CSD) response. 2607 * @param None 2608 * @retval SD_Error: SD Card Error code. 2609 */ 2610 static SD_Error CmdResp2Error ( void ) 2611 { 2612 SD_Error errorstatus = SD_OK; 2613 uint32_t status; 2614 2615 status = SDIO->STA; 2616 2617 while ( !( status & ( SDIO_FLAG_CCRCFAIL | SDIO_FLAG_CTIMEOUT | 2618 SDIO_FLAG_CMDREND ) ) ) 2619 { 2620 status = SDIO->STA; 2621 } 2622 2623 if ( status & SDIO_FLAG_CTIMEOUT ) 2624 { 2625 errorstatus = SD_CMD_RSP_TIMEOUT; 2626 SDIO_ClearFlag ( SDIO_FLAG_CTIMEOUT ); 2627 return ( errorstatus ); 2628 } 2629 else if ( status & SDIO_FLAG_CCRCFAIL ) 2630 { 2631 errorstatus = SD_CMD_CRC_FAIL; 2632 SDIO_ClearFlag ( SDIO_FLAG_CCRCFAIL ); 2633 return ( errorstatus ); 2634 } 2635 2636 /*!< Clear all the static flags */ 2637 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 2638 2639 return ( errorstatus ); 2640 } 2641 2642 /** 2643 * @brief Checks for error conditions for R6 (RCA) response. 2644 * @param cmd: The sent command index. 2645 * @param prca: pointer to the variable that will contain the SD card relative 2646 * address RCA. 2647 * @retval SD_Error: SD Card Error code. 2648 */ 2649 static SD_Error CmdResp6Error ( uint8_t cmd, uint16_t * prca ) 2650 { 2651 SD_Error errorstatus = SD_OK; 2652 uint32_t status; 2653 uint32_t response_r1; 2654 2655 status = SDIO->STA; 2656 2657 while ( !( status & ( SDIO_FLAG_CCRCFAIL | SDIO_FLAG_CTIMEOUT | 2658 SDIO_FLAG_CMDREND ) ) ) 2659 { 2660 status = SDIO->STA; 2661 } 2662 2663 if ( status & SDIO_FLAG_CTIMEOUT ) 2664 { 2665 errorstatus = SD_CMD_RSP_TIMEOUT; 2666 SDIO_ClearFlag ( SDIO_FLAG_CTIMEOUT ); 2667 return ( errorstatus ); 2668 } 2669 else if ( status & SDIO_FLAG_CCRCFAIL ) 2670 { 2671 errorstatus = SD_CMD_CRC_FAIL; 2672 SDIO_ClearFlag ( SDIO_FLAG_CCRCFAIL ); 2673 return ( errorstatus ); 2674 } 2675 2676 /*!< Check response received is of desired command */ 2677 if ( SDIO_GetCommandResponse( ) != cmd ) 2678 { 2679 errorstatus = SD_ILLEGAL_CMD; 2680 return ( errorstatus ); 2681 } 2682 2683 /*!< Clear all the static flags */ 2684 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 2685 2686 /*!< We have received response, retrieve it. */ 2687 response_r1 = SDIO_GetResponse ( SDIO_RESP1 ); 2688 2689 if ( SD_ALLZERO == ( response_r1 & 2690 ( SD_R6_GENERAL_UNKNOWN_ERROR | SD_R6_ILLEGAL_CMD | 2691 SD_R6_COM_CRC_FAILED ) ) ) 2692 { 2693 *prca = ( uint16_t )( response_r1 >> 16 ); 2694 return ( errorstatus ); 2695 } 2696 2697 if ( response_r1 & SD_R6_GENERAL_UNKNOWN_ERROR ) 2698 { 2699 return ( SD_GENERAL_UNKNOWN_ERROR ); 2700 } 2701 2702 if ( response_r1 & SD_R6_ILLEGAL_CMD ) 2703 { 2704 return ( SD_ILLEGAL_CMD ); 2705 } 2706 2707 if ( response_r1 & SD_R6_COM_CRC_FAILED ) 2708 { 2709 return ( SD_COM_CRC_FAILED ); 2710 } 2711 2712 return ( errorstatus ); 2713 } 2714 2715 /** 2716 * @brief Enables or disables the SDIO wide bus mode. 2717 * @param NewState: new state of the SDIO wide bus mode. 2718 * This parameter can be: ENABLE or DISABLE. 2719 * @retval SD_Error: SD Card Error code. 2720 */ 2721 static SD_Error SDEnWideBus ( FunctionalState NewState ) 2722 { 2723 SD_Error errorstatus = SD_OK; 2724 2725 uint32_t scr[ 2 ] = 2726 { 2727 0, 2728 0 2729 } ; 2730 2731 if ( SDIO_GetResponse( SDIO_RESP1 ) & SD_CARD_LOCKED ) 2732 { 2733 errorstatus = SD_LOCK_UNLOCK_FAILED; 2734 return ( errorstatus ); 2735 } 2736 2737 /*!< Get SCR Register */ 2738 errorstatus = FindSCR ( RCA, scr ); 2739 2740 if ( errorstatus != SD_OK ) 2741 { 2742 return ( errorstatus ); 2743 } 2744 2745 /*!< If wide bus operation to be enabled */ 2746 if ( NewState == ENABLE ) 2747 { 2748 /*!< If requested card supports wide bus operation */ 2749 if ( ( scr[ 1 ] & SD_WIDE_BUS_SUPPORT ) != SD_ALLZERO ) 2750 { 2751 /*!< Send CMD55 APP_CMD with argument as card's RCA.*/ 2752 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t ) RCA << 16; 2753 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_APP_CMD; 2754 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2755 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2756 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2757 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2758 2759 errorstatus = CmdResp1Error ( SD_CMD_APP_CMD ); 2760 2761 if ( errorstatus != SD_OK ) 2762 { 2763 return ( errorstatus ); 2764 } 2765 2766 /*!< Send ACMD6 APP_CMD with argument as 2 for wide bus mode */ 2767 SDIO_CmdInitStructure.SDIO_Argument = 0x2; 2768 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_APP_SD_SET_BUSWIDTH; 2769 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2770 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2771 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2772 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2773 2774 errorstatus = CmdResp1Error ( SD_CMD_APP_SD_SET_BUSWIDTH ); 2775 2776 if ( errorstatus != SD_OK ) 2777 { 2778 return ( errorstatus ); 2779 } 2780 return ( errorstatus ); 2781 } 2782 else 2783 { 2784 errorstatus = SD_REQUEST_NOT_APPLICABLE; 2785 return ( errorstatus ); 2786 } 2787 } /*!< If wide bus operation to be disabled */ 2788 else 2789 { 2790 /*!< If requested card supports 1 bit mode operation */ 2791 if ( ( scr[ 1 ] & SD_SINGLE_BUS_SUPPORT ) != SD_ALLZERO ) 2792 { 2793 /*!< Send CMD55 APP_CMD with argument as card's RCA.*/ 2794 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t ) RCA << 16; 2795 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_APP_CMD; 2796 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2797 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2798 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2799 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2800 2801 errorstatus = CmdResp1Error ( SD_CMD_APP_CMD ); 2802 2803 if ( errorstatus != SD_OK ) 2804 { 2805 return ( errorstatus ); 2806 } 2807 2808 /*!< Send ACMD6 APP_CMD with argument as 2 for wide bus mode */ 2809 SDIO_CmdInitStructure.SDIO_Argument = 0x00; 2810 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_APP_SD_SET_BUSWIDTH; 2811 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2812 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2813 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2814 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2815 2816 errorstatus = CmdResp1Error ( SD_CMD_APP_SD_SET_BUSWIDTH ); 2817 2818 if ( errorstatus != SD_OK ) 2819 { 2820 return ( errorstatus ); 2821 } 2822 2823 return ( errorstatus ); 2824 } 2825 else 2826 { 2827 errorstatus = SD_REQUEST_NOT_APPLICABLE; 2828 return ( errorstatus ); 2829 } 2830 } 2831 } 2832 2833 /** 2834 * @brief Checks if the SD card is in programming state. 2835 * @param pstatus: pointer to the variable that will contain the SD card state. 2836 * @retval SD_Error: SD Card Error code. 2837 */ 2838 static SD_Error IsCardProgramming ( uint8_t * pstatus ) 2839 { 2840 SD_Error errorstatus = SD_OK; 2841 __IO uint32_t respR1 = 0, status = 0; 2842 2843 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t ) RCA << 16; 2844 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SEND_STATUS; 2845 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 2846 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 2847 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 2848 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 2849 2850 status = SDIO->STA; 2851 while ( !( status & ( SDIO_FLAG_CCRCFAIL | SDIO_FLAG_CMDREND | 2852 SDIO_FLAG_CTIMEOUT ) ) ) 2853 { 2854 status = SDIO->STA; 2855 } 2856 2857 if ( status & SDIO_FLAG_CTIMEOUT ) 2858 { 2859 errorstatus = SD_CMD_RSP_TIMEOUT; 2860 SDIO_ClearFlag ( SDIO_FLAG_CTIMEOUT ); 2861 return ( errorstatus ); 2862 } 2863 else if ( status & SDIO_FLAG_CCRCFAIL ) 2864 { 2865 errorstatus = SD_CMD_CRC_FAIL; 2866 SDIO_ClearFlag ( SDIO_FLAG_CCRCFAIL ); 2867 return ( errorstatus ); 2868 } 2869 2870 status = ( uint32_t )SDIO_GetCommandResponse ( ); 2871 2872 /*!< Check response received is of desired command */ 2873 if ( status != SD_CMD_SEND_STATUS ) 2874 { 2875 errorstatus = SD_ILLEGAL_CMD; 2876 return ( errorstatus ); 2877 } 2878 2879 /*!< Clear all the static flags */ 2880 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 2881 2882 /*!< We have received response, retrieve it for analysis */ 2883 respR1 = SDIO_GetResponse ( SDIO_RESP1 ); 2884 2885 /*!< Find out card status */ 2886 *pstatus = ( uint8_t )( ( respR1 >> 9 ) & 0x0000000F ); 2887 2888 if ( ( respR1 & SD_OCR_ERRORBITS ) == SD_ALLZERO ) 2889 { 2890 return ( errorstatus ); 2891 } 2892 2893 if ( respR1 & SD_OCR_ADDR_OUT_OF_RANGE ) 2894 { 2895 return ( SD_ADDR_OUT_OF_RANGE ); 2896 } 2897 2898 if ( respR1 & SD_OCR_ADDR_MISALIGNED ) 2899 { 2900 return ( SD_ADDR_MISALIGNED ); 2901 } 2902 2903 if ( respR1 & SD_OCR_BLOCK_LEN_ERR ) 2904 { 2905 return ( SD_BLOCK_LEN_ERR ); 2906 } 2907 2908 if ( respR1 & SD_OCR_ERASE_SEQ_ERR ) 2909 { 2910 return ( SD_ERASE_SEQ_ERR ); 2911 } 2912 2913 if ( respR1 & SD_OCR_BAD_ERASE_PARAM ) 2914 { 2915 return ( SD_BAD_ERASE_PARAM ); 2916 } 2917 2918 if ( respR1 & SD_OCR_WRITE_PROT_VIOLATION ) 2919 { 2920 return ( SD_WRITE_PROT_VIOLATION ); 2921 } 2922 2923 if ( respR1 & SD_OCR_LOCK_UNLOCK_FAILED ) 2924 { 2925 return ( SD_LOCK_UNLOCK_FAILED ); 2926 } 2927 2928 if ( respR1 & SD_OCR_COM_CRC_FAILED ) 2929 { 2930 return ( SD_COM_CRC_FAILED ); 2931 } 2932 2933 if ( respR1 & SD_OCR_ILLEGAL_CMD ) 2934 { 2935 return ( SD_ILLEGAL_CMD ); 2936 } 2937 2938 if ( respR1 & SD_OCR_CARD_ECC_FAILED ) 2939 { 2940 return ( SD_CARD_ECC_FAILED ); 2941 } 2942 2943 if ( respR1 & SD_OCR_CC_ERROR ) 2944 { 2945 return ( SD_CC_ERROR ); 2946 } 2947 2948 if ( respR1 & SD_OCR_GENERAL_UNKNOWN_ERROR ) 2949 { 2950 return ( SD_GENERAL_UNKNOWN_ERROR ); 2951 } 2952 2953 if ( respR1 & SD_OCR_STREAM_READ_UNDERRUN ) 2954 { 2955 return ( SD_STREAM_READ_UNDERRUN ); 2956 } 2957 2958 if ( respR1 & SD_OCR_STREAM_WRITE_OVERRUN ) 2959 { 2960 return ( SD_STREAM_WRITE_OVERRUN ); 2961 } 2962 2963 if ( respR1 & SD_OCR_CID_CSD_OVERWRIETE ) 2964 { 2965 return ( SD_CID_CSD_OVERWRITE ); 2966 } 2967 2968 if ( respR1 & SD_OCR_WP_ERASE_SKIP ) 2969 { 2970 return ( SD_WP_ERASE_SKIP ); 2971 } 2972 2973 if ( respR1 & SD_OCR_CARD_ECC_DISABLED ) 2974 { 2975 return ( SD_CARD_ECC_DISABLED ); 2976 } 2977 2978 if ( respR1 & SD_OCR_ERASE_RESET ) 2979 { 2980 return ( SD_ERASE_RESET ); 2981 } 2982 2983 if ( respR1 & SD_OCR_AKE_SEQ_ERROR ) 2984 { 2985 return ( SD_AKE_SEQ_ERROR ); 2986 } 2987 2988 return ( errorstatus ); 2989 } 2990 2991 /** 2992 * @brief Find the SD card SCR register value. 2993 * @param rca: selected card address. 2994 * @param pscr: pointer to the buffer that will contain the SCR value. 2995 * @retval SD_Error: SD Card Error code. 2996 */ 2997 static SD_Error FindSCR ( uint16_t rca, uint32_t * pscr ) 2998 { 2999 uint32_t index = 0; 3000 SD_Error errorstatus = SD_OK; 3001 uint32_t tempscr[ 2 ] = 3002 { 3003 0, 3004 0 3005 } ; 3006 3007 /*!< Set Block Size To 8 Bytes */ 3008 /*!< Send CMD55 APP_CMD with argument as card's RCA */ 3009 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t )8; 3010 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SET_BLOCKLEN; 3011 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 3012 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 3013 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 3014 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 3015 3016 errorstatus = CmdResp1Error ( SD_CMD_SET_BLOCKLEN ); 3017 3018 if ( errorstatus != SD_OK ) 3019 { 3020 return ( errorstatus ); 3021 } 3022 3023 /*!< Send CMD55 APP_CMD with argument as card's RCA */ 3024 SDIO_CmdInitStructure.SDIO_Argument = ( uint32_t ) RCA << 16; 3025 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_APP_CMD; 3026 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 3027 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 3028 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 3029 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 3030 3031 errorstatus = CmdResp1Error ( SD_CMD_APP_CMD ); 3032 3033 if ( errorstatus != SD_OK ) 3034 { 3035 return ( errorstatus ); 3036 } 3037 SDIO_DataInitStructure.SDIO_DataTimeOut = SD_DATATIMEOUT; 3038 SDIO_DataInitStructure.SDIO_DataLength = 8; 3039 SDIO_DataInitStructure.SDIO_DataBlockSize = SDIO_DataBlockSize_8b; 3040 SDIO_DataInitStructure.SDIO_TransferDir = SDIO_TransferDir_ToSDIO; 3041 SDIO_DataInitStructure.SDIO_TransferMode = SDIO_TransferMode_Block; 3042 SDIO_DataInitStructure.SDIO_DPSM = SDIO_DPSM_Enable; 3043 SDIO_DataConfig ( & SDIO_DataInitStructure ); 3044 3045 /*!< Send ACMD51 SD_APP_SEND_SCR with argument as 0 */ 3046 SDIO_CmdInitStructure.SDIO_Argument = 0x0; 3047 SDIO_CmdInitStructure.SDIO_CmdIndex = SD_CMD_SD_APP_SEND_SCR; 3048 SDIO_CmdInitStructure.SDIO_Response = SDIO_Response_Short; 3049 SDIO_CmdInitStructure.SDIO_Wait = SDIO_Wait_No; 3050 SDIO_CmdInitStructure.SDIO_CPSM = SDIO_CPSM_Enable; 3051 SDIO_SendCommand ( & SDIO_CmdInitStructure ); 3052 3053 errorstatus = CmdResp1Error ( SD_CMD_SD_APP_SEND_SCR ); 3054 3055 if ( errorstatus != SD_OK ) 3056 { 3057 return ( errorstatus ); 3058 } 3059 3060 while ( !( SDIO->STA & ( SDIO_FLAG_RXOVERR | SDIO_FLAG_DCRCFAIL | 3061 SDIO_FLAG_DTIMEOUT | SDIO_FLAG_DBCKEND | SDIO_FLAG_STBITERR ) ) ) 3062 { 3063 if ( SDIO_GetFlagStatus( SDIO_FLAG_RXDAVL ) != RESET ) 3064 { 3065 *( tempscr + index ) = SDIO_ReadData ( ); 3066 index++; 3067 } 3068 } 3069 3070 if ( SDIO_GetFlagStatus( SDIO_FLAG_DTIMEOUT ) != RESET ) 3071 { 3072 SDIO_ClearFlag ( SDIO_FLAG_DTIMEOUT ); 3073 errorstatus = SD_DATA_TIMEOUT; 3074 return ( errorstatus ); 3075 } 3076 else if ( SDIO_GetFlagStatus( SDIO_FLAG_DCRCFAIL ) != RESET ) 3077 { 3078 SDIO_ClearFlag ( SDIO_FLAG_DCRCFAIL ); 3079 errorstatus = SD_DATA_CRC_FAIL; 3080 return ( errorstatus ); 3081 } 3082 else if ( SDIO_GetFlagStatus( SDIO_FLAG_RXOVERR ) != RESET ) 3083 { 3084 SDIO_ClearFlag ( SDIO_FLAG_RXOVERR ); 3085 errorstatus = SD_RX_OVERRUN; 3086 return ( errorstatus ); 3087 } 3088 else if ( SDIO_GetFlagStatus( SDIO_FLAG_STBITERR ) != RESET ) 3089 { 3090 SDIO_ClearFlag ( SDIO_FLAG_STBITERR ); 3091 errorstatus = SD_START_BIT_ERR; 3092 return ( errorstatus ); 3093 } 3094 3095 /*!< Clear all the static flags */ 3096 SDIO_ClearFlag ( SDIO_STATIC_FLAGS ); 3097 3098 *( pscr + 1 ) = ( ( tempscr[ 0 ] & SD_0TO7BITS ) << 24 ) | 3099 ( ( tempscr[ 0 ] & SD_8TO15BITS ) << 8 ) | 3100 ( ( tempscr[ 0 ] & SD_16TO23BITS ) >> 8 ) | 3101 ( ( tempscr[ 0 ] & SD_24TO31BITS ) >> 24 ); 3102 3103 *( pscr ) = ( ( tempscr[ 1 ] & SD_0TO7BITS ) << 24 ) | 3104 ( ( tempscr[ 1 ] & SD_8TO15BITS ) << 8 ) | 3105 ( ( tempscr[ 1 ] & SD_16TO23BITS ) >> 8 ) | 3106 ( ( tempscr[ 1 ] & SD_24TO31BITS ) >> 24 ); 3107 3108 return ( errorstatus ); 3109 } 3110 3111 /** 3112 * @brief Converts the number of bytes in power of two and returns the power. 3113 * @param NumberOfBytes: number of bytes. 3114 * @retval None 3115 */ 3116 static uint8_t convert_from_bytes_to_power_of_two ( uint16_t NumberOfBytes ) 3117 { 3118 uint8_t count = 0; 3119 3120 while ( NumberOfBytes != 1 ) 3121 { 3122 NumberOfBytes >>= 1; 3123 count++; 3124 } 3125 return ( count ); 3126 } 3127 3128 /** 3129 * @} 3130 */ 3131 3132 /** 3133 * @} 3134 */ 3135 3136 /** 3137 * @} 3138 */ 3139 3140 /** 3141 * @} 3142 */ 3143 3144 /** 3145 * @} 3146 */ 3147 3148 /******************* (C) COPYRIGHT 2010 STMicroelectronics *****END OF FILE****/
1 /****************************************Copyright (c)**************************************************** 2 ** 3 ** http://www.powermcu.com 4 ** 5 **--------------File Info--------------------------------------------------------------------------------- 6 ** File name: sdio_sd.h 7 ** Descriptions: sdio sd卡操作头文件 8 ** 9 **-------------------------------------------------------------------------------------------------------- 10 ** Created by: AVRman 11 ** Created date: 2010-10-30 12 ** Version: v1.0 13 ** Descriptions: The original version 14 ** 15 **-------------------------------------------------------------------------------------------------------- 16 ** Modified by: 17 ** Modified date: 18 ** Version: 19 ** Descriptions: 20 ** 21 *********************************************************************************************************/ 22 23 /* Define to prevent recursive inclusion -------------------------------------*/ 24 #ifndef __SDIO_SD_H 25 #define __SDIO_SD_H 26 27 #ifdef __cplusplus 28 extern "C" 29 { 30 #endif 31 32 /* Includes ------------------------------------------------------------------*/ 33 #include "stm32f10x.h" 34 35 typedef enum 36 { 37 /** 38 * @brief SDIO specific error defines 39 */ 40 SD_CMD_CRC_FAIL = ( 1 ), 41 /*!< Command response received (but CRC check failed) */ 42 SD_DATA_CRC_FAIL = ( 2 ), 43 /*!< Data bock sent/received (CRC check Failed) */ 44 SD_CMD_RSP_TIMEOUT = ( 3 ), /*!< Command response timeout */ 45 SD_DATA_TIMEOUT = ( 4 ), /*!< Data time out */ 46 SD_TX_UNDERRUN = ( 5 ), /*!< Transmit FIFO under-run */ 47 SD_RX_OVERRUN = ( 6 ), /*!< Receive FIFO over-run */ 48 SD_START_BIT_ERR = ( 7 ), 49 /*!< Start bit not detected on all data signals in widE bus mode */ 50 SD_CMD_OUT_OF_RANGE = ( 8 ), /*!< CMD's argument was out of range.*/ 51 SD_ADDR_MISALIGNED = ( 9 ), /*!< Misaligned address */ 52 SD_BLOCK_LEN_ERR = ( 10 ), 53 /*!< Transferred block length is not allowed for the card or the number of transferred bytes does not match the block length */ 54 SD_ERASE_SEQ_ERR = ( 11 ), 55 /*!< An error in the sequence of erase command occurs.*/ 56 SD_BAD_ERASE_PARAM = ( 12 ), /*!< An Invalid selection for erase groups */ 57 SD_WRITE_PROT_VIOLATION = ( 13 ), 58 /*!< Attempt to program a write protect block */ 59 SD_LOCK_UNLOCK_FAILED = ( 14 ), 60 /*!< Sequence or password error has been detected in unlock command or if there was an attempt to access a locked card */ 61 SD_COM_CRC_FAILED = ( 15 ), 62 /*!< CRC check of the previous command failed */ 63 SD_ILLEGAL_CMD = ( 16 ), /*!< Command is not legal for the card state */ 64 SD_CARD_ECC_FAILED = ( 17 ), 65 /*!< Card internal ECC was applied but failed to correct the data */ 66 SD_CC_ERROR = ( 18 ), /*!< Internal card controller error */ 67 SD_GENERAL_UNKNOWN_ERROR = ( 19 ), /*!< General or Unknown error */ 68 SD_STREAM_READ_UNDERRUN = ( 20 ), 69 /*!< The card could not sustain data transfer in stream read operation. */ 70 SD_STREAM_WRITE_OVERRUN = ( 21 ), 71 /*!< The card could not sustain data programming in stream mode */ 72 SD_CID_CSD_OVERWRITE = ( 22 ), /*!< CID/CSD overwrite error */ 73 SD_WP_ERASE_SKIP = ( 23 ), /*!< only partial address space was erased */ 74 SD_CARD_ECC_DISABLED = ( 24 ), 75 /*!< Command has been executed without using internal ECC */ 76 SD_ERASE_RESET = ( 25 ), 77 /*!< Erase sequence was cleared before executing because an out of erase sequence command was received */ 78 SD_AKE_SEQ_ERROR = ( 26 ), /*!< Error in sequence of authentication. */ 79 SD_INVALID_VOLTRANGE = ( 27 ), SD_ADDR_OUT_OF_RANGE = ( 28 ), 80 SD_SWITCH_ERROR = ( 29 ), SD_SDIO_DISABLED = ( 30 ), SD_SDIO_FUNCTION_BUSY = 81 ( 31 ), SD_SDIO_FUNCTION_FAILED = ( 32 ), 82 SD_SDIO_UNKNOWN_FUNCTION = ( 33 ), 83 84 /** 85 * @brief Standard error defines 86 */ 87 SD_INTERNAL_ERROR, SD_NOT_CONFIGURED, SD_REQUEST_PENDING, 88 SD_REQUEST_NOT_APPLICABLE, SD_INVALID_PARAMETER, SD_UNSUPPORTED_FEATURE, 89 SD_UNSUPPORTED_HW, SD_ERROR, SD_OK 90 } SD_Error; 91 92 /** 93 * @brief SDIO Transfer state 94 */ 95 typedef enum 96 { 97 SD_TRANSFER_OK = 0, SD_TRANSFER_BUSY = 1, SD_TRANSFER_ERROR 98 } SDTransferState; 99 100 /** 101 * @brief SD Card States 102 */ 103 typedef enum 104 { 105 SD_CARD_READY = ( ( uint32_t )0x00000001 ), SD_CARD_IDENTIFICATION = 106 ( ( uint32_t )0x00000002 ), SD_CARD_STANDBY = ( ( uint32_t )0x00000003 ), 107 SD_CARD_TRANSFER = ( ( uint32_t )0x00000004 ), SD_CARD_SENDING = 108 ( ( uint32_t )0x00000005 ), SD_CARD_RECEIVING = 109 ( ( uint32_t )0x00000006 ), SD_CARD_PROGRAMMING = 110 ( ( uint32_t )0x00000007 ), SD_CARD_DISCONNECTED = 111 ( ( uint32_t )0x00000008 ), SD_CARD_ERROR = ( ( uint32_t )0x000000FF ) 112 } SDCardState; 113 114 /** 115 * @brief Card Specific Data: CSD Register 116 */ 117 typedef struct 118 { 119 __IO uint8_t CSDStruct; /*!< CSD structure */ 120 __IO uint8_t SysSpecVersion; /*!< System specification version */ 121 __IO uint8_t Reserved1; /*!< Reserved */ 122 __IO uint8_t TAAC; /*!< Data read access-time 1 */ 123 __IO uint8_t NSAC; /*!< Data read access-time 2 in CLK cycles */ 124 __IO uint8_t MaxBusClkFrec; /*!< Max. bus clock frequency */ 125 __IO uint16_t CardComdClasses; /*!< Card command classes */ 126 __IO uint8_t RdBlockLen; /*!< Max. read data block length */ 127 __IO uint8_t PartBlockRead; /*!< Partial blocks for read allowed */ 128 __IO uint8_t WrBlockMisalign; /*!< Write block misalignment */ 129 __IO uint8_t RdBlockMisalign; /*!< Read block misalignment */ 130 __IO uint8_t DSRImpl; /*!< DSR implemented */ 131 __IO uint8_t Reserved2; /*!< Reserved */ 132 __IO uint32_t DeviceSize; /*!< Device Size */ 133 __IO uint8_t MaxRdCurrentVDDMin; /*!< Max. read current @ VDD min */ 134 __IO uint8_t MaxRdCurrentVDDMax; /*!< Max. read current @ VDD max */ 135 __IO uint8_t MaxWrCurrentVDDMin; /*!< Max. write current @ VDD min */ 136 __IO uint8_t MaxWrCurrentVDDMax; /*!< Max. write current @ VDD max */ 137 __IO uint8_t DeviceSizeMul; /*!< Device size multiplier */ 138 __IO uint8_t EraseGrSize; /*!< Erase group size */ 139 __IO uint8_t EraseGrMul; /*!< Erase group size multiplier */ 140 __IO uint8_t WrProtectGrSize; /*!< Write protect group size */ 141 __IO uint8_t WrProtectGrEnable; /*!< Write protect group enable */ 142 __IO uint8_t ManDeflECC; /*!< Manufacturer default ECC */ 143 __IO uint8_t WrSpeedFact; /*!< Write speed factor */ 144 __IO uint8_t MaxWrBlockLen; /*!< Max. write data block length */ 145 __IO uint8_t WriteBlockPaPartial; /*!< Partial blocks for write allowed */ 146 __IO uint8_t Reserved3; /*!< Reserded */ 147 __IO uint8_t ContentProtectAppli; /*!< Content protection application */ 148 __IO uint8_t FileFormatGrouop; /*!< File format group */ 149 __IO uint8_t CopyFlag; /*!< Copy flag (OTP) */ 150 __IO uint8_t PermWrProtect; /*!< Permanent write protection */ 151 __IO uint8_t TempWrProtect; /*!< Temporary write protection */ 152 __IO uint8_t FileFormat; /*!< File Format */ 153 __IO uint8_t ECC; /*!< ECC code */ 154 __IO uint8_t CSD_CRC; /*!< CSD CRC */ 155 __IO uint8_t Reserved4; /*!< always 1*/ 156 } SD_CSD; 157 158 /** 159 * @brief Card Identification Data: CID Register 160 */ 161 typedef struct 162 { 163 __IO uint8_t ManufacturerID; /*!< ManufacturerID */ 164 __IO uint16_t OEM_AppliID; /*!< OEM/Application ID */ 165 __IO uint32_t ProdName1; /*!< Product Name part1 */ 166 __IO uint8_t ProdName2; /*!< Product Name part2*/ 167 __IO uint8_t ProdRev; /*!< Product Revision */ 168 __IO uint32_t ProdSN; /*!< Product Serial Number */ 169 __IO uint8_t Reserved1; /*!< Reserved1 */ 170 __IO uint16_t ManufactDate; /*!< Manufacturing Date */ 171 __IO uint8_t CID_CRC; /*!< CID CRC */ 172 __IO uint8_t Reserved2; /*!< always 1 */ 173 } SD_CID; 174 175 /** 176 * @brief SD Card information 177 */ 178 typedef struct 179 { 180 SD_CSD SD_csd; 181 SD_CID SD_cid; 182 uint32_t CardCapacity; /*!< Card Capacity */ 183 uint32_t CardBlockSize; /*!< Card Block Size */ 184 uint16_t RCA; 185 uint8_t CardType; 186 } SD_CardInfo; 187 188 /** 189 * @brief SDIO Data Transfer Frequency (25MHz max) 190 */ 191 #define SDIO_TRANSFER_CLK_DIV ((uint8_t)0x1) 192 193 #define SD_DETECT_PIN GPIO_Pin_14 /* PB.14 */ 194 #define SD_DETECT_GPIO_PORT GPIOB /* GPIOB */ 195 #define SD_DETECT_GPIO_CLK RCC_APB2Periph_GPIOB 196 197 /** 198 * @brief SDIO Intialization Frequency (400KHz max) 199 */ 200 #define SDIO_INIT_CLK_DIV ((uint8_t)0xB2) 201 #define SDIO_FIFO_ADDRESS ((uint32_t)0x40018080) 202 203 /** 204 * @brief SDIO Commands Index 205 */ 206 #define SD_CMD_GO_IDLE_STATE ((uint8_t)0) 207 #define SD_CMD_SEND_OP_COND ((uint8_t)1) 208 #define SD_CMD_ALL_SEND_CID ((uint8_t)2) 209 #define SD_CMD_SET_REL_ADDR ((uint8_t)3) /*!< SDIO_SEND_REL_ADDR for SD Card */ 210 #define SD_CMD_SET_DSR ((uint8_t)4) 211 #define SD_CMD_SDIO_SEN_OP_COND ((uint8_t)5) 212 #define SD_CMD_HS_SWITCH ((uint8_t)6) 213 #define SD_CMD_SEL_DESEL_CARD ((uint8_t)7) 214 #define SD_CMD_HS_SEND_EXT_CSD ((uint8_t)8) 215 #define SD_CMD_SEND_CSD ((uint8_t)9) 216 #define SD_CMD_SEND_CID ((uint8_t)10) 217 #define SD_CMD_READ_DAT_UNTIL_STOP ((uint8_t)11) /*!< SD Card doesn't support it */ 218 #define SD_CMD_STOP_TRANSMISSION ((uint8_t)12) 219 #define SD_CMD_SEND_STATUS ((uint8_t)13) 220 #define SD_CMD_HS_BUSTEST_READ ((uint8_t)14) 221 #define SD_CMD_GO_INACTIVE_STATE ((uint8_t)15) 222 #define SD_CMD_SET_BLOCKLEN ((uint8_t)16) 223 #define SD_CMD_READ_SINGLE_BLOCK ((uint8_t)17) 224 #define SD_CMD_READ_MULT_BLOCK ((uint8_t)18) 225 #define SD_CMD_HS_BUSTEST_WRITE ((uint8_t)19) 226 #define SD_CMD_WRITE_DAT_UNTIL_STOP ((uint8_t)20) /*!< SD Card doesn't support it */ 227 #define SD_CMD_SET_BLOCK_COUNT ((uint8_t)23) /*!< SD Card doesn't support it */ 228 #define SD_CMD_WRITE_SINGLE_BLOCK ((uint8_t)24) 229 #define SD_CMD_WRITE_MULT_BLOCK ((uint8_t)25) 230 #define SD_CMD_PROG_CID ((uint8_t)26) /*!< reserved for manufacturers */ 231 #define SD_CMD_PROG_CSD ((uint8_t)27) 232 #define SD_CMD_SET_WRITE_PROT ((uint8_t)28) 233 #define SD_CMD_CLR_WRITE_PROT ((uint8_t)29) 234 #define SD_CMD_SEND_WRITE_PROT ((uint8_t)30) 235 #define SD_CMD_SD_ERASE_GRP_START ((uint8_t)32) /*!< To set the address of the first write 236 block to be erased.( For SD card only )* / 237 #define SD_CMD_SD_ERASE_GRP_END ((uint8_t)33) /*!< To set the address of the last write block of the 238 continuous range to be erased.( For SD card only )* / 239 #define SD_CMD_ERASE_GRP_START ((uint8_t)35) /*!< To set the address of the first write block to be erased. 240 ( For MMC card only spec 3.31 )* / 241 242 #define SD_CMD_ERASE_GRP_END ((uint8_t)36) /*!< To set the address of the last write block of the 243 continuous range to be erased.( For MMC card only spec 3.31 )* / 244 245 #define SD_CMD_ERASE ((uint8_t)38) 246 #define SD_CMD_FAST_IO ((uint8_t)39) /*!< SD Card doesn't support it */ 247 #define SD_CMD_GO_IRQ_STATE ((uint8_t)40) /*!< SD Card doesn't support it */ 248 #define SD_CMD_LOCK_UNLOCK ((uint8_t)42) 249 #define SD_CMD_APP_CMD ((uint8_t)55) 250 #define SD_CMD_GEN_CMD ((uint8_t)56) 251 #define SD_CMD_NO_CMD ((uint8_t)64) 252 253 /** 254 * @brief Following commands are SD Card Specific commands. 255 * SDIO_APP_CMD should be sent before sending these commands. 256 */ 257 #define SD_CMD_APP_SD_SET_BUSWIDTH ((uint8_t)6) /*!< For SD Card only */ 258 #define SD_CMD_SD_APP_STAUS ((uint8_t)13) /*!< For SD Card only */ 259 #define SD_CMD_SD_APP_SEND_NUM_WRITE_BLOCKS ((uint8_t)22) /*!< For SD Card only */ 260 #define SD_CMD_SD_APP_OP_COND ((uint8_t)41) /*!< For SD Card only */ 261 #define SD_CMD_SD_APP_SET_CLR_CARD_DETECT ((uint8_t)42) /*!< For SD Card only */ 262 #define SD_CMD_SD_APP_SEND_SCR ((uint8_t)51) /*!< For SD Card only */ 263 #define SD_CMD_SDIO_RW_DIRECT ((uint8_t)52) /*!< For SD I/O Card only */ 264 #define SD_CMD_SDIO_RW_EXTENDED ((uint8_t)53) /*!< For SD I/O Card only */ 265 266 /** 267 * @brief Following commands are SD Card Specific security commands. 268 * SDIO_APP_CMD should be sent before sending these commands. 269 */ 270 #define SD_CMD_SD_APP_GET_MKB ((uint8_t)43) /*!< For SD Card only */ 271 #define SD_CMD_SD_APP_GET_MID ((uint8_t)44) /*!< For SD Card only */ 272 #define SD_CMD_SD_APP_SET_CER_RN1 ((uint8_t)45) /*!< For SD Card only */ 273 #define SD_CMD_SD_APP_GET_CER_RN2 ((uint8_t)46) /*!< For SD Card only */ 274 #define SD_CMD_SD_APP_SET_CER_RES2 ((uint8_t)47) /*!< For SD Card only */ 275 #define SD_CMD_SD_APP_GET_CER_RES1 ((uint8_t)48) /*!< For SD Card only */ 276 #define SD_CMD_SD_APP_SECURE_READ_MULTIPLE_BLOCK ((uint8_t)18) /*!< For SD Card only */ 277 #define SD_CMD_SD_APP_SECURE_WRITE_MULTIPLE_BLOCK ((uint8_t)25) /*!< For SD Card only */ 278 #define SD_CMD_SD_APP_SECURE_ERASE ((uint8_t)38) /*!< For SD Card only */ 279 #define SD_CMD_SD_APP_CHANGE_SECURE_AREA ((uint8_t)49) /*!< For SD Card only */ 280 #define SD_CMD_SD_APP_SECURE_WRITE_MKB ((uint8_t)48) /*!< For SD Card only */ 281 282 #define SD_DMA_MODE ((uint32_t)0x00000000) 283 #define SD_INTERRUPT_MODE ((uint32_t)0x00000001) 284 #define SD_POLLING_MODE ((uint32_t)0x00000002) 285 286 /** 287 * @brief SD detection on its memory slot 288 */ 289 #define SD_PRESENT ((uint8_t)0x01) 290 #define SD_NOT_PRESENT ((uint8_t)0x00) 291 292 /** 293 * @brief Supported SD Memory Cards 294 */ 295 #define SDIO_STD_CAPACITY_SD_CARD_V1_1 ((uint32_t)0x00000000) 296 #define SDIO_STD_CAPACITY_SD_CARD_V2_0 ((uint32_t)0x00000001) 297 #define SDIO_HIGH_CAPACITY_SD_CARD ((uint32_t)0x00000002) 298 #define SDIO_MULTIMEDIA_CARD ((uint32_t)0x00000003) 299 #define SDIO_SECURE_DIGITAL_IO_CARD ((uint32_t)0x00000004) 300 #define SDIO_HIGH_SPEED_MULTIMEDIA_CARD ((uint32_t)0x00000005) 301 #define SDIO_SECURE_DIGITAL_IO_COMBO_CARD ((uint32_t)0x00000006) 302 #define SDIO_HIGH_CAPACITY_MMC_CARD ((uint32_t)0x00000007) 303 304 /* Private function prototypes -----------------------------------------------*/ 305 void SD_DeInit ( void ); 306 SD_Error SD_Init ( void ); 307 SDTransferState SD_GetStatus ( void ); 308 SDCardState SD_GetState ( void ); 309 uint8_t SD_Detect ( void ); 310 SD_Error SD_PowerON ( void ); 311 SD_Error SD_PowerOFF ( void ); 312 SD_Error SD_InitializeCards ( void ); 313 SD_Error SD_GetCardInfo ( SD_CardInfo * cardinfo ); 314 SD_Error SD_EnableWideBusOperation ( uint32_t WideMode ); 315 SD_Error SD_SetDeviceMode ( uint32_t Mode ); 316 SD_Error SD_SelectDeselect ( uint32_t addr ); 317 SD_Error SD_ReadBlock ( uint8_t * readbuff, uint32_t ReadAddr, 318 uint16_t BlockSize ); 319 SD_Error SD_ReadMultiBlocks ( uint8_t * readbuff, uint32_t ReadAddr, 320 uint16_t BlockSize, uint32_t NumberOfBlocks ); 321 SD_Error SD_WriteBlock ( uint8_t * writebuff, uint32_t WriteAddr, 322 uint16_t BlockSize ); 323 SD_Error SD_WriteMultiBlocks ( uint8_t * writebuff, uint32_t WriteAddr, 324 uint16_t BlockSize, uint32_t NumberOfBlocks ); 325 SDTransferState SD_GetTransferState ( void ); 326 SD_Error SD_StopTransfer ( void ); 327 SD_Error SD_Erase ( uint32_t startaddr, uint32_t endaddr ); 328 SD_Error SD_SendStatus ( uint32_t * pcardstatus ); 329 SD_Error SD_SendSDStatus ( uint32_t * psdstatus ); 330 SD_Error SD_ProcessIRQSrc ( void ); 331 332 #ifdef __cplusplus 333 } 334 #endif 335 336 #endif /* __SDIO_SD_H */ 337 338 /********************************************************************************************************* 339 END FILE 340 *********************************************************************************************************/