Lines Matching refs:hsd
291 static uint32_t SD_InitCard(SD_HandleTypeDef *hsd);
292 static uint32_t SD_PowerON(SD_HandleTypeDef *hsd);
293 static uint32_t SD_SendSDStatus(SD_HandleTypeDef *hsd, uint32_t *pSDstatus);
294 static uint32_t SD_SendStatus(SD_HandleTypeDef *hsd, uint32_t *pCardStatus);
295 static uint32_t SD_WideBus_Enable(SD_HandleTypeDef *hsd);
296 static uint32_t SD_WideBus_Disable(SD_HandleTypeDef *hsd);
297 static uint32_t SD_FindSCR(SD_HandleTypeDef *hsd, uint32_t *pSCR);
298 static void SD_PowerOFF(SD_HandleTypeDef *hsd);
299 static void SD_Write_IT(SD_HandleTypeDef *hsd);
300 static void SD_Read_IT(SD_HandleTypeDef *hsd);
301 static uint32_t SD_SwitchSpeed(SD_HandleTypeDef *hsd, uint32_t SwitchSpeedMode);
303 static uint32_t SD_UltraHighSpeed(SD_HandleTypeDef *hsd, uint32_t UltraHighSpeedMode);
304 static uint32_t SD_DDR_Mode(SD_HandleTypeDef *hsd);
336 HAL_StatusTypeDef HAL_SD_Init(SD_HandleTypeDef *hsd) in HAL_SD_Init() argument
344 if (hsd == NULL) in HAL_SD_Init()
350 assert_param(IS_SDMMC_ALL_INSTANCE(hsd->Instance)); in HAL_SD_Init()
351 assert_param(IS_SDMMC_CLOCK_EDGE(hsd->Init.ClockEdge)); in HAL_SD_Init()
352 assert_param(IS_SDMMC_CLOCK_POWER_SAVE(hsd->Init.ClockPowerSave)); in HAL_SD_Init()
353 assert_param(IS_SDMMC_BUS_WIDE(hsd->Init.BusWide)); in HAL_SD_Init()
354 assert_param(IS_SDMMC_HARDWARE_FLOW_CONTROL(hsd->Init.HardwareFlowControl)); in HAL_SD_Init()
355 assert_param(IS_SDMMC_CLKDIV(hsd->Init.ClockDiv)); in HAL_SD_Init()
357 if (hsd->State == HAL_SD_STATE_RESET) in HAL_SD_Init()
360 hsd->Lock = HAL_UNLOCKED; in HAL_SD_Init()
364 if (hsd->Init.TranceiverPresent == SDMMC_TRANSCEIVER_UNKNOWN) in HAL_SD_Init()
366 hsd->Init.TranceiverPresent = SDMMC_TRANSCEIVER_PRESENT; in HAL_SD_Init()
371 hsd->TxCpltCallback = HAL_SD_TxCpltCallback; in HAL_SD_Init()
372 hsd->RxCpltCallback = HAL_SD_RxCpltCallback; in HAL_SD_Init()
373 hsd->ErrorCallback = HAL_SD_ErrorCallback; in HAL_SD_Init()
374 hsd->AbortCpltCallback = HAL_SD_AbortCallback; in HAL_SD_Init()
375 hsd->Read_DMALnkLstBufCpltCallback = HAL_SDEx_Read_DMALnkLstBufCpltCallback; in HAL_SD_Init()
376 hsd->Write_DMALnkLstBufCpltCallback = HAL_SDEx_Write_DMALnkLstBufCpltCallback; in HAL_SD_Init()
378 if (hsd->Init.TranceiverPresent == SDMMC_TRANSCEIVER_PRESENT) in HAL_SD_Init()
380 hsd->DriveTransceiver_1_8V_Callback = HAL_SD_DriveTransceiver_1_8V_Callback; in HAL_SD_Init()
384 if (hsd->MspInitCallback == NULL) in HAL_SD_Init()
386 hsd->MspInitCallback = HAL_SD_MspInit; in HAL_SD_Init()
390 hsd->MspInitCallback(hsd); in HAL_SD_Init()
393 HAL_SD_MspInit(hsd); in HAL_SD_Init()
397 hsd->State = HAL_SD_STATE_PROGRAMMING; in HAL_SD_Init()
400 if (HAL_SD_InitCard(hsd) != HAL_OK) in HAL_SD_Init()
405 if (HAL_SD_GetCardStatus(hsd, &CardStatus) != HAL_OK) in HAL_SD_Init()
412 if ((hsd->SdCard.CardType == CARD_SDHC_SDXC) && ((speedgrade != 0U) || (unitsize != 0U))) in HAL_SD_Init()
414 hsd->SdCard.CardSpeed = CARD_ULTRA_HIGH_SPEED; in HAL_SD_Init()
418 if (hsd->SdCard.CardType == CARD_SDHC_SDXC) in HAL_SD_Init()
420 hsd->SdCard.CardSpeed = CARD_HIGH_SPEED; in HAL_SD_Init()
424 hsd->SdCard.CardSpeed = CARD_NORMAL_SPEED; in HAL_SD_Init()
429 if (HAL_SD_ConfigWideBusOperation(hsd, hsd->Init.BusWide) != HAL_OK) in HAL_SD_Init()
436 while ((HAL_SD_GetCardState(hsd) != HAL_SD_CARD_TRANSFER)) in HAL_SD_Init()
440 hsd->ErrorCode = HAL_SD_ERROR_TIMEOUT; in HAL_SD_Init()
441 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Init()
447 hsd->ErrorCode = HAL_SD_ERROR_NONE; in HAL_SD_Init()
450 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_Init()
453 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Init()
465 HAL_StatusTypeDef HAL_SD_InitCard(SD_HandleTypeDef *hsd) in HAL_SD_InitCard() argument
478 if (hsd->Instance == SDMMC1) in HAL_SD_InitCard()
482 else if (hsd->Instance == SDMMC2) in HAL_SD_InitCard()
492 hsd->State = HAL_SD_STATE_READY; in HAL_SD_InitCard()
493 hsd->ErrorCode = SDMMC_ERROR_INVALID_PARAMETER; in HAL_SD_InitCard()
499 Init.TranceiverPresent = hsd->Init.TranceiverPresent; in HAL_SD_InitCard()
501 if (hsd->Init.TranceiverPresent == SDMMC_TRANSCEIVER_PRESENT) in HAL_SD_InitCard()
504 hsd->Instance->POWER |= SDMMC_POWER_DIRPOL; in HAL_SD_InitCard()
508 hsd->Instance->POWER |= SDMMC_POWER_DIRPOL; in HAL_SD_InitCard()
512 (void)SDMMC_Init(hsd->Instance, Init); in HAL_SD_InitCard()
515 (void)SDMMC_PowerState_ON(hsd->Instance); in HAL_SD_InitCard()
530 errorstate = SD_PowerON(hsd); in HAL_SD_InitCard()
533 hsd->State = HAL_SD_STATE_READY; in HAL_SD_InitCard()
534 hsd->ErrorCode |= errorstate; in HAL_SD_InitCard()
539 errorstate = SD_InitCard(hsd); in HAL_SD_InitCard()
542 hsd->State = HAL_SD_STATE_READY; in HAL_SD_InitCard()
543 hsd->ErrorCode |= errorstate; in HAL_SD_InitCard()
548 errorstate = SDMMC_CmdBlockLength(hsd->Instance, BLOCKSIZE); in HAL_SD_InitCard()
552 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_InitCard()
553 hsd->ErrorCode |= errorstate; in HAL_SD_InitCard()
554 hsd->State = HAL_SD_STATE_READY; in HAL_SD_InitCard()
566 HAL_StatusTypeDef HAL_SD_DeInit(SD_HandleTypeDef *hsd) in HAL_SD_DeInit() argument
569 if (hsd == NULL) in HAL_SD_DeInit()
575 assert_param(IS_SDMMC_ALL_INSTANCE(hsd->Instance)); in HAL_SD_DeInit()
577 hsd->State = HAL_SD_STATE_BUSY; in HAL_SD_DeInit()
581 if (hsd->Init.TranceiverPresent == SDMMC_TRANSCEIVER_PRESENT) in HAL_SD_DeInit()
584 if (hsd->DriveTransceiver_1_8V_Callback == NULL) in HAL_SD_DeInit()
586 hsd->DriveTransceiver_1_8V_Callback = HAL_SD_DriveTransceiver_1_8V_Callback; in HAL_SD_DeInit()
588 hsd->DriveTransceiver_1_8V_Callback(RESET); in HAL_SD_DeInit()
596 SD_PowerOFF(hsd); in HAL_SD_DeInit()
599 if (hsd->MspDeInitCallback == NULL) in HAL_SD_DeInit()
601 hsd->MspDeInitCallback = HAL_SD_MspDeInit; in HAL_SD_DeInit()
605 hsd->MspDeInitCallback(hsd); in HAL_SD_DeInit()
608 HAL_SD_MspDeInit(hsd); in HAL_SD_DeInit()
611 hsd->ErrorCode = HAL_SD_ERROR_NONE; in HAL_SD_DeInit()
612 hsd->State = HAL_SD_STATE_RESET; in HAL_SD_DeInit()
622 __weak void HAL_SD_MspInit(SD_HandleTypeDef *hsd) in HAL_SD_MspInit() argument
625 UNUSED(hsd); in HAL_SD_MspInit()
637 __weak void HAL_SD_MspDeInit(SD_HandleTypeDef *hsd) in HAL_SD_MspDeInit() argument
640 UNUSED(hsd); in HAL_SD_MspDeInit()
678 HAL_StatusTypeDef HAL_SD_ReadBlocks(SD_HandleTypeDef *hsd, uint8_t *pData, uint32_t BlockAdd, uint3… in HAL_SD_ReadBlocks() argument
692 hsd->ErrorCode |= HAL_SD_ERROR_PARAM; in HAL_SD_ReadBlocks()
696 if (hsd->State == HAL_SD_STATE_READY) in HAL_SD_ReadBlocks()
698 hsd->ErrorCode = HAL_SD_ERROR_NONE; in HAL_SD_ReadBlocks()
700 if ((add + NumberOfBlocks) > (hsd->SdCard.LogBlockNbr)) in HAL_SD_ReadBlocks()
702 hsd->ErrorCode |= HAL_SD_ERROR_ADDR_OUT_OF_RANGE; in HAL_SD_ReadBlocks()
706 hsd->State = HAL_SD_STATE_BUSY; in HAL_SD_ReadBlocks()
709 hsd->Instance->DCTRL = 0U; in HAL_SD_ReadBlocks()
711 if (hsd->SdCard.CardType != CARD_SDHC_SDXC) in HAL_SD_ReadBlocks()
723 (void)SDMMC_ConfigData(hsd->Instance, &config); in HAL_SD_ReadBlocks()
724 __SDMMC_CMDTRANS_ENABLE(hsd->Instance); in HAL_SD_ReadBlocks()
729 hsd->Context = SD_CONTEXT_READ_MULTIPLE_BLOCK; in HAL_SD_ReadBlocks()
732 errorstate = SDMMC_CmdReadMultiBlock(hsd->Instance, add); in HAL_SD_ReadBlocks()
736 hsd->Context = SD_CONTEXT_READ_SINGLE_BLOCK; in HAL_SD_ReadBlocks()
739 errorstate = SDMMC_CmdReadSingleBlock(hsd->Instance, add); in HAL_SD_ReadBlocks()
744 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_ReadBlocks()
745 hsd->ErrorCode |= errorstate; in HAL_SD_ReadBlocks()
746 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ReadBlocks()
747 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_ReadBlocks()
753 …while (!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR | SDMMC_FLAG_DCRCFAIL | SDMMC_FLAG_DTIMEOUT | SD… in HAL_SD_ReadBlocks()
755 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXFIFOHF) && (dataremaining >= SDMMC_FIFO_SIZE)) in HAL_SD_ReadBlocks()
760 data = SDMMC_ReadFIFO(hsd->Instance); in HAL_SD_ReadBlocks()
776 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_ReadBlocks()
777 hsd->ErrorCode |= HAL_SD_ERROR_TIMEOUT; in HAL_SD_ReadBlocks()
778 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ReadBlocks()
779 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_ReadBlocks()
783 __SDMMC_CMDTRANS_DISABLE(hsd->Instance); in HAL_SD_ReadBlocks()
786 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DATAEND) && (NumberOfBlocks > 1U)) in HAL_SD_ReadBlocks()
788 if (hsd->SdCard.CardType != CARD_SECURED) in HAL_SD_ReadBlocks()
791 errorstate = SDMMC_CmdStopTransfer(hsd->Instance); in HAL_SD_ReadBlocks()
795 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_ReadBlocks()
796 hsd->ErrorCode |= errorstate; in HAL_SD_ReadBlocks()
797 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ReadBlocks()
798 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_ReadBlocks()
805 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DTIMEOUT)) in HAL_SD_ReadBlocks()
808 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_ReadBlocks()
809 hsd->ErrorCode |= HAL_SD_ERROR_DATA_TIMEOUT; in HAL_SD_ReadBlocks()
810 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ReadBlocks()
811 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_ReadBlocks()
814 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DCRCFAIL)) in HAL_SD_ReadBlocks()
817 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_ReadBlocks()
818 hsd->ErrorCode |= HAL_SD_ERROR_DATA_CRC_FAIL; in HAL_SD_ReadBlocks()
819 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ReadBlocks()
820 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_ReadBlocks()
823 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR)) in HAL_SD_ReadBlocks()
826 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_ReadBlocks()
827 hsd->ErrorCode |= HAL_SD_ERROR_RX_OVERRUN; in HAL_SD_ReadBlocks()
828 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ReadBlocks()
829 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_ReadBlocks()
838 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_DATA_FLAGS); in HAL_SD_ReadBlocks()
840 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ReadBlocks()
846 hsd->ErrorCode |= HAL_SD_ERROR_BUSY; in HAL_SD_ReadBlocks()
863 HAL_StatusTypeDef HAL_SD_WriteBlocks(SD_HandleTypeDef *hsd, const uint8_t *pData, uint32_t BlockAdd, in HAL_SD_WriteBlocks() argument
877 hsd->ErrorCode |= HAL_SD_ERROR_PARAM; in HAL_SD_WriteBlocks()
881 if (hsd->State == HAL_SD_STATE_READY) in HAL_SD_WriteBlocks()
883 hsd->ErrorCode = HAL_SD_ERROR_NONE; in HAL_SD_WriteBlocks()
885 if ((add + NumberOfBlocks) > (hsd->SdCard.LogBlockNbr)) in HAL_SD_WriteBlocks()
887 hsd->ErrorCode |= HAL_SD_ERROR_ADDR_OUT_OF_RANGE; in HAL_SD_WriteBlocks()
891 hsd->State = HAL_SD_STATE_BUSY; in HAL_SD_WriteBlocks()
894 hsd->Instance->DCTRL = 0U; in HAL_SD_WriteBlocks()
896 if (hsd->SdCard.CardType != CARD_SDHC_SDXC) in HAL_SD_WriteBlocks()
908 (void)SDMMC_ConfigData(hsd->Instance, &config); in HAL_SD_WriteBlocks()
909 __SDMMC_CMDTRANS_ENABLE(hsd->Instance); in HAL_SD_WriteBlocks()
914 hsd->Context = SD_CONTEXT_WRITE_MULTIPLE_BLOCK; in HAL_SD_WriteBlocks()
917 errorstate = SDMMC_CmdWriteMultiBlock(hsd->Instance, add); in HAL_SD_WriteBlocks()
921 hsd->Context = SD_CONTEXT_WRITE_SINGLE_BLOCK; in HAL_SD_WriteBlocks()
924 errorstate = SDMMC_CmdWriteSingleBlock(hsd->Instance, add); in HAL_SD_WriteBlocks()
929 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_WriteBlocks()
930 hsd->ErrorCode |= errorstate; in HAL_SD_WriteBlocks()
931 hsd->State = HAL_SD_STATE_READY; in HAL_SD_WriteBlocks()
932 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_WriteBlocks()
938 while (!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_TXUNDERR | SDMMC_FLAG_DCRCFAIL | SDMMC_FLAG_DTIMEOUT | in HAL_SD_WriteBlocks()
941 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_TXFIFOHE) && (dataremaining >= SDMMC_FIFO_SIZE)) in HAL_SD_WriteBlocks()
954 (void)SDMMC_WriteFIFO(hsd->Instance, &data); in HAL_SD_WriteBlocks()
962 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_WriteBlocks()
963 hsd->ErrorCode |= errorstate; in HAL_SD_WriteBlocks()
964 hsd->State = HAL_SD_STATE_READY; in HAL_SD_WriteBlocks()
965 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_WriteBlocks()
969 __SDMMC_CMDTRANS_DISABLE(hsd->Instance); in HAL_SD_WriteBlocks()
972 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DATAEND) && (NumberOfBlocks > 1U)) in HAL_SD_WriteBlocks()
974 if (hsd->SdCard.CardType != CARD_SECURED) in HAL_SD_WriteBlocks()
977 errorstate = SDMMC_CmdStopTransfer(hsd->Instance); in HAL_SD_WriteBlocks()
981 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_WriteBlocks()
982 hsd->ErrorCode |= errorstate; in HAL_SD_WriteBlocks()
983 hsd->State = HAL_SD_STATE_READY; in HAL_SD_WriteBlocks()
984 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_WriteBlocks()
991 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DTIMEOUT)) in HAL_SD_WriteBlocks()
994 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_WriteBlocks()
995 hsd->ErrorCode |= HAL_SD_ERROR_DATA_TIMEOUT; in HAL_SD_WriteBlocks()
996 hsd->State = HAL_SD_STATE_READY; in HAL_SD_WriteBlocks()
997 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_WriteBlocks()
1000 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DCRCFAIL)) in HAL_SD_WriteBlocks()
1003 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_WriteBlocks()
1004 hsd->ErrorCode |= HAL_SD_ERROR_DATA_CRC_FAIL; in HAL_SD_WriteBlocks()
1005 hsd->State = HAL_SD_STATE_READY; in HAL_SD_WriteBlocks()
1006 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_WriteBlocks()
1009 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_TXUNDERR)) in HAL_SD_WriteBlocks()
1012 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_WriteBlocks()
1013 hsd->ErrorCode |= HAL_SD_ERROR_TX_UNDERRUN; in HAL_SD_WriteBlocks()
1014 hsd->State = HAL_SD_STATE_READY; in HAL_SD_WriteBlocks()
1015 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_WriteBlocks()
1024 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_DATA_FLAGS); in HAL_SD_WriteBlocks()
1026 hsd->State = HAL_SD_STATE_READY; in HAL_SD_WriteBlocks()
1032 hsd->ErrorCode |= HAL_SD_ERROR_BUSY; in HAL_SD_WriteBlocks()
1050 HAL_StatusTypeDef HAL_SD_ReadBlocks_IT(SD_HandleTypeDef *hsd, uint8_t *pData, uint32_t BlockAdd, in HAL_SD_ReadBlocks_IT() argument
1059 hsd->ErrorCode |= HAL_SD_ERROR_PARAM; in HAL_SD_ReadBlocks_IT()
1063 if (hsd->State == HAL_SD_STATE_READY) in HAL_SD_ReadBlocks_IT()
1065 hsd->ErrorCode = HAL_SD_ERROR_NONE; in HAL_SD_ReadBlocks_IT()
1067 if ((add + NumberOfBlocks) > (hsd->SdCard.LogBlockNbr)) in HAL_SD_ReadBlocks_IT()
1069 hsd->ErrorCode |= HAL_SD_ERROR_ADDR_OUT_OF_RANGE; in HAL_SD_ReadBlocks_IT()
1073 hsd->State = HAL_SD_STATE_BUSY; in HAL_SD_ReadBlocks_IT()
1076 hsd->Instance->DCTRL = 0U; in HAL_SD_ReadBlocks_IT()
1078 hsd->pRxBuffPtr = pData; in HAL_SD_ReadBlocks_IT()
1079 hsd->RxXferSize = BLOCKSIZE * NumberOfBlocks; in HAL_SD_ReadBlocks_IT()
1081 if (hsd->SdCard.CardType != CARD_SDHC_SDXC) in HAL_SD_ReadBlocks_IT()
1093 (void)SDMMC_ConfigData(hsd->Instance, &config); in HAL_SD_ReadBlocks_IT()
1094 __SDMMC_CMDTRANS_ENABLE(hsd->Instance); in HAL_SD_ReadBlocks_IT()
1099 hsd->Context = (SD_CONTEXT_READ_MULTIPLE_BLOCK | SD_CONTEXT_IT); in HAL_SD_ReadBlocks_IT()
1102 errorstate = SDMMC_CmdReadMultiBlock(hsd->Instance, add); in HAL_SD_ReadBlocks_IT()
1106 hsd->Context = (SD_CONTEXT_READ_SINGLE_BLOCK | SD_CONTEXT_IT); in HAL_SD_ReadBlocks_IT()
1109 errorstate = SDMMC_CmdReadSingleBlock(hsd->Instance, add); in HAL_SD_ReadBlocks_IT()
1114 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_ReadBlocks_IT()
1115 hsd->ErrorCode |= errorstate; in HAL_SD_ReadBlocks_IT()
1116 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ReadBlocks_IT()
1117 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_ReadBlocks_IT()
1121 …__HAL_SD_ENABLE_IT(hsd, (SDMMC_IT_DCRCFAIL | SDMMC_IT_DTIMEOUT | SDMMC_IT_RXOVERR | SDMMC_IT_DATAE… in HAL_SD_ReadBlocks_IT()
1145 HAL_StatusTypeDef HAL_SD_WriteBlocks_IT(SD_HandleTypeDef *hsd, const uint8_t *pData, uint32_t Block… in HAL_SD_WriteBlocks_IT() argument
1154 hsd->ErrorCode |= HAL_SD_ERROR_PARAM; in HAL_SD_WriteBlocks_IT()
1158 if (hsd->State == HAL_SD_STATE_READY) in HAL_SD_WriteBlocks_IT()
1160 hsd->ErrorCode = HAL_SD_ERROR_NONE; in HAL_SD_WriteBlocks_IT()
1162 if ((add + NumberOfBlocks) > (hsd->SdCard.LogBlockNbr)) in HAL_SD_WriteBlocks_IT()
1164 hsd->ErrorCode |= HAL_SD_ERROR_ADDR_OUT_OF_RANGE; in HAL_SD_WriteBlocks_IT()
1168 hsd->State = HAL_SD_STATE_BUSY; in HAL_SD_WriteBlocks_IT()
1171 hsd->Instance->DCTRL = 0U; in HAL_SD_WriteBlocks_IT()
1173 hsd->pTxBuffPtr = pData; in HAL_SD_WriteBlocks_IT()
1174 hsd->TxXferSize = BLOCKSIZE * NumberOfBlocks; in HAL_SD_WriteBlocks_IT()
1176 if (hsd->SdCard.CardType != CARD_SDHC_SDXC) in HAL_SD_WriteBlocks_IT()
1188 (void)SDMMC_ConfigData(hsd->Instance, &config); in HAL_SD_WriteBlocks_IT()
1190 __SDMMC_CMDTRANS_ENABLE(hsd->Instance); in HAL_SD_WriteBlocks_IT()
1195 hsd->Context = (SD_CONTEXT_WRITE_MULTIPLE_BLOCK | SD_CONTEXT_IT); in HAL_SD_WriteBlocks_IT()
1198 errorstate = SDMMC_CmdWriteMultiBlock(hsd->Instance, add); in HAL_SD_WriteBlocks_IT()
1202 hsd->Context = (SD_CONTEXT_WRITE_SINGLE_BLOCK | SD_CONTEXT_IT); in HAL_SD_WriteBlocks_IT()
1205 errorstate = SDMMC_CmdWriteSingleBlock(hsd->Instance, add); in HAL_SD_WriteBlocks_IT()
1210 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_WriteBlocks_IT()
1211 hsd->ErrorCode |= errorstate; in HAL_SD_WriteBlocks_IT()
1212 hsd->State = HAL_SD_STATE_READY; in HAL_SD_WriteBlocks_IT()
1213 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_WriteBlocks_IT()
1218 …__HAL_SD_ENABLE_IT(hsd, (SDMMC_IT_DCRCFAIL | SDMMC_IT_DTIMEOUT | SDMMC_IT_TXUNDERR | SDMMC_IT_DATA… in HAL_SD_WriteBlocks_IT()
1242 HAL_StatusTypeDef HAL_SD_ReadBlocks_DMA(SD_HandleTypeDef *hsd, uint8_t *pData, uint32_t BlockAdd, in HAL_SD_ReadBlocks_DMA() argument
1251 hsd->ErrorCode |= HAL_SD_ERROR_PARAM; in HAL_SD_ReadBlocks_DMA()
1255 if (hsd->State == HAL_SD_STATE_READY) in HAL_SD_ReadBlocks_DMA()
1257 hsd->ErrorCode = HAL_SD_ERROR_NONE; in HAL_SD_ReadBlocks_DMA()
1259 if ((add + NumberOfBlocks) > (hsd->SdCard.LogBlockNbr)) in HAL_SD_ReadBlocks_DMA()
1261 hsd->ErrorCode |= HAL_SD_ERROR_ADDR_OUT_OF_RANGE; in HAL_SD_ReadBlocks_DMA()
1265 hsd->State = HAL_SD_STATE_BUSY; in HAL_SD_ReadBlocks_DMA()
1268 hsd->Instance->DCTRL = 0U; in HAL_SD_ReadBlocks_DMA()
1270 hsd->pRxBuffPtr = pData; in HAL_SD_ReadBlocks_DMA()
1271 hsd->RxXferSize = BLOCKSIZE * NumberOfBlocks; in HAL_SD_ReadBlocks_DMA()
1273 if (hsd->SdCard.CardType != CARD_SDHC_SDXC) in HAL_SD_ReadBlocks_DMA()
1285 (void)SDMMC_ConfigData(hsd->Instance, &config); in HAL_SD_ReadBlocks_DMA()
1287 __SDMMC_CMDTRANS_ENABLE(hsd->Instance); in HAL_SD_ReadBlocks_DMA()
1288 hsd->Instance->IDMABASER = (uint32_t) pData ; in HAL_SD_ReadBlocks_DMA()
1289 hsd->Instance->IDMACTRL = SDMMC_ENABLE_IDMA_SINGLE_BUFF; in HAL_SD_ReadBlocks_DMA()
1294 hsd->Context = (SD_CONTEXT_READ_MULTIPLE_BLOCK | SD_CONTEXT_DMA); in HAL_SD_ReadBlocks_DMA()
1297 errorstate = SDMMC_CmdReadMultiBlock(hsd->Instance, add); in HAL_SD_ReadBlocks_DMA()
1301 hsd->Context = (SD_CONTEXT_READ_SINGLE_BLOCK | SD_CONTEXT_DMA); in HAL_SD_ReadBlocks_DMA()
1304 errorstate = SDMMC_CmdReadSingleBlock(hsd->Instance, add); in HAL_SD_ReadBlocks_DMA()
1309 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_ReadBlocks_DMA()
1310 hsd->ErrorCode |= errorstate; in HAL_SD_ReadBlocks_DMA()
1311 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ReadBlocks_DMA()
1312 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_ReadBlocks_DMA()
1317 …__HAL_SD_ENABLE_IT(hsd, (SDMMC_IT_DCRCFAIL | SDMMC_IT_DTIMEOUT | SDMMC_IT_RXOVERR | SDMMC_IT_DATAE… in HAL_SD_ReadBlocks_DMA()
1340 HAL_StatusTypeDef HAL_SD_WriteBlocks_DMA(SD_HandleTypeDef *hsd, const uint8_t *pData, uint32_t Bloc… in HAL_SD_WriteBlocks_DMA() argument
1349 hsd->ErrorCode |= HAL_SD_ERROR_PARAM; in HAL_SD_WriteBlocks_DMA()
1353 if (hsd->State == HAL_SD_STATE_READY) in HAL_SD_WriteBlocks_DMA()
1355 hsd->ErrorCode = HAL_SD_ERROR_NONE; in HAL_SD_WriteBlocks_DMA()
1357 if ((add + NumberOfBlocks) > (hsd->SdCard.LogBlockNbr)) in HAL_SD_WriteBlocks_DMA()
1359 hsd->ErrorCode |= HAL_SD_ERROR_ADDR_OUT_OF_RANGE; in HAL_SD_WriteBlocks_DMA()
1363 hsd->State = HAL_SD_STATE_BUSY; in HAL_SD_WriteBlocks_DMA()
1366 hsd->Instance->DCTRL = 0U; in HAL_SD_WriteBlocks_DMA()
1368 hsd->pTxBuffPtr = pData; in HAL_SD_WriteBlocks_DMA()
1369 hsd->TxXferSize = BLOCKSIZE * NumberOfBlocks; in HAL_SD_WriteBlocks_DMA()
1371 if (hsd->SdCard.CardType != CARD_SDHC_SDXC) in HAL_SD_WriteBlocks_DMA()
1383 (void)SDMMC_ConfigData(hsd->Instance, &config); in HAL_SD_WriteBlocks_DMA()
1385 __SDMMC_CMDTRANS_ENABLE(hsd->Instance); in HAL_SD_WriteBlocks_DMA()
1387 hsd->Instance->IDMABASER = (uint32_t) pData ; in HAL_SD_WriteBlocks_DMA()
1388 hsd->Instance->IDMACTRL = SDMMC_ENABLE_IDMA_SINGLE_BUFF; in HAL_SD_WriteBlocks_DMA()
1393 hsd->Context = (SD_CONTEXT_WRITE_MULTIPLE_BLOCK | SD_CONTEXT_DMA); in HAL_SD_WriteBlocks_DMA()
1396 errorstate = SDMMC_CmdWriteMultiBlock(hsd->Instance, add); in HAL_SD_WriteBlocks_DMA()
1400 hsd->Context = (SD_CONTEXT_WRITE_SINGLE_BLOCK | SD_CONTEXT_DMA); in HAL_SD_WriteBlocks_DMA()
1403 errorstate = SDMMC_CmdWriteSingleBlock(hsd->Instance, add); in HAL_SD_WriteBlocks_DMA()
1408 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_WriteBlocks_DMA()
1409 hsd->ErrorCode |= errorstate; in HAL_SD_WriteBlocks_DMA()
1410 hsd->State = HAL_SD_STATE_READY; in HAL_SD_WriteBlocks_DMA()
1411 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_WriteBlocks_DMA()
1416 …__HAL_SD_ENABLE_IT(hsd, (SDMMC_IT_DCRCFAIL | SDMMC_IT_DTIMEOUT | SDMMC_IT_TXUNDERR | SDMMC_IT_DATA… in HAL_SD_WriteBlocks_DMA()
1435 HAL_StatusTypeDef HAL_SD_Erase(SD_HandleTypeDef *hsd, uint32_t BlockStartAdd, uint32_t BlockEndAdd) in HAL_SD_Erase() argument
1441 if (hsd->State == HAL_SD_STATE_READY) in HAL_SD_Erase()
1443 hsd->ErrorCode = HAL_SD_ERROR_NONE; in HAL_SD_Erase()
1447 hsd->ErrorCode |= HAL_SD_ERROR_PARAM; in HAL_SD_Erase()
1451 if (end_add > (hsd->SdCard.LogBlockNbr)) in HAL_SD_Erase()
1453 hsd->ErrorCode |= HAL_SD_ERROR_ADDR_OUT_OF_RANGE; in HAL_SD_Erase()
1457 hsd->State = HAL_SD_STATE_BUSY; in HAL_SD_Erase()
1460 if (((hsd->SdCard.Class) & SDMMC_CCCC_ERASE) == 0U) in HAL_SD_Erase()
1463 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_Erase()
1464 hsd->ErrorCode |= HAL_SD_ERROR_REQUEST_NOT_APPLICABLE; in HAL_SD_Erase()
1465 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Erase()
1469 if ((SDMMC_GetResponse(hsd->Instance, SDMMC_RESP1) & SDMMC_CARD_LOCKED) == SDMMC_CARD_LOCKED) in HAL_SD_Erase()
1472 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_Erase()
1473 hsd->ErrorCode |= HAL_SD_ERROR_LOCK_UNLOCK_FAILED; in HAL_SD_Erase()
1474 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Erase()
1479 if (hsd->SdCard.CardType != CARD_SDHC_SDXC) in HAL_SD_Erase()
1486 if (hsd->SdCard.CardType != CARD_SECURED) in HAL_SD_Erase()
1489 errorstate = SDMMC_CmdSDEraseStartAdd(hsd->Instance, start_add); in HAL_SD_Erase()
1493 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_Erase()
1494 hsd->ErrorCode |= errorstate; in HAL_SD_Erase()
1495 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Erase()
1500 errorstate = SDMMC_CmdSDEraseEndAdd(hsd->Instance, end_add); in HAL_SD_Erase()
1504 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_Erase()
1505 hsd->ErrorCode |= errorstate; in HAL_SD_Erase()
1506 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Erase()
1512 errorstate = SDMMC_CmdErase(hsd->Instance, 0UL); in HAL_SD_Erase()
1516 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_Erase()
1517 hsd->ErrorCode |= errorstate; in HAL_SD_Erase()
1518 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Erase()
1522 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Erase()
1537 void HAL_SD_IRQHandler(SD_HandleTypeDef *hsd) in HAL_SD_IRQHandler() argument
1540 uint32_t context = hsd->Context; in HAL_SD_IRQHandler()
1543 if ((__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXFIFOHF) != RESET) && ((context & SD_CONTEXT_IT) != 0U)) in HAL_SD_IRQHandler()
1545 SD_Read_IT(hsd); in HAL_SD_IRQHandler()
1548 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DATAEND) != RESET) in HAL_SD_IRQHandler()
1550 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_DATAEND); in HAL_SD_IRQHandler()
1552 __HAL_SD_DISABLE_IT(hsd, SDMMC_IT_DATAEND | SDMMC_IT_DCRCFAIL | SDMMC_IT_DTIMEOUT | \ in HAL_SD_IRQHandler()
1556 __HAL_SD_DISABLE_IT(hsd, SDMMC_IT_IDMABTC); in HAL_SD_IRQHandler()
1557 __SDMMC_CMDTRANS_DISABLE(hsd->Instance); in HAL_SD_IRQHandler()
1563 errorstate = SDMMC_CmdStopTransfer(hsd->Instance); in HAL_SD_IRQHandler()
1566 hsd->ErrorCode |= errorstate; in HAL_SD_IRQHandler()
1568 hsd->ErrorCallback(hsd); in HAL_SD_IRQHandler()
1570 HAL_SD_ErrorCallback(hsd); in HAL_SD_IRQHandler()
1576 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_DATA_FLAGS); in HAL_SD_IRQHandler()
1578 hsd->State = HAL_SD_STATE_READY; in HAL_SD_IRQHandler()
1579 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_IRQHandler()
1583 hsd->RxCpltCallback(hsd); in HAL_SD_IRQHandler()
1585 HAL_SD_RxCpltCallback(hsd); in HAL_SD_IRQHandler()
1591 hsd->TxCpltCallback(hsd); in HAL_SD_IRQHandler()
1593 HAL_SD_TxCpltCallback(hsd); in HAL_SD_IRQHandler()
1599 hsd->Instance->DLEN = 0; in HAL_SD_IRQHandler()
1600 hsd->Instance->DCTRL = 0; in HAL_SD_IRQHandler()
1601 hsd->Instance->IDMACTRL = SDMMC_DISABLE_IDMA; in HAL_SD_IRQHandler()
1606 errorstate = SDMMC_CmdStopTransfer(hsd->Instance); in HAL_SD_IRQHandler()
1609 hsd->ErrorCode |= errorstate; in HAL_SD_IRQHandler()
1611 hsd->ErrorCallback(hsd); in HAL_SD_IRQHandler()
1613 HAL_SD_ErrorCallback(hsd); in HAL_SD_IRQHandler()
1618 hsd->State = HAL_SD_STATE_READY; in HAL_SD_IRQHandler()
1619 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_IRQHandler()
1623 hsd->TxCpltCallback(hsd); in HAL_SD_IRQHandler()
1625 HAL_SD_TxCpltCallback(hsd); in HAL_SD_IRQHandler()
1631 hsd->RxCpltCallback(hsd); in HAL_SD_IRQHandler()
1633 HAL_SD_RxCpltCallback(hsd); in HAL_SD_IRQHandler()
1643 …else if ((__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_TXFIFOHE) != RESET) && ((context & SD_CONTEXT_IT) != 0… in HAL_SD_IRQHandler()
1645 SD_Write_IT(hsd); in HAL_SD_IRQHandler()
1648 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DCRCFAIL | SDMMC_FLAG_DTIMEOUT | SDMMC_FLAG_RXOVERR | in HAL_SD_IRQHandler()
1652 if (__HAL_SD_GET_FLAG(hsd, SDMMC_IT_DCRCFAIL) != RESET) in HAL_SD_IRQHandler()
1654 hsd->ErrorCode |= HAL_SD_ERROR_DATA_CRC_FAIL; in HAL_SD_IRQHandler()
1656 if (__HAL_SD_GET_FLAG(hsd, SDMMC_IT_DTIMEOUT) != RESET) in HAL_SD_IRQHandler()
1658 hsd->ErrorCode |= HAL_SD_ERROR_DATA_TIMEOUT; in HAL_SD_IRQHandler()
1660 if (__HAL_SD_GET_FLAG(hsd, SDMMC_IT_RXOVERR) != RESET) in HAL_SD_IRQHandler()
1662 hsd->ErrorCode |= HAL_SD_ERROR_RX_OVERRUN; in HAL_SD_IRQHandler()
1664 if (__HAL_SD_GET_FLAG(hsd, SDMMC_IT_TXUNDERR) != RESET) in HAL_SD_IRQHandler()
1666 hsd->ErrorCode |= HAL_SD_ERROR_TX_UNDERRUN; in HAL_SD_IRQHandler()
1670 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_DATA_FLAGS); in HAL_SD_IRQHandler()
1673 __HAL_SD_DISABLE_IT(hsd, SDMMC_IT_DATAEND | SDMMC_IT_DCRCFAIL | SDMMC_IT_DTIMEOUT | \ in HAL_SD_IRQHandler()
1676 __SDMMC_CMDTRANS_DISABLE(hsd->Instance); in HAL_SD_IRQHandler()
1677 hsd->Instance->DCTRL |= SDMMC_DCTRL_FIFORST; in HAL_SD_IRQHandler()
1678 hsd->Instance->CMD |= SDMMC_CMD_CMDSTOP; in HAL_SD_IRQHandler()
1679 hsd->ErrorCode |= SDMMC_CmdStopTransfer(hsd->Instance); in HAL_SD_IRQHandler()
1680 hsd->Instance->CMD &= ~(SDMMC_CMD_CMDSTOP); in HAL_SD_IRQHandler()
1681 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_DABORT); in HAL_SD_IRQHandler()
1686 hsd->State = HAL_SD_STATE_READY; in HAL_SD_IRQHandler()
1687 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_IRQHandler()
1689 hsd->ErrorCallback(hsd); in HAL_SD_IRQHandler()
1691 HAL_SD_ErrorCallback(hsd); in HAL_SD_IRQHandler()
1696 if (hsd->ErrorCode != HAL_SD_ERROR_NONE) in HAL_SD_IRQHandler()
1699 __HAL_SD_DISABLE_IT(hsd, SDMMC_IT_IDMABTC); in HAL_SD_IRQHandler()
1700 hsd->Instance->IDMACTRL = SDMMC_DISABLE_IDMA; in HAL_SD_IRQHandler()
1703 hsd->State = HAL_SD_STATE_READY; in HAL_SD_IRQHandler()
1705 hsd->ErrorCallback(hsd); in HAL_SD_IRQHandler()
1707 HAL_SD_ErrorCallback(hsd); in HAL_SD_IRQHandler()
1717 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_IDMABTC) != RESET) in HAL_SD_IRQHandler()
1719 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_IDMABTC); in HAL_SD_IRQHandler()
1724 hsd->Write_DMALnkLstBufCpltCallback(hsd); in HAL_SD_IRQHandler()
1726 HAL_SDEx_Write_DMALnkLstBufCpltCallback(hsd); in HAL_SD_IRQHandler()
1732 hsd->Read_DMALnkLstBufCpltCallback(hsd); in HAL_SD_IRQHandler()
1734 HAL_SDEx_Read_DMALnkLstBufCpltCallback(hsd); in HAL_SD_IRQHandler()
1749 HAL_SD_StateTypeDef HAL_SD_GetState(const SD_HandleTypeDef *hsd) in HAL_SD_GetState() argument
1751 return hsd->State; in HAL_SD_GetState()
1760 uint32_t HAL_SD_GetError(const SD_HandleTypeDef *hsd) in HAL_SD_GetError() argument
1762 return hsd->ErrorCode; in HAL_SD_GetError()
1770 __weak void HAL_SD_TxCpltCallback(SD_HandleTypeDef *hsd) in HAL_SD_TxCpltCallback() argument
1773 UNUSED(hsd); in HAL_SD_TxCpltCallback()
1785 __weak void HAL_SD_RxCpltCallback(SD_HandleTypeDef *hsd) in HAL_SD_RxCpltCallback() argument
1788 UNUSED(hsd); in HAL_SD_RxCpltCallback()
1800 __weak void HAL_SD_ErrorCallback(SD_HandleTypeDef *hsd) in HAL_SD_ErrorCallback() argument
1803 UNUSED(hsd); in HAL_SD_ErrorCallback()
1815 __weak void HAL_SD_AbortCallback(SD_HandleTypeDef *hsd) in HAL_SD_AbortCallback() argument
1818 UNUSED(hsd); in HAL_SD_AbortCallback()
1862 HAL_StatusTypeDef HAL_SD_RegisterCallback(SD_HandleTypeDef *hsd, HAL_SD_CallbackIDTypeDef CallbackI… in HAL_SD_RegisterCallback() argument
1870 hsd->ErrorCode |= HAL_SD_ERROR_INVALID_CALLBACK; in HAL_SD_RegisterCallback()
1874 if (hsd->State == HAL_SD_STATE_READY) in HAL_SD_RegisterCallback()
1879 hsd->TxCpltCallback = pCallback; in HAL_SD_RegisterCallback()
1882 hsd->RxCpltCallback = pCallback; in HAL_SD_RegisterCallback()
1885 hsd->ErrorCallback = pCallback; in HAL_SD_RegisterCallback()
1888 hsd->AbortCpltCallback = pCallback; in HAL_SD_RegisterCallback()
1891 hsd->Read_DMALnkLstBufCpltCallback = pCallback; in HAL_SD_RegisterCallback()
1894 hsd->Write_DMALnkLstBufCpltCallback = pCallback; in HAL_SD_RegisterCallback()
1897 hsd->MspInitCallback = pCallback; in HAL_SD_RegisterCallback()
1900 hsd->MspDeInitCallback = pCallback; in HAL_SD_RegisterCallback()
1904 hsd->ErrorCode |= HAL_SD_ERROR_INVALID_CALLBACK; in HAL_SD_RegisterCallback()
1910 else if (hsd->State == HAL_SD_STATE_RESET) in HAL_SD_RegisterCallback()
1915 hsd->MspInitCallback = pCallback; in HAL_SD_RegisterCallback()
1918 hsd->MspDeInitCallback = pCallback; in HAL_SD_RegisterCallback()
1922 hsd->ErrorCode |= HAL_SD_ERROR_INVALID_CALLBACK; in HAL_SD_RegisterCallback()
1931 hsd->ErrorCode |= HAL_SD_ERROR_INVALID_CALLBACK; in HAL_SD_RegisterCallback()
1958 HAL_StatusTypeDef HAL_SD_UnRegisterCallback(SD_HandleTypeDef *hsd, HAL_SD_CallbackIDTypeDef Callbac… in HAL_SD_UnRegisterCallback() argument
1962 if (hsd->State == HAL_SD_STATE_READY) in HAL_SD_UnRegisterCallback()
1967 hsd->TxCpltCallback = HAL_SD_TxCpltCallback; in HAL_SD_UnRegisterCallback()
1970 hsd->RxCpltCallback = HAL_SD_RxCpltCallback; in HAL_SD_UnRegisterCallback()
1973 hsd->ErrorCallback = HAL_SD_ErrorCallback; in HAL_SD_UnRegisterCallback()
1976 hsd->AbortCpltCallback = HAL_SD_AbortCallback; in HAL_SD_UnRegisterCallback()
1979 hsd->Read_DMALnkLstBufCpltCallback = HAL_SDEx_Read_DMALnkLstBufCpltCallback; in HAL_SD_UnRegisterCallback()
1982 hsd->Write_DMALnkLstBufCpltCallback = HAL_SDEx_Write_DMALnkLstBufCpltCallback; in HAL_SD_UnRegisterCallback()
1985 hsd->MspInitCallback = HAL_SD_MspInit; in HAL_SD_UnRegisterCallback()
1988 hsd->MspDeInitCallback = HAL_SD_MspDeInit; in HAL_SD_UnRegisterCallback()
1992 hsd->ErrorCode |= HAL_SD_ERROR_INVALID_CALLBACK; in HAL_SD_UnRegisterCallback()
1998 else if (hsd->State == HAL_SD_STATE_RESET) in HAL_SD_UnRegisterCallback()
2003 hsd->MspInitCallback = HAL_SD_MspInit; in HAL_SD_UnRegisterCallback()
2006 hsd->MspDeInitCallback = HAL_SD_MspDeInit; in HAL_SD_UnRegisterCallback()
2010 hsd->ErrorCode |= HAL_SD_ERROR_INVALID_CALLBACK; in HAL_SD_UnRegisterCallback()
2019 hsd->ErrorCode |= HAL_SD_ERROR_INVALID_CALLBACK; in HAL_SD_UnRegisterCallback()
2035 HAL_StatusTypeDef HAL_SD_RegisterTransceiverCallback(SD_HandleTypeDef *hsd, pSD_TransceiverCallback… in HAL_SD_RegisterTransceiverCallback() argument
2042 hsd->ErrorCode |= HAL_SD_ERROR_INVALID_CALLBACK; in HAL_SD_RegisterTransceiverCallback()
2047 __HAL_LOCK(hsd); in HAL_SD_RegisterTransceiverCallback()
2049 if (hsd->State == HAL_SD_STATE_READY) in HAL_SD_RegisterTransceiverCallback()
2051 hsd->DriveTransceiver_1_8V_Callback = pCallback; in HAL_SD_RegisterTransceiverCallback()
2056 hsd->ErrorCode |= HAL_SD_ERROR_INVALID_CALLBACK; in HAL_SD_RegisterTransceiverCallback()
2062 __HAL_UNLOCK(hsd); in HAL_SD_RegisterTransceiverCallback()
2072 HAL_StatusTypeDef HAL_SD_UnRegisterTransceiverCallback(SD_HandleTypeDef *hsd) in HAL_SD_UnRegisterTransceiverCallback() argument
2077 __HAL_LOCK(hsd); in HAL_SD_UnRegisterTransceiverCallback()
2079 if (hsd->State == HAL_SD_STATE_READY) in HAL_SD_UnRegisterTransceiverCallback()
2081 hsd->DriveTransceiver_1_8V_Callback = HAL_SD_DriveTransceiver_1_8V_Callback; in HAL_SD_UnRegisterTransceiverCallback()
2086 hsd->ErrorCode |= HAL_SD_ERROR_INVALID_CALLBACK; in HAL_SD_UnRegisterTransceiverCallback()
2092 __HAL_UNLOCK(hsd); in HAL_SD_UnRegisterTransceiverCallback()
2125 HAL_StatusTypeDef HAL_SD_GetCardCID(const SD_HandleTypeDef *hsd, HAL_SD_CardCIDTypeDef *pCID) in HAL_SD_GetCardCID() argument
2127 pCID->ManufacturerID = (uint8_t)((hsd->CID[0] & 0xFF000000U) >> 24U); in HAL_SD_GetCardCID()
2129 pCID->OEM_AppliID = (uint16_t)((hsd->CID[0] & 0x00FFFF00U) >> 8U); in HAL_SD_GetCardCID()
2131 pCID->ProdName1 = (((hsd->CID[0] & 0x000000FFU) << 24U) | ((hsd->CID[1] & 0xFFFFFF00U) >> 8U)); in HAL_SD_GetCardCID()
2133 pCID->ProdName2 = (uint8_t)(hsd->CID[1] & 0x000000FFU); in HAL_SD_GetCardCID()
2135 pCID->ProdRev = (uint8_t)((hsd->CID[2] & 0xFF000000U) >> 24U); in HAL_SD_GetCardCID()
2137 pCID->ProdSN = (((hsd->CID[2] & 0x00FFFFFFU) << 8U) | ((hsd->CID[3] & 0xFF000000U) >> 24U)); in HAL_SD_GetCardCID()
2139 pCID->Reserved1 = (uint8_t)((hsd->CID[3] & 0x00F00000U) >> 20U); in HAL_SD_GetCardCID()
2141 pCID->ManufactDate = (uint16_t)((hsd->CID[3] & 0x000FFF00U) >> 8U); in HAL_SD_GetCardCID()
2143 pCID->CID_CRC = (uint8_t)((hsd->CID[3] & 0x000000FEU) >> 1U); in HAL_SD_GetCardCID()
2158 HAL_StatusTypeDef HAL_SD_GetCardCSD(SD_HandleTypeDef *hsd, HAL_SD_CardCSDTypeDef *pCSD) in HAL_SD_GetCardCSD() argument
2160 pCSD->CSDStruct = (uint8_t)((hsd->CSD[0] & 0xC0000000U) >> 30U); in HAL_SD_GetCardCSD()
2162 pCSD->SysSpecVersion = (uint8_t)((hsd->CSD[0] & 0x3C000000U) >> 26U); in HAL_SD_GetCardCSD()
2164 pCSD->Reserved1 = (uint8_t)((hsd->CSD[0] & 0x03000000U) >> 24U); in HAL_SD_GetCardCSD()
2166 pCSD->TAAC = (uint8_t)((hsd->CSD[0] & 0x00FF0000U) >> 16U); in HAL_SD_GetCardCSD()
2168 pCSD->NSAC = (uint8_t)((hsd->CSD[0] & 0x0000FF00U) >> 8U); in HAL_SD_GetCardCSD()
2170 pCSD->MaxBusClkFrec = (uint8_t)(hsd->CSD[0] & 0x000000FFU); in HAL_SD_GetCardCSD()
2172 pCSD->CardComdClasses = (uint16_t)((hsd->CSD[1] & 0xFFF00000U) >> 20U); in HAL_SD_GetCardCSD()
2174 pCSD->RdBlockLen = (uint8_t)((hsd->CSD[1] & 0x000F0000U) >> 16U); in HAL_SD_GetCardCSD()
2176 pCSD->PartBlockRead = (uint8_t)((hsd->CSD[1] & 0x00008000U) >> 15U); in HAL_SD_GetCardCSD()
2178 pCSD->WrBlockMisalign = (uint8_t)((hsd->CSD[1] & 0x00004000U) >> 14U); in HAL_SD_GetCardCSD()
2180 pCSD->RdBlockMisalign = (uint8_t)((hsd->CSD[1] & 0x00002000U) >> 13U); in HAL_SD_GetCardCSD()
2182 pCSD->DSRImpl = (uint8_t)((hsd->CSD[1] & 0x00001000U) >> 12U); in HAL_SD_GetCardCSD()
2186 if (hsd->SdCard.CardType == CARD_SDSC) in HAL_SD_GetCardCSD()
2188 pCSD->DeviceSize = (((hsd->CSD[1] & 0x000003FFU) << 2U) | ((hsd->CSD[2] & 0xC0000000U) >> 30U)); in HAL_SD_GetCardCSD()
2190 pCSD->MaxRdCurrentVDDMin = (uint8_t)((hsd->CSD[2] & 0x38000000U) >> 27U); in HAL_SD_GetCardCSD()
2192 pCSD->MaxRdCurrentVDDMax = (uint8_t)((hsd->CSD[2] & 0x07000000U) >> 24U); in HAL_SD_GetCardCSD()
2194 pCSD->MaxWrCurrentVDDMin = (uint8_t)((hsd->CSD[2] & 0x00E00000U) >> 21U); in HAL_SD_GetCardCSD()
2196 pCSD->MaxWrCurrentVDDMax = (uint8_t)((hsd->CSD[2] & 0x001C0000U) >> 18U); in HAL_SD_GetCardCSD()
2198 pCSD->DeviceSizeMul = (uint8_t)((hsd->CSD[2] & 0x00038000U) >> 15U); in HAL_SD_GetCardCSD()
2200 hsd->SdCard.BlockNbr = (pCSD->DeviceSize + 1U) ; in HAL_SD_GetCardCSD()
2201 hsd->SdCard.BlockNbr *= (1UL << ((pCSD->DeviceSizeMul & 0x07U) + 2U)); in HAL_SD_GetCardCSD()
2202 hsd->SdCard.BlockSize = (1UL << (pCSD->RdBlockLen & 0x0FU)); in HAL_SD_GetCardCSD()
2204 hsd->SdCard.LogBlockNbr = (hsd->SdCard.BlockNbr) * ((hsd->SdCard.BlockSize) / BLOCKSIZE); in HAL_SD_GetCardCSD()
2205 hsd->SdCard.LogBlockSize = BLOCKSIZE; in HAL_SD_GetCardCSD()
2207 else if (hsd->SdCard.CardType == CARD_SDHC_SDXC) in HAL_SD_GetCardCSD()
2210 … pCSD->DeviceSize = (((hsd->CSD[1] & 0x0000003FU) << 16U) | ((hsd->CSD[2] & 0xFFFF0000U) >> 16U)); in HAL_SD_GetCardCSD()
2212 hsd->SdCard.BlockNbr = ((pCSD->DeviceSize + 1U) * 1024U); in HAL_SD_GetCardCSD()
2213 hsd->SdCard.LogBlockNbr = hsd->SdCard.BlockNbr; in HAL_SD_GetCardCSD()
2214 hsd->SdCard.BlockSize = BLOCKSIZE; in HAL_SD_GetCardCSD()
2215 hsd->SdCard.LogBlockSize = hsd->SdCard.BlockSize; in HAL_SD_GetCardCSD()
2220 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_GetCardCSD()
2221 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_GetCardCSD()
2222 hsd->State = HAL_SD_STATE_READY; in HAL_SD_GetCardCSD()
2226 pCSD->EraseGrSize = (uint8_t)((hsd->CSD[2] & 0x00004000U) >> 14U); in HAL_SD_GetCardCSD()
2228 pCSD->EraseGrMul = (uint8_t)((hsd->CSD[2] & 0x00003F80U) >> 7U); in HAL_SD_GetCardCSD()
2230 pCSD->WrProtectGrSize = (uint8_t)(hsd->CSD[2] & 0x0000007FU); in HAL_SD_GetCardCSD()
2232 pCSD->WrProtectGrEnable = (uint8_t)((hsd->CSD[3] & 0x80000000U) >> 31U); in HAL_SD_GetCardCSD()
2234 pCSD->ManDeflECC = (uint8_t)((hsd->CSD[3] & 0x60000000U) >> 29U); in HAL_SD_GetCardCSD()
2236 pCSD->WrSpeedFact = (uint8_t)((hsd->CSD[3] & 0x1C000000U) >> 26U); in HAL_SD_GetCardCSD()
2238 pCSD->MaxWrBlockLen = (uint8_t)((hsd->CSD[3] & 0x03C00000U) >> 22U); in HAL_SD_GetCardCSD()
2240 pCSD->WriteBlockPaPartial = (uint8_t)((hsd->CSD[3] & 0x00200000U) >> 21U); in HAL_SD_GetCardCSD()
2244 pCSD->ContentProtectAppli = (uint8_t)((hsd->CSD[3] & 0x00010000U) >> 16U); in HAL_SD_GetCardCSD()
2246 pCSD->FileFormatGroup = (uint8_t)((hsd->CSD[3] & 0x00008000U) >> 15U); in HAL_SD_GetCardCSD()
2248 pCSD->CopyFlag = (uint8_t)((hsd->CSD[3] & 0x00004000U) >> 14U); in HAL_SD_GetCardCSD()
2250 pCSD->PermWrProtect = (uint8_t)((hsd->CSD[3] & 0x00002000U) >> 13U); in HAL_SD_GetCardCSD()
2252 pCSD->TempWrProtect = (uint8_t)((hsd->CSD[3] & 0x00001000U) >> 12U); in HAL_SD_GetCardCSD()
2254 pCSD->FileFormat = (uint8_t)((hsd->CSD[3] & 0x00000C00U) >> 10U); in HAL_SD_GetCardCSD()
2256 pCSD->ECC = (uint8_t)((hsd->CSD[3] & 0x00000300U) >> 8U); in HAL_SD_GetCardCSD()
2258 pCSD->CSD_CRC = (uint8_t)((hsd->CSD[3] & 0x000000FEU) >> 1U); in HAL_SD_GetCardCSD()
2272 HAL_StatusTypeDef HAL_SD_GetCardStatus(SD_HandleTypeDef *hsd, HAL_SD_CardStatusTypeDef *pStatus) in HAL_SD_GetCardStatus() argument
2278 if (hsd->State == HAL_SD_STATE_BUSY) in HAL_SD_GetCardStatus()
2283 errorstate = SD_SendSDStatus(hsd, sd_status); in HAL_SD_GetCardStatus()
2287 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_GetCardStatus()
2288 hsd->ErrorCode |= errorstate; in HAL_SD_GetCardStatus()
2289 hsd->State = HAL_SD_STATE_READY; in HAL_SD_GetCardStatus()
2321 errorstate = SDMMC_CmdBlockLength(hsd->Instance, BLOCKSIZE); in HAL_SD_GetCardStatus()
2325 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_GetCardStatus()
2326 hsd->ErrorCode = errorstate; in HAL_SD_GetCardStatus()
2327 hsd->State = HAL_SD_STATE_READY; in HAL_SD_GetCardStatus()
2341 HAL_StatusTypeDef HAL_SD_GetCardInfo(const SD_HandleTypeDef *hsd, HAL_SD_CardInfoTypeDef *pCardInfo) in HAL_SD_GetCardInfo() argument
2343 pCardInfo->CardType = (uint32_t)(hsd->SdCard.CardType); in HAL_SD_GetCardInfo()
2344 pCardInfo->CardVersion = (uint32_t)(hsd->SdCard.CardVersion); in HAL_SD_GetCardInfo()
2345 pCardInfo->Class = (uint32_t)(hsd->SdCard.Class); in HAL_SD_GetCardInfo()
2346 pCardInfo->RelCardAdd = (uint32_t)(hsd->SdCard.RelCardAdd); in HAL_SD_GetCardInfo()
2347 pCardInfo->BlockNbr = (uint32_t)(hsd->SdCard.BlockNbr); in HAL_SD_GetCardInfo()
2348 pCardInfo->BlockSize = (uint32_t)(hsd->SdCard.BlockSize); in HAL_SD_GetCardInfo()
2349 pCardInfo->LogBlockNbr = (uint32_t)(hsd->SdCard.LogBlockNbr); in HAL_SD_GetCardInfo()
2350 pCardInfo->LogBlockSize = (uint32_t)(hsd->SdCard.LogBlockSize); in HAL_SD_GetCardInfo()
2366 HAL_StatusTypeDef HAL_SD_ConfigWideBusOperation(SD_HandleTypeDef *hsd, uint32_t WideMode) in HAL_SD_ConfigWideBusOperation() argument
2378 hsd->State = HAL_SD_STATE_BUSY; in HAL_SD_ConfigWideBusOperation()
2380 if (hsd->SdCard.CardType != CARD_SECURED) in HAL_SD_ConfigWideBusOperation()
2384 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigWideBusOperation()
2388 errorstate = SD_WideBus_Enable(hsd); in HAL_SD_ConfigWideBusOperation()
2390 hsd->ErrorCode |= errorstate; in HAL_SD_ConfigWideBusOperation()
2394 errorstate = SD_WideBus_Disable(hsd); in HAL_SD_ConfigWideBusOperation()
2396 hsd->ErrorCode |= errorstate; in HAL_SD_ConfigWideBusOperation()
2401 hsd->ErrorCode |= HAL_SD_ERROR_PARAM; in HAL_SD_ConfigWideBusOperation()
2407 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigWideBusOperation()
2410 if (hsd->ErrorCode != HAL_SD_ERROR_NONE) in HAL_SD_ConfigWideBusOperation()
2413 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_ConfigWideBusOperation()
2418 if (hsd->Instance == SDMMC1) in HAL_SD_ConfigWideBusOperation()
2429 Init.ClockEdge = hsd->Init.ClockEdge; in HAL_SD_ConfigWideBusOperation()
2430 Init.ClockPowerSave = hsd->Init.ClockPowerSave; in HAL_SD_ConfigWideBusOperation()
2432 Init.HardwareFlowControl = hsd->Init.HardwareFlowControl; in HAL_SD_ConfigWideBusOperation()
2435 if (hsd->Init.ClockDiv >= (sdmmc_clk / (2U * SD_NORMAL_SPEED_FREQ))) in HAL_SD_ConfigWideBusOperation()
2437 Init.ClockDiv = hsd->Init.ClockDiv; in HAL_SD_ConfigWideBusOperation()
2439 else if (hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) in HAL_SD_ConfigWideBusOperation()
2442 Init.ClockDiv = hsd->Init.ClockDiv; in HAL_SD_ConfigWideBusOperation()
2444 else if (hsd->SdCard.CardSpeed == CARD_HIGH_SPEED) in HAL_SD_ConfigWideBusOperation()
2447 if (hsd->Init.ClockDiv == 0U) in HAL_SD_ConfigWideBusOperation()
2455 Init.ClockDiv = hsd->Init.ClockDiv; in HAL_SD_ConfigWideBusOperation()
2460 if ((sdmmc_clk / (2U * hsd->Init.ClockDiv)) > SD_HIGH_SPEED_FREQ) in HAL_SD_ConfigWideBusOperation()
2466 Init.ClockDiv = hsd->Init.ClockDiv; in HAL_SD_ConfigWideBusOperation()
2473 if (hsd->Init.ClockDiv == 0U) in HAL_SD_ConfigWideBusOperation()
2481 Init.ClockDiv = hsd->Init.ClockDiv; in HAL_SD_ConfigWideBusOperation()
2486 if ((sdmmc_clk / (2U * hsd->Init.ClockDiv)) > SD_NORMAL_SPEED_FREQ) in HAL_SD_ConfigWideBusOperation()
2492 Init.ClockDiv = hsd->Init.ClockDiv; in HAL_SD_ConfigWideBusOperation()
2498 Init.TranceiverPresent = hsd->Init.TranceiverPresent; in HAL_SD_ConfigWideBusOperation()
2501 (void)SDMMC_Init(hsd->Instance, Init); in HAL_SD_ConfigWideBusOperation()
2505 hsd->ErrorCode |= SDMMC_ERROR_INVALID_PARAMETER; in HAL_SD_ConfigWideBusOperation()
2511 errorstate = SDMMC_CmdBlockLength(hsd->Instance, BLOCKSIZE); in HAL_SD_ConfigWideBusOperation()
2515 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_ConfigWideBusOperation()
2516 hsd->ErrorCode |= errorstate; in HAL_SD_ConfigWideBusOperation()
2521 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ConfigWideBusOperation()
2538 HAL_StatusTypeDef HAL_SD_ConfigSpeedBusOperation(SD_HandleTypeDef *hsd, uint32_t SpeedMode) in HAL_SD_ConfigSpeedBusOperation() argument
2547 hsd->State = HAL_SD_STATE_BUSY; in HAL_SD_ConfigSpeedBusOperation()
2550 if (hsd->Init.TranceiverPresent == SDMMC_TRANSCEIVER_PRESENT) in HAL_SD_ConfigSpeedBusOperation()
2556 if ((hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2557 (hsd->SdCard.CardType == CARD_SDHC_SDXC)) in HAL_SD_ConfigSpeedBusOperation()
2559 hsd->Instance->CLKCR |= SDMMC_CLKCR_BUSSPEED; in HAL_SD_ConfigSpeedBusOperation()
2561 if (SD_UltraHighSpeed(hsd, SDMMC_SDR104_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2563 if (SD_SwitchSpeed(hsd, SDMMC_SDR25_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2565 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2570 else if (hsd->SdCard.CardSpeed == CARD_HIGH_SPEED) in HAL_SD_ConfigSpeedBusOperation()
2573 if (SD_SwitchSpeed(hsd, SDMMC_SDR25_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2575 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2587 if ((hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2588 (hsd->SdCard.CardType == CARD_SDHC_SDXC)) in HAL_SD_ConfigSpeedBusOperation()
2591 if (SD_UltraHighSpeed(hsd, SDMMC_SDR104_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2593 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2596 hsd->Instance->CLKCR |= SDMMC_CLKCR_BUSSPEED; in HAL_SD_ConfigSpeedBusOperation()
2600 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2607 if ((hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2608 (hsd->SdCard.CardType == CARD_SDHC_SDXC)) in HAL_SD_ConfigSpeedBusOperation()
2611 if (SD_UltraHighSpeed(hsd, SDMMC_SDR50_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2613 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2616 hsd->Instance->CLKCR |= SDMMC_CLKCR_BUSSPEED; in HAL_SD_ConfigSpeedBusOperation()
2620 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2627 if ((hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2628 (hsd->SdCard.CardType == CARD_SDHC_SDXC)) in HAL_SD_ConfigSpeedBusOperation()
2631 if (SD_DDR_Mode(hsd) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2633 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2636 hsd->Instance->CLKCR |= SDMMC_CLKCR_BUSSPEED | SDMMC_CLKCR_DDR; in HAL_SD_ConfigSpeedBusOperation()
2640 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2647 if ((hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2648 (hsd->SdCard.CardSpeed == CARD_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2649 (hsd->SdCard.CardType == CARD_SDHC_SDXC)) in HAL_SD_ConfigSpeedBusOperation()
2652 if (SD_SwitchSpeed(hsd, SDMMC_SDR25_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2654 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2660 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2668 if (SD_SwitchSpeed(hsd, SDMMC_SDR12_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2670 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2677 hsd->ErrorCode |= HAL_SD_ERROR_PARAM; in HAL_SD_ConfigSpeedBusOperation()
2688 if ((hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2689 (hsd->SdCard.CardSpeed == CARD_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2690 (hsd->SdCard.CardType == CARD_SDHC_SDXC)) in HAL_SD_ConfigSpeedBusOperation()
2693 if (SD_SwitchSpeed(hsd, SDMMC_SDR25_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2695 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2707 if ((hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2708 (hsd->SdCard.CardSpeed == CARD_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2709 (hsd->SdCard.CardType == CARD_SDHC_SDXC)) in HAL_SD_ConfigSpeedBusOperation()
2712 if (SD_SwitchSpeed(hsd, SDMMC_SDR25_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2714 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2720 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2728 if (SD_SwitchSpeed(hsd, SDMMC_SDR12_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2730 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2738 hsd->ErrorCode |= HAL_SD_ERROR_PARAM; in HAL_SD_ConfigSpeedBusOperation()
2748 if ((hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2749 (hsd->SdCard.CardSpeed == CARD_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2750 (hsd->SdCard.CardType == CARD_SDHC_SDXC)) in HAL_SD_ConfigSpeedBusOperation()
2753 if (SD_SwitchSpeed(hsd, SDMMC_SDR25_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2755 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2767 if ((hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2768 (hsd->SdCard.CardSpeed == CARD_HIGH_SPEED) || in HAL_SD_ConfigSpeedBusOperation()
2769 (hsd->SdCard.CardType == CARD_SDHC_SDXC)) in HAL_SD_ConfigSpeedBusOperation()
2772 if (SD_SwitchSpeed(hsd, SDMMC_SDR25_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2774 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2780 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2788 if (SD_SwitchSpeed(hsd, SDMMC_SDR12_SWITCH_PATTERN) != HAL_SD_ERROR_NONE) in HAL_SD_ConfigSpeedBusOperation()
2790 hsd->ErrorCode |= HAL_SD_ERROR_UNSUPPORTED_FEATURE; in HAL_SD_ConfigSpeedBusOperation()
2798 hsd->ErrorCode |= HAL_SD_ERROR_PARAM; in HAL_SD_ConfigSpeedBusOperation()
2806 while ((HAL_SD_GetCardState(hsd) != HAL_SD_CARD_TRANSFER)) in HAL_SD_ConfigSpeedBusOperation()
2810 hsd->ErrorCode = HAL_SD_ERROR_TIMEOUT; in HAL_SD_ConfigSpeedBusOperation()
2811 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ConfigSpeedBusOperation()
2817 errorstate = SDMMC_CmdBlockLength(hsd->Instance, BLOCKSIZE); in HAL_SD_ConfigSpeedBusOperation()
2821 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_FLAGS); in HAL_SD_ConfigSpeedBusOperation()
2822 hsd->ErrorCode |= errorstate; in HAL_SD_ConfigSpeedBusOperation()
2827 hsd->State = HAL_SD_STATE_READY; in HAL_SD_ConfigSpeedBusOperation()
2836 HAL_SD_CardStateTypeDef HAL_SD_GetCardState(SD_HandleTypeDef *hsd) in HAL_SD_GetCardState() argument
2842 errorstate = SD_SendStatus(hsd, &resp1); in HAL_SD_GetCardState()
2845 hsd->ErrorCode |= errorstate; in HAL_SD_GetCardState()
2859 HAL_StatusTypeDef HAL_SD_Abort(SD_HandleTypeDef *hsd) in HAL_SD_Abort() argument
2864 if (hsd->State == HAL_SD_STATE_BUSY) in HAL_SD_Abort()
2867 __HAL_SD_DISABLE_IT(hsd, SDMMC_IT_DATAEND | SDMMC_IT_DCRCFAIL | SDMMC_IT_DTIMEOUT | \ in HAL_SD_Abort()
2869 __SDMMC_CMDTRANS_DISABLE(hsd->Instance); in HAL_SD_Abort()
2877 hsd->ErrorCode = SDMMC_CmdStopTransfer(hsd->Instance); in HAL_SD_Abort()
2878 error_code = hsd->ErrorCode; in HAL_SD_Abort()
2885 if ((hsd->Instance->DCTRL & SDMMC_DCTRL_DTDIR) == SDMMC_TRANSFER_DIR_TO_CARD) in HAL_SD_Abort()
2887 if (hsd->ErrorCode == HAL_SD_ERROR_NONE) in HAL_SD_Abort()
2889 while (!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DABORT | SDMMC_FLAG_BUSYD0END)) in HAL_SD_Abort()
2893 hsd->ErrorCode = HAL_SD_ERROR_TIMEOUT; in HAL_SD_Abort()
2894 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Abort()
2900 if (hsd->ErrorCode == HAL_SD_ERROR_CMD_RSP_TIMEOUT) in HAL_SD_Abort()
2902 while (!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DATAEND)) in HAL_SD_Abort()
2906 hsd->ErrorCode = HAL_SD_ERROR_TIMEOUT; in HAL_SD_Abort()
2907 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Abort()
2913 else if ((hsd->Instance->DCTRL & SDMMC_DCTRL_DTDIR) == SDMMC_TRANSFER_DIR_TO_SDMMC) in HAL_SD_Abort()
2915 while (!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DABORT | SDMMC_FLAG_DATAEND)) in HAL_SD_Abort()
2919 hsd->ErrorCode = HAL_SD_ERROR_TIMEOUT; in HAL_SD_Abort()
2920 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Abort()
2936 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_BUSYD0END); in HAL_SD_Abort()
2937 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_DATA_FLAGS); in HAL_SD_Abort()
2939 hsd->Instance->IDMACTRL = SDMMC_DISABLE_IDMA; in HAL_SD_Abort()
2941 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Abort()
2944 hsd->Context = SD_CONTEXT_NONE; in HAL_SD_Abort()
2955 HAL_StatusTypeDef HAL_SD_Abort_IT(SD_HandleTypeDef *hsd) in HAL_SD_Abort_IT() argument
2960 __HAL_SD_DISABLE_IT(hsd, SDMMC_IT_DATAEND | SDMMC_IT_DCRCFAIL | SDMMC_IT_DTIMEOUT | \ in HAL_SD_Abort_IT()
2964 hsd->Instance->IDMACTRL = SDMMC_DISABLE_IDMA; in HAL_SD_Abort_IT()
2967 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_DATA_FLAGS); in HAL_SD_Abort_IT()
2969 CardState = HAL_SD_GetCardState(hsd); in HAL_SD_Abort_IT()
2970 hsd->State = HAL_SD_STATE_READY; in HAL_SD_Abort_IT()
2974 hsd->ErrorCode = SDMMC_CmdStopTransfer(hsd->Instance); in HAL_SD_Abort_IT()
2977 if (hsd->ErrorCode != HAL_SD_ERROR_NONE) in HAL_SD_Abort_IT()
2984 hsd->AbortCpltCallback(hsd); in HAL_SD_Abort_IT()
2986 HAL_SD_AbortCallback(hsd); in HAL_SD_Abort_IT()
3011 static uint32_t SD_InitCard(SD_HandleTypeDef *hsd) in SD_InitCard() argument
3019 if (SDMMC_GetPowerState(hsd->Instance) == 0U) in SD_InitCard()
3025 if (hsd->SdCard.CardType != CARD_SECURED) in SD_InitCard()
3028 errorstate = SDMMC_CmdSendCID(hsd->Instance); in SD_InitCard()
3036 hsd->CID[0U] = SDMMC_GetResponse(hsd->Instance, SDMMC_RESP1); in SD_InitCard()
3037 hsd->CID[1U] = SDMMC_GetResponse(hsd->Instance, SDMMC_RESP2); in SD_InitCard()
3038 hsd->CID[2U] = SDMMC_GetResponse(hsd->Instance, SDMMC_RESP3); in SD_InitCard()
3039 hsd->CID[3U] = SDMMC_GetResponse(hsd->Instance, SDMMC_RESP4); in SD_InitCard()
3043 if (hsd->SdCard.CardType != CARD_SECURED) in SD_InitCard()
3049 errorstate = SDMMC_CmdSetRelAdd(hsd->Instance, &sd_rca); in SD_InitCard()
3060 if (hsd->SdCard.CardType != CARD_SECURED) in SD_InitCard()
3063 hsd->SdCard.RelCardAdd = sd_rca; in SD_InitCard()
3066 errorstate = SDMMC_CmdSendCSD(hsd->Instance, (uint32_t)(hsd->SdCard.RelCardAdd << 16U)); in SD_InitCard()
3074 hsd->CSD[0U] = SDMMC_GetResponse(hsd->Instance, SDMMC_RESP1); in SD_InitCard()
3075 hsd->CSD[1U] = SDMMC_GetResponse(hsd->Instance, SDMMC_RESP2); in SD_InitCard()
3076 hsd->CSD[2U] = SDMMC_GetResponse(hsd->Instance, SDMMC_RESP3); in SD_InitCard()
3077 hsd->CSD[3U] = SDMMC_GetResponse(hsd->Instance, SDMMC_RESP4); in SD_InitCard()
3082 hsd->SdCard.Class = (SDMMC_GetResponse(hsd->Instance, SDMMC_RESP2) >> 20U); in SD_InitCard()
3085 if (HAL_SD_GetCardCSD(hsd, &CSD) != HAL_OK) in SD_InitCard()
3091 …errorstate = SDMMC_CmdSelDesel(hsd->Instance, (uint32_t)(((uint32_t)hsd->SdCard.RelCardAdd) << 16U… in SD_InitCard()
3108 static uint32_t SD_PowerON(SD_HandleTypeDef *hsd) in SD_PowerON() argument
3119 errorstate = SDMMC_CmdGoIdleState(hsd->Instance); in SD_PowerON()
3126 errorstate = SDMMC_CmdOperCond(hsd->Instance); in SD_PowerON()
3129 hsd->SdCard.CardVersion = CARD_V1_X; in SD_PowerON()
3131 errorstate = SDMMC_CmdGoIdleState(hsd->Instance); in SD_PowerON()
3140 hsd->SdCard.CardVersion = CARD_V2_X; in SD_PowerON()
3143 if (hsd->SdCard.CardVersion == CARD_V2_X) in SD_PowerON()
3146 errorstate = SDMMC_CmdAppCommand(hsd->Instance, 0); in SD_PowerON()
3157 errorstate = SDMMC_CmdAppCommand(hsd->Instance, 0); in SD_PowerON()
3164 …errorstate = SDMMC_CmdAppOperCommand(hsd->Instance, SDMMC_VOLTAGE_WINDOW_SD | SDMMC_HIGH_CAPACITY | in SD_PowerON()
3172 response = SDMMC_GetResponse(hsd->Instance, SDMMC_RESP1); in SD_PowerON()
3186 hsd->SdCard.CardType = CARD_SDSC; in SD_PowerON()
3190 hsd->SdCard.CardType = CARD_SDHC_SDXC; in SD_PowerON()
3192 if (hsd->Init.TranceiverPresent == SDMMC_TRANSCEIVER_PRESENT) in SD_PowerON()
3196 hsd->SdCard.CardSpeed = CARD_ULTRA_HIGH_SPEED; in SD_PowerON()
3199 hsd->Instance->POWER |= SDMMC_POWER_VSWITCHEN; in SD_PowerON()
3202 errorstate = SDMMC_CmdVoltageSwitch(hsd->Instance); in SD_PowerON()
3209 while ((hsd->Instance->STA & SDMMC_FLAG_CKSTOP) != SDMMC_FLAG_CKSTOP) in SD_PowerON()
3218 hsd->Instance->ICR = SDMMC_FLAG_CKSTOP; in SD_PowerON()
3221 if ((hsd->Instance->STA & SDMMC_FLAG_BUSYD0) != SDMMC_FLAG_BUSYD0) in SD_PowerON()
3230 hsd->DriveTransceiver_1_8V_Callback(SET); in SD_PowerON()
3236 hsd->Instance->POWER |= SDMMC_POWER_VSWITCH; in SD_PowerON()
3239 while ((hsd->Instance->STA & SDMMC_FLAG_VSWEND) != SDMMC_FLAG_VSWEND) in SD_PowerON()
3248 hsd->Instance->ICR = SDMMC_FLAG_VSWEND; in SD_PowerON()
3251 if ((hsd->Instance->STA & SDMMC_FLAG_BUSYD0) == SDMMC_FLAG_BUSYD0) in SD_PowerON()
3259 hsd->Instance->POWER = 0x13U; in SD_PowerON()
3262 hsd->Instance->ICR = 0xFFFFFFFFU; in SD_PowerON()
3277 static void SD_PowerOFF(SD_HandleTypeDef *hsd) in SD_PowerOFF() argument
3280 (void)SDMMC_PowerState_OFF(hsd->Instance); in SD_PowerOFF()
3290 static uint32_t SD_SendSDStatus(SD_HandleTypeDef *hsd, uint32_t *pSDstatus) in SD_SendSDStatus() argument
3299 if ((SDMMC_GetResponse(hsd->Instance, SDMMC_RESP1) & SDMMC_CARD_LOCKED) == SDMMC_CARD_LOCKED) in SD_SendSDStatus()
3305 errorstate = SDMMC_CmdBlockLength(hsd->Instance, 64U); in SD_SendSDStatus()
3308 hsd->ErrorCode |= HAL_SD_ERROR_NONE; in SD_SendSDStatus()
3313 errorstate = SDMMC_CmdAppCommand(hsd->Instance, (uint32_t)(hsd->SdCard.RelCardAdd << 16U)); in SD_SendSDStatus()
3316 hsd->ErrorCode |= HAL_SD_ERROR_NONE; in SD_SendSDStatus()
3327 (void)SDMMC_ConfigData(hsd->Instance, &config); in SD_SendSDStatus()
3330 errorstate = SDMMC_CmdStatusRegister(hsd->Instance); in SD_SendSDStatus()
3333 hsd->ErrorCode |= HAL_SD_ERROR_NONE; in SD_SendSDStatus()
3338 …while (!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR | SDMMC_FLAG_DCRCFAIL | SDMMC_FLAG_DTIMEOUT | SD… in SD_SendSDStatus()
3340 if ((!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXFIFOE)) && (count < 16U)) in SD_SendSDStatus()
3342 *pData = SDMMC_ReadFIFO(hsd->Instance); in SD_SendSDStatus()
3353 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DTIMEOUT)) in SD_SendSDStatus()
3357 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DCRCFAIL)) in SD_SendSDStatus()
3361 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR)) in SD_SendSDStatus()
3370 while ((__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DPSMACT))) in SD_SendSDStatus()
3372 *pData = SDMMC_ReadFIFO(hsd->Instance); in SD_SendSDStatus()
3382 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_DATA_FLAGS); in SD_SendSDStatus()
3394 static uint32_t SD_SendStatus(SD_HandleTypeDef *hsd, uint32_t *pCardStatus) in SD_SendStatus() argument
3404 errorstate = SDMMC_CmdSendStatus(hsd->Instance, (uint32_t)(hsd->SdCard.RelCardAdd << 16U)); in SD_SendStatus()
3411 *pCardStatus = SDMMC_GetResponse(hsd->Instance, SDMMC_RESP1); in SD_SendStatus()
3421 static uint32_t SD_WideBus_Enable(SD_HandleTypeDef *hsd) in SD_WideBus_Enable() argument
3426 if ((SDMMC_GetResponse(hsd->Instance, SDMMC_RESP1) & SDMMC_CARD_LOCKED) == SDMMC_CARD_LOCKED) in SD_WideBus_Enable()
3432 errorstate = SD_FindSCR(hsd, scr); in SD_WideBus_Enable()
3442 errorstate = SDMMC_CmdAppCommand(hsd->Instance, (uint32_t)(hsd->SdCard.RelCardAdd << 16U)); in SD_WideBus_Enable()
3449 errorstate = SDMMC_CmdBusWidth(hsd->Instance, 2U); in SD_WideBus_Enable()
3468 static uint32_t SD_WideBus_Disable(SD_HandleTypeDef *hsd) in SD_WideBus_Disable() argument
3473 if ((SDMMC_GetResponse(hsd->Instance, SDMMC_RESP1) & SDMMC_CARD_LOCKED) == SDMMC_CARD_LOCKED) in SD_WideBus_Disable()
3479 errorstate = SD_FindSCR(hsd, scr); in SD_WideBus_Disable()
3489 errorstate = SDMMC_CmdAppCommand(hsd->Instance, (uint32_t)(hsd->SdCard.RelCardAdd << 16U)); in SD_WideBus_Disable()
3496 errorstate = SDMMC_CmdBusWidth(hsd->Instance, 0U); in SD_WideBus_Disable()
3516 static uint32_t SD_FindSCR(SD_HandleTypeDef *hsd, uint32_t *pSCR) in SD_FindSCR() argument
3526 errorstate = SDMMC_CmdBlockLength(hsd->Instance, 8U); in SD_FindSCR()
3533 errorstate = SDMMC_CmdAppCommand(hsd->Instance, (uint32_t)((hsd->SdCard.RelCardAdd) << 16U)); in SD_FindSCR()
3545 (void)SDMMC_ConfigData(hsd->Instance, &config); in SD_FindSCR()
3548 errorstate = SDMMC_CmdSendSCR(hsd->Instance); in SD_FindSCR()
3554 …while (!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR | SDMMC_FLAG_DCRCFAIL | SDMMC_FLAG_DTIMEOUT | SD… in SD_FindSCR()
3557 if ((!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXFIFOE)) && (index == 0U)) in SD_FindSCR()
3559 tempscr[0] = SDMMC_ReadFIFO(hsd->Instance); in SD_FindSCR()
3560 tempscr[1] = SDMMC_ReadFIFO(hsd->Instance); in SD_FindSCR()
3570 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DTIMEOUT)) in SD_FindSCR()
3572 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_DTIMEOUT); in SD_FindSCR()
3576 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DCRCFAIL)) in SD_FindSCR()
3578 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_DCRCFAIL); in SD_FindSCR()
3582 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR)) in SD_FindSCR()
3584 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_RXOVERR); in SD_FindSCR()
3592 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_DATA_FLAGS); in SD_FindSCR()
3611 static void SD_Read_IT(SD_HandleTypeDef *hsd) in SD_Read_IT() argument
3617 tmp = hsd->pRxBuffPtr; in SD_Read_IT()
3619 if (hsd->RxXferSize >= SDMMC_FIFO_SIZE) in SD_Read_IT()
3624 data = SDMMC_ReadFIFO(hsd->Instance); in SD_Read_IT()
3635 hsd->pRxBuffPtr = tmp; in SD_Read_IT()
3636 hsd->RxXferSize -= SDMMC_FIFO_SIZE; in SD_Read_IT()
3646 static void SD_Write_IT(SD_HandleTypeDef *hsd) in SD_Write_IT() argument
3652 tmp = hsd->pTxBuffPtr; in SD_Write_IT()
3654 if (hsd->TxXferSize >= SDMMC_FIFO_SIZE) in SD_Write_IT()
3667 (void)SDMMC_WriteFIFO(hsd->Instance, &data); in SD_Write_IT()
3670 hsd->pTxBuffPtr = tmp; in SD_Write_IT()
3671 hsd->TxXferSize -= SDMMC_FIFO_SIZE; in SD_Write_IT()
3684 uint32_t SD_SwitchSpeed(SD_HandleTypeDef *hsd, uint32_t SwitchSpeedMode) in SD_SwitchSpeed() argument
3692 if (hsd->SdCard.CardSpeed == CARD_NORMAL_SPEED) in SD_SwitchSpeed()
3698 if (hsd->SdCard.CardSpeed >= CARD_HIGH_SPEED) in SD_SwitchSpeed()
3701 hsd->Instance->DCTRL = 0; in SD_SwitchSpeed()
3702 errorstate = SDMMC_CmdBlockLength(hsd->Instance, 64U); in SD_SwitchSpeed()
3717 (void)SDMMC_ConfigData(hsd->Instance, &sdmmc_datainitstructure); in SD_SwitchSpeed()
3719 errorstate = SDMMC_CmdSwitch(hsd->Instance, SwitchSpeedMode); in SD_SwitchSpeed()
3725 …while (!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR | SDMMC_FLAG_DCRCFAIL | SDMMC_FLAG_DTIMEOUT | SD… in SD_SwitchSpeed()
3728 if ((!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXFIFOE)) && (count < 16U)) in SD_SwitchSpeed()
3730 SD_hs[count] = SDMMC_ReadFIFO(hsd->Instance); in SD_SwitchSpeed()
3735 hsd->ErrorCode = HAL_SD_ERROR_TIMEOUT; in SD_SwitchSpeed()
3736 hsd->State = HAL_SD_STATE_READY; in SD_SwitchSpeed()
3741 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DTIMEOUT)) in SD_SwitchSpeed()
3743 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_DTIMEOUT); in SD_SwitchSpeed()
3747 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DCRCFAIL)) in SD_SwitchSpeed()
3749 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_DCRCFAIL); in SD_SwitchSpeed()
3755 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR)) in SD_SwitchSpeed()
3757 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_RXOVERR); in SD_SwitchSpeed()
3769 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_DATA_FLAGS); in SD_SwitchSpeed()
3792 static uint32_t SD_UltraHighSpeed(SD_HandleTypeDef *hsd, uint32_t UltraHighSpeedMode) in SD_UltraHighSpeed() argument
3801 if (hsd->SdCard.CardSpeed == CARD_NORMAL_SPEED) in SD_UltraHighSpeed()
3807 if (hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) in SD_UltraHighSpeed()
3810 hsd->Instance->DCTRL = 0; in SD_UltraHighSpeed()
3811 errorstate = SDMMC_CmdBlockLength(hsd->Instance, 64U); in SD_UltraHighSpeed()
3826 if (SDMMC_ConfigData(hsd->Instance, &sdmmc_datainitstructure) != HAL_OK) in SD_UltraHighSpeed()
3831 errorstate = SDMMC_CmdSwitch(hsd->Instance, UltraHighSpeedMode); in SD_UltraHighSpeed()
3837 …while (!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR | SDMMC_FLAG_DCRCFAIL | SDMMC_FLAG_DTIMEOUT | SD… in SD_UltraHighSpeed()
3840 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXFIFOHF)) in SD_UltraHighSpeed()
3844 SD_hs[(8U * loop) + count] = SDMMC_ReadFIFO(hsd->Instance); in SD_UltraHighSpeed()
3851 hsd->ErrorCode = HAL_SD_ERROR_TIMEOUT; in SD_UltraHighSpeed()
3852 hsd->State = HAL_SD_STATE_READY; in SD_UltraHighSpeed()
3857 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DTIMEOUT)) in SD_UltraHighSpeed()
3859 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_DTIMEOUT); in SD_UltraHighSpeed()
3863 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DCRCFAIL)) in SD_UltraHighSpeed()
3865 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_DCRCFAIL); in SD_UltraHighSpeed()
3871 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR)) in SD_UltraHighSpeed()
3873 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_RXOVERR); in SD_UltraHighSpeed()
3885 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_DATA_FLAGS); in SD_UltraHighSpeed()
3895 hsd->DriveTransceiver_1_8V_Callback(SET); in SD_UltraHighSpeed()
3902 MODIFY_REG(hsd->Instance->CLKCR, SDMMC_CLKCR_SELCLKRX, SDMMC_CLKCR_SELCLKRX_1); in SD_UltraHighSpeed()
3903 LL_DLYB_Enable(SD_GET_DLYB_INSTANCE(hsd->Instance)); in SD_UltraHighSpeed()
3919 static uint32_t SD_DDR_Mode(SD_HandleTypeDef *hsd) in SD_DDR_Mode() argument
3928 if (hsd->SdCard.CardSpeed == CARD_NORMAL_SPEED) in SD_DDR_Mode()
3934 if (hsd->SdCard.CardSpeed == CARD_ULTRA_HIGH_SPEED) in SD_DDR_Mode()
3937 hsd->Instance->DCTRL = 0; in SD_DDR_Mode()
3938 errorstate = SDMMC_CmdBlockLength(hsd->Instance, 64U); in SD_DDR_Mode()
3953 if (SDMMC_ConfigData(hsd->Instance, &sdmmc_datainitstructure) != HAL_OK) in SD_DDR_Mode()
3958 errorstate = SDMMC_CmdSwitch(hsd->Instance, SDMMC_DDR50_SWITCH_PATTERN); in SD_DDR_Mode()
3964 …while (!__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR | SDMMC_FLAG_DCRCFAIL | SDMMC_FLAG_DTIMEOUT | SD… in SD_DDR_Mode()
3967 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXFIFOHF)) in SD_DDR_Mode()
3971 SD_hs[(8U * loop) + count] = SDMMC_ReadFIFO(hsd->Instance); in SD_DDR_Mode()
3978 hsd->ErrorCode = HAL_SD_ERROR_TIMEOUT; in SD_DDR_Mode()
3979 hsd->State = HAL_SD_STATE_READY; in SD_DDR_Mode()
3984 if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DTIMEOUT)) in SD_DDR_Mode()
3986 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_DTIMEOUT); in SD_DDR_Mode()
3990 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_DCRCFAIL)) in SD_DDR_Mode()
3992 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_DCRCFAIL); in SD_DDR_Mode()
3998 else if (__HAL_SD_GET_FLAG(hsd, SDMMC_FLAG_RXOVERR)) in SD_DDR_Mode()
4000 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_FLAG_RXOVERR); in SD_DDR_Mode()
4012 __HAL_SD_CLEAR_FLAG(hsd, SDMMC_STATIC_DATA_FLAGS); in SD_DDR_Mode()
4022 hsd->DriveTransceiver_1_8V_Callback(SET); in SD_DDR_Mode()
4029 MODIFY_REG(hsd->Instance->CLKCR, SDMMC_CLKCR_SELCLKRX, SDMMC_CLKCR_SELCLKRX_0); in SD_DDR_Mode()
4030 LL_DLYB_Enable(SD_GET_DLYB_INSTANCE(hsd->Instance)); in SD_DDR_Mode()
4045 __weak void HAL_SDEx_Read_DMALnkLstBufCpltCallback(SD_HandleTypeDef *hsd) in HAL_SDEx_Read_DMALnkLstBufCpltCallback() argument
4048 UNUSED(hsd); in HAL_SDEx_Read_DMALnkLstBufCpltCallback()
4059 __weak void HAL_SDEx_Write_DMALnkLstBufCpltCallback(SD_HandleTypeDef *hsd) in HAL_SDEx_Write_DMALnkLstBufCpltCallback() argument
4062 UNUSED(hsd); in HAL_SDEx_Write_DMALnkLstBufCpltCallback()