123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258 |
- /*
- * Copyright (c) 2015, Freescale Semiconductor, Inc.
- * Copyright 2016-2018 NXP
- * All rights reserved.
- *
- * SPDX-License-Identifier: BSD-3-Clause
- */
- #ifndef _FSL_SDMMC_COMMON_H_
- #define _FSL_SDMMC_COMMON_H_
- #include "fsl_common.h"
- #include "fsl_sdmmc_host.h"
- #include "fsl_sdmmc_spec.h"
- #include "stdlib.h"
- /*!
- * @addtogroup CARD
- * @{
- */
- /*******************************************************************************
- * Definitions
- ******************************************************************************/
- /*! @brief Middleware version. */
- #define FSL_SDMMC_DRIVER_VERSION (MAKE_VERSION(2U, 2U, 11U)) /*2.2.11*/
- /*! @brief Reverse byte sequence in uint32_t */
- #define SWAP_WORD_BYTE_SEQUENCE(x) (__REV(x))
- /*! @brief Reverse byte sequence for each half word in uint32_t */
- #define SWAP_HALF_WROD_BYTE_SEQUENCE(x) (__REV16(x))
- /*! @brief Maximum loop count to check the card operation voltage range */
- #define FSL_SDMMC_MAX_VOLTAGE_RETRIES (1000U)
- /*! @brief Maximum loop count to send the cmd */
- #define FSL_SDMMC_MAX_CMD_RETRIES (10U)
- /*! @brief Default block size */
- #define FSL_SDMMC_DEFAULT_BLOCK_SIZE (512U)
- #ifndef SDMMC_GLOBAL_BUFFER_SIZE
- /*! @brief SDMMC global data buffer size, word unit*/
- #define SDMMC_GLOBAL_BUFFER_SIZE (128U)
- #endif
- /*! @brief SDMMC enable software tuning */
- #define SDMMC_ENABLE_SOFTWARE_TUNING (0U)
- /* Common definition for cache line size align */
- #if defined(FSL_SDK_ENABLE_DRIVER_CACHE_CONTROL) && FSL_SDK_ENABLE_DRIVER_CACHE_CONTROL
- #if defined(FSL_FEATURE_L1DCACHE_LINESIZE_BYTE)
- #if defined(FSL_FEATURE_L2DCACHE_LINESIZE_BYTE)
- #define SDMMC_DATA_BUFFER_ALIGN_CACHE MAX(FSL_FEATURE_L1DCACHE_LINESIZE_BYTE, FSL_FEATURE_L2DCACHE_LINESIZE_BYTE)
- #else
- #define SDMMC_DATA_BUFFER_ALIGN_CACHE FSL_FEATURE_L1DCACHE_LINESIZE_BYTE
- #endif
- #else
- #define SDMMC_DATA_BUFFER_ALIGN_CACHE 1
- #endif
- #else
- #define SDMMC_DATA_BUFFER_ALIGN_CACHE 1
- #endif
- /*! @brief SD/MMC error log. */
- #if defined SDMMC_ENABLE_LOG_PRINT
- #include "fsl_debug_console.h"
- #define SDMMC_LOG(...) PRINTF(__VA_ARGS__)
- #else
- #define SDMMC_LOG(format, ...)
- #endif
- /*! @brief SD/MMC card API's running status. */
- enum _sdmmc_status
- {
- kStatus_SDMMC_NotSupportYet = MAKE_STATUS(kStatusGroup_SDMMC, 0U), /*!< Haven't supported */
- kStatus_SDMMC_TransferFailed = MAKE_STATUS(kStatusGroup_SDMMC, 1U), /*!< Send command failed */
- kStatus_SDMMC_SetCardBlockSizeFailed = MAKE_STATUS(kStatusGroup_SDMMC, 2U), /*!< Set block size failed */
- kStatus_SDMMC_HostNotSupport = MAKE_STATUS(kStatusGroup_SDMMC, 3U), /*!< Host doesn't support */
- kStatus_SDMMC_CardNotSupport = MAKE_STATUS(kStatusGroup_SDMMC, 4U), /*!< Card doesn't support */
- kStatus_SDMMC_AllSendCidFailed = MAKE_STATUS(kStatusGroup_SDMMC, 5U), /*!< Send CID failed */
- kStatus_SDMMC_SendRelativeAddressFailed = MAKE_STATUS(kStatusGroup_SDMMC, 6U), /*!< Send relative address failed */
- kStatus_SDMMC_SendCsdFailed = MAKE_STATUS(kStatusGroup_SDMMC, 7U), /*!< Send CSD failed */
- kStatus_SDMMC_SelectCardFailed = MAKE_STATUS(kStatusGroup_SDMMC, 8U), /*!< Select card failed */
- kStatus_SDMMC_SendScrFailed = MAKE_STATUS(kStatusGroup_SDMMC, 9U), /*!< Send SCR failed */
- kStatus_SDMMC_SetDataBusWidthFailed = MAKE_STATUS(kStatusGroup_SDMMC, 10U), /*!< Set bus width failed */
- kStatus_SDMMC_GoIdleFailed = MAKE_STATUS(kStatusGroup_SDMMC, 11U), /*!< Go idle failed */
- kStatus_SDMMC_HandShakeOperationConditionFailed =
- MAKE_STATUS(kStatusGroup_SDMMC, 12U), /*!< Send Operation Condition failed */
- kStatus_SDMMC_SendApplicationCommandFailed =
- MAKE_STATUS(kStatusGroup_SDMMC, 13U), /*!< Send application command failed */
- kStatus_SDMMC_SwitchFailed = MAKE_STATUS(kStatusGroup_SDMMC, 14U), /*!< Switch command failed */
- kStatus_SDMMC_StopTransmissionFailed = MAKE_STATUS(kStatusGroup_SDMMC, 15U), /*!< Stop transmission failed */
- kStatus_SDMMC_WaitWriteCompleteFailed = MAKE_STATUS(kStatusGroup_SDMMC, 16U), /*!< Wait write complete failed */
- kStatus_SDMMC_SetBlockCountFailed = MAKE_STATUS(kStatusGroup_SDMMC, 17U), /*!< Set block count failed */
- kStatus_SDMMC_SetRelativeAddressFailed = MAKE_STATUS(kStatusGroup_SDMMC, 18U), /*!< Set relative address failed */
- kStatus_SDMMC_SwitchBusTimingFailed = MAKE_STATUS(kStatusGroup_SDMMC, 19U), /*!< Switch high speed failed */
- kStatus_SDMMC_SendExtendedCsdFailed = MAKE_STATUS(kStatusGroup_SDMMC, 20U), /*!< Send EXT_CSD failed */
- kStatus_SDMMC_ConfigureBootFailed = MAKE_STATUS(kStatusGroup_SDMMC, 21U), /*!< Configure boot failed */
- kStatus_SDMMC_ConfigureExtendedCsdFailed = MAKE_STATUS(kStatusGroup_SDMMC, 22U), /*!< Configure EXT_CSD failed */
- kStatus_SDMMC_EnableHighCapacityEraseFailed =
- MAKE_STATUS(kStatusGroup_SDMMC, 23U), /*!< Enable high capacity erase failed */
- kStatus_SDMMC_SendTestPatternFailed = MAKE_STATUS(kStatusGroup_SDMMC, 24U), /*!< Send test pattern failed */
- kStatus_SDMMC_ReceiveTestPatternFailed = MAKE_STATUS(kStatusGroup_SDMMC, 25U), /*!< Receive test pattern failed */
- kStatus_SDMMC_SDIO_ResponseError = MAKE_STATUS(kStatusGroup_SDMMC, 26U), /*!< sdio response error */
- kStatus_SDMMC_SDIO_InvalidArgument =
- MAKE_STATUS(kStatusGroup_SDMMC, 27U), /*!< sdio invalid argument response error */
- kStatus_SDMMC_SDIO_SendOperationConditionFail =
- MAKE_STATUS(kStatusGroup_SDMMC, 28U), /*!< sdio send operation condition fail */
- kStatus_SDMMC_InvalidVoltage = MAKE_STATUS(kStatusGroup_SDMMC, 29U), /*!< invaild voltage */
- kStatus_SDMMC_SDIO_SwitchHighSpeedFail = MAKE_STATUS(kStatusGroup_SDMMC, 30U), /*!< switch to high speed fail */
- kStatus_SDMMC_SDIO_ReadCISFail = MAKE_STATUS(kStatusGroup_SDMMC, 31U), /*!< read CIS fail */
- kStatus_SDMMC_SDIO_InvalidCard = MAKE_STATUS(kStatusGroup_SDMMC, 32U), /*!< invaild SDIO card */
- kStatus_SDMMC_TuningFail = MAKE_STATUS(kStatusGroup_SDMMC, 33U), /*!< tuning fail */
- kStatus_SDMMC_SwitchVoltageFail = MAKE_STATUS(kStatusGroup_SDMMC, 34U), /*!< switch voltage fail*/
- kStatus_SDMMC_SwitchVoltage18VFail33VSuccess = MAKE_STATUS(kStatusGroup_SDMMC, 35U), /*!< switch voltage fail*/
- kStatus_SDMMC_ReTuningRequest = MAKE_STATUS(kStatusGroup_SDMMC, 36U), /*!< retuning request */
- kStatus_SDMMC_SetDriverStrengthFail = MAKE_STATUS(kStatusGroup_SDMMC, 37U), /*!< set driver strength fail */
- kStatus_SDMMC_SetPowerClassFail = MAKE_STATUS(kStatusGroup_SDMMC, 38U), /*!< set power class fail */
- kStatus_SDMMC_HostNotReady = MAKE_STATUS(kStatusGroup_SDMMC, 39U), /*!< host controller not ready */
- kStatus_SDMMC_CardDetectFailed = MAKE_STATUS(kStatusGroup_SDMMC, 40U), /*!< card detect failed */
- kStatus_SDMMC_AuSizeNotSetProperly = MAKE_STATUS(kStatusGroup_SDMMC, 41U), /*!< AU size not set properly */
- };
- /*! @brief card operation voltage */
- typedef enum _sdmmc_operation_voltage
- {
- kCARD_OperationVoltageNone = 0U, /*!< indicate current voltage setting is not setting by suser*/
- kCARD_OperationVoltage330V = 1U, /*!< card operation voltage around 3.3v */
- kCARD_OperationVoltage300V = 2U, /*!< card operation voltage around 3.0v */
- kCARD_OperationVoltage180V = 3U, /*!< card operation voltage around 1.8v */
- } sdmmc_operation_voltage_t;
- /*************************************************************************************************
- * API
- ************************************************************************************************/
- #if defined(__cplusplus)
- extern "C" {
- #endif
- /*!
- * @name common function
- * @{
- */
- /*!
- * @brief Selects the card to put it into transfer state.
- *
- * @param base SDMMCHOST peripheral base address.
- * @param transfer SDMMCHOST transfer function.
- * @param relativeAddress Relative address.
- * @param isSelected True to put card into transfer state.
- * @retval kStatus_SDMMC_TransferFailed Transfer failed.
- * @retval kStatus_Success Operate successfully.
- */
- status_t SDMMC_SelectCard(SDMMCHOST_TYPE *base,
- SDMMCHOST_TRANSFER_FUNCTION transfer,
- uint32_t relativeAddress,
- bool isSelected);
- /*!
- * @brief Sends an application command.
- *
- * @param base SDMMCHOST peripheral base address.
- * @param transfer SDMMCHOST transfer function.
- * @param relativeAddress Card relative address.
- * @retval kStatus_SDMMC_TransferFailed Transfer failed.
- * @retval kStatus_SDMMC_CardNotSupport Card doesn't support.
- * @retval kStatus_Success Operate successfully.
- */
- status_t SDMMC_SendApplicationCommand(SDMMCHOST_TYPE *base,
- SDMMCHOST_TRANSFER_FUNCTION transfer,
- uint32_t relativeAddress);
- /*!
- * @brief Sets the block count.
- *
- * @param base SDMMCHOST peripheral base address.
- * @param transfer SDMMCHOST transfer function.
- * @param blockCount Block count.
- * @retval kStatus_SDMMC_TransferFailed Transfer failed.
- * @retval kStatus_Success Operate successfully.
- */
- status_t SDMMC_SetBlockCount(SDMMCHOST_TYPE *base, SDMMCHOST_TRANSFER_FUNCTION transfer, uint32_t blockCount);
- /*!
- * @brief Sets the card to be idle state.
- *
- * @param base SDMMCHOST peripheral base address.
- * @param transfer SDMMCHOST transfer function.
- * @retval kStatus_SDMMC_TransferFailed Transfer failed.
- * @retval kStatus_Success Operate successfully.
- */
- status_t SDMMC_GoIdle(SDMMCHOST_TYPE *base, SDMMCHOST_TRANSFER_FUNCTION transfer);
- /*!
- * @brief Sets data block size.
- *
- * @param base SDMMCHOST peripheral base address.
- * @param transfer SDMMCHOST transfer function.
- * @param blockSize Block size.
- * @retval kStatus_SDMMC_TransferFailed Transfer failed.
- * @retval kStatus_Success Operate successfully.
- */
- status_t SDMMC_SetBlockSize(SDMMCHOST_TYPE *base, SDMMCHOST_TRANSFER_FUNCTION transfer, uint32_t blockSize);
- /*!
- * @brief Sets card to inactive status
- *
- * @param base SDMMCHOST peripheral base address.
- * @param transfer SDMMCHOST transfer function.
- * @retval kStatus_SDMMC_TransferFailed Transfer failed.
- * @retval kStatus_Success Operate successfully.
- */
- status_t SDMMC_SetCardInactive(SDMMCHOST_TYPE *base, SDMMCHOST_TRANSFER_FUNCTION transfer);
- /*!
- * @brief provide a simple delay function for sdmmc
- *
- * @param num Delay num*10000.
- */
- void SDMMC_Delay(uint32_t num);
- /*!
- * @brief provide a voltage switch function for SD/SDIO card
- * @deprecated Do not use this function, it has been superceded by SDMMC_SwitchToVoltage.
- * @param base SDMMCHOST peripheral base address.
- * @param transfer SDMMCHOST transfer function.
- */
- status_t SDMMC_SwitchVoltage(SDMMCHOST_TYPE *base, SDMMCHOST_TRANSFER_FUNCTION transfer);
- /*!
- * @brief provide a voltage switch function for SD/SDIO card
- *
- * @param base SDMMCHOST peripheral base address.
- * @param transfer SDMMCHOST transfer function.
- * @param switchVoltageFunc voltage switch function.
- * @return error code.
- */
- status_t SDMMC_SwitchToVoltage(SDMMCHOST_TYPE *base,
- SDMMCHOST_TRANSFER_FUNCTION transfer,
- sdmmchost_card_switch_voltage_t switchVoltageFunc);
- /*!
- * @brief excute tuning
- *
- * @param base SDMMCHOST peripheral base address.
- * @param transfer Host transfer function
- * @param tuningCmd Tuning cmd
- * @param blockSize Tuning block size
- */
- status_t SDMMC_ExecuteTuning(SDMMCHOST_TYPE *base,
- SDMMCHOST_TRANSFER_FUNCTION transfer,
- uint32_t tuningCmd,
- uint32_t blockSize);
- /* @} */
- #if defined(__cplusplus)
- }
- #endif
- /* @} */
- #endif /* _FSL_SDMMC_COMMON_H_ */
|