457 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			457 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|   | /*
 | ||
|  |  * @brief    Common definitions used in SD/MMC cards | ||
|  |  * @note | ||
|  |  * Copyright(C) NXP Semiconductors, 2012 | ||
|  |  * All rights reserved. | ||
|  |  * | ||
|  |  * @par | ||
|  |  * Software that is described herein is for illustrative purposes only | ||
|  |  * which provides customers with programming information regarding the | ||
|  |  * LPC products.  This software is supplied "AS IS" without any warranties of | ||
|  |  * any kind, and NXP Semiconductors and its licensor disclaim any and | ||
|  |  * all warranties, express or implied, including all implied warranties of | ||
|  |  * merchantability, fitness for a particular purpose and non-infringement of | ||
|  |  * intellectual property rights.  NXP Semiconductors assumes no responsibility | ||
|  |  * or liability for the use of the software, conveys no license or rights under any | ||
|  |  * patent, copyright, mask work right, or any other intellectual property rights in | ||
|  |  * or to any products. NXP Semiconductors reserves the right to make changes | ||
|  |  * in the software without notification. NXP Semiconductors also makes no | ||
|  |  * representation or warranty that such application will be suitable for the | ||
|  |  * specified use without further testing or modification. | ||
|  |  * | ||
|  |  * @par | ||
|  |  * Permission to use, copy, modify, and distribute this software and its | ||
|  |  * documentation is hereby granted, under NXP Semiconductors' and its | ||
|  |  * licensor's relevant copyrights in the software, without fee, provided that it | ||
|  |  * is used in conjunction with NXP Semiconductors microcontrollers.  This | ||
|  |  * copyright, permission, and disclaimer notice must appear in all copies of | ||
|  |  * this code. | ||
|  |  */ | ||
|  | 
 | ||
|  | #ifndef __SDMMC_H
 | ||
|  | #define __SDMMC_H
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | extern "C" { | ||
|  | #endif
 | ||
|  | 
 | ||
|  | /** @defgroup CHIP_SDMMC_Definitions CHIP: Common SD/MMC definitions
 | ||
|  |  * @ingroup CHIP_Common | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief OCR Register definitions | ||
|  |  */ | ||
|  | /** Support voltage range 2.0-2.1 (this bit is reserved in SDC)*/ | ||
|  | #define SDC_OCR_20_21               (((uint32_t) 1) << 8)
 | ||
|  | /** Support voltage range 2.1-2.2 (this bit is reserved in SDC)*/ | ||
|  | #define SDC_OCR_21_22               (((uint32_t) 1) << 9)
 | ||
|  | /** Support voltage range 2.2-2.3 (this bit is reserved in SDC)*/ | ||
|  | #define SDC_OCR_22_23               (((uint32_t) 1) << 10)
 | ||
|  | /** Support voltage range 2.3-2.4 (this bit is reserved in SDC)*/ | ||
|  | #define SDC_OCR_23_24               (((uint32_t) 1) << 11)
 | ||
|  | /** Support voltage range 2.4-2.5 (this bit is reserved in SDC)*/ | ||
|  | #define SDC_OCR_24_25               (((uint32_t) 1) << 12)
 | ||
|  | /** Support voltage range 2.5-2.6 (this bit is reserved in SDC)*/ | ||
|  | #define SDC_OCR_25_26               (((uint32_t) 1) << 13)
 | ||
|  | /** Support voltage range 2.6-2.7 (this bit is reserved in SDC)*/ | ||
|  | #define SDC_OCR_26_27               (((uint32_t) 1) << 14)
 | ||
|  | /** Support voltage range 2.7-2.8 */ | ||
|  | #define SDC_OCR_27_28               (((uint32_t) 1) << 15)
 | ||
|  | /** Support voltage range 2.8-2.9*/ | ||
|  | #define SDC_OCR_28_29               (((uint32_t) 1) << 16)
 | ||
|  | /** Support voltage range 2.9-3.0 */ | ||
|  | #define SDC_OCR_29_30               (((uint32_t) 1) << 17)
 | ||
|  | /** Support voltage range 3.0-3.1 */ | ||
|  | #define SDC_OCR_30_31               (((uint32_t) 1) << 18)
 | ||
|  | /** Support voltage range 3.1-3.2 */ | ||
|  | #define SDC_OCR_31_32               (((uint32_t) 1) << 19)
 | ||
|  | /** Support voltage range 3.2-3.3 */ | ||
|  | #define SDC_OCR_32_33               (((uint32_t) 1) << 20)
 | ||
|  | /** Support voltage range 3.3-3.4 */ | ||
|  | #define SDC_OCR_33_34               (((uint32_t) 1) << 21)
 | ||
|  | /** Support voltage range 3.4-3.5 */ | ||
|  | #define SDC_OCR_34_35               (((uint32_t) 1) << 22)
 | ||
|  | /** Support voltage range 3.5-3.6 */ | ||
|  | #define SDC_OCR_35_36               (((uint32_t) 1) << 23)
 | ||
|  | /** Support voltage range 2.7-3.6 */ | ||
|  | #define SDC_OCR_27_36               ((uint32_t) 0x00FF8000)
 | ||
|  | /** Card Capacity Status (CCS). (this bit is reserved in MMC) */ | ||
|  | #define SDC_OCR_HC_CCS              (((uint32_t) 1) << 30)
 | ||
|  | /** Card power up status bit */ | ||
|  | #define SDC_OCR_IDLE                (((uint32_t) 1) << 31)
 | ||
|  | #define SDC_OCR_BUSY                (((uint32_t) 0) << 31)
 | ||
|  | 
 | ||
|  | /* SD/MMC commands - this matrix shows the command, response types, and
 | ||
|  |    supported card type for that command. | ||
|  |    Command                 Number Resp  SD  MMC | ||
|  |    ----------------------- ------ ----- --- --- | ||
|  |    Reset (go idle)         CMD0   NA    x   x | ||
|  |    Send op condition       CMD1   R3        x | ||
|  |    All send CID            CMD2   R2    x   x | ||
|  |    Send relative address   CMD3   R1        x | ||
|  |    Send relative address   CMD3   R6    x | ||
|  |    Program DSR             CMD4   NA        x | ||
|  |    Select/deselect card    CMD7   R1b       x | ||
|  |    Select/deselect card    CMD7   R1    x | ||
|  |    Send CSD                CMD9   R2    x   x | ||
|  |    Send CID                CMD10  R2    x   x | ||
|  |    Read data until stop    CMD11  R1    x   x | ||
|  |    Stop transmission       CMD12  R1/b  x   x | ||
|  |    Send status             CMD13  R1    x   x | ||
|  |    Go inactive state       CMD15  NA    x   x | ||
|  |    Set block length        CMD16  R1    x   x | ||
|  |    Read single block       CMD17  R1    x   x | ||
|  |    Read multiple blocks    CMD18  R1    x   x | ||
|  |    Write data until stop   CMD20  R1        x | ||
|  |    Setblock count          CMD23  R1        x | ||
|  |    Write single block      CMD24  R1    x   x | ||
|  |    Write multiple blocks   CMD25  R1    x   x | ||
|  |    Program CID             CMD26  R1        x | ||
|  |    Program CSD             CMD27  R1    x   x | ||
|  |    Set write protection    CMD28  R1b   x   x | ||
|  |    Clear write protection  CMD29  R1b   x   x | ||
|  |    Send write protection   CMD30  R1    x   x | ||
|  |    Erase block start       CMD32  R1    x | ||
|  |    Erase block end         CMD33  R1    x | ||
|  |    Erase block start       CMD35  R1        x | ||
|  |    Erase block end         CMD36  R1        x | ||
|  |    Erase blocks            CMD38  R1b       x | ||
|  |    Fast IO                 CMD39  R4        x | ||
|  |    Go IRQ state            CMD40  R5        x | ||
|  |    Lock/unlock             CMD42  R1b       x | ||
|  |    Application command     CMD55  R1        x | ||
|  |    General command         CMD56  R1b       x | ||
|  | 
 | ||
|  |  *** SD card application commands - these must be preceded with *** | ||
|  |  *** MMC CMD55 application specific command first               *** | ||
|  |    Set bus width           ACMD6  R1    x | ||
|  |    Send SD status          ACMD13 R1    x | ||
|  |    Send number WR blocks   ACMD22 R1    x | ||
|  |    Set WR block erase cnt  ACMD23 R1    x | ||
|  |    Send op condition       ACMD41 R3    x | ||
|  |    Set clear card detect   ACMD42 R1    x | ||
|  |    Send CSR                ACMD51 R1    x */ | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief  SD/MMC application specific commands for SD cards only - these | ||
|  |  * must be preceded by the SDMMC CMD55 to work correctly | ||
|  |  */ | ||
|  | typedef enum { | ||
|  | 	SD_SET_BUS_WIDTH,		/*!< Set the SD bus width */ | ||
|  | 	SD_SEND_STATUS,			/*!< Send the SD card status */ | ||
|  | 	SD_SEND_WR_BLOCKS,		/*!< Send the number of written clocks */ | ||
|  | 	SD_SET_ERASE_COUNT,		/*!< Set the number of blocks to pre-erase */ | ||
|  | 	SD_SENDOP_COND,			/*!< Send the OCR register (init) */ | ||
|  | 	SD_CLEAR_CARD_DET,		/*!< Set or clear the 50K detect pullup */ | ||
|  | 	SD_SEND_SCR,			/*!< Send the SD configuration register */ | ||
|  | 	SD_INVALID_APP_CMD		/*!< Invalid SD application command */ | ||
|  | } SD_APP_CMD_T; | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief  Possible SDMMC response types | ||
|  |  */ | ||
|  | typedef enum { | ||
|  | 	SDMMC_RESPONSE_R1,		/*!< Typical status */ | ||
|  | 	SDMMC_RESPONSE_R1B,		/*!< Typical status with busy */ | ||
|  | 	SDMMC_RESPONSE_R2,		/*!< CID/CSD registers (CMD2 and CMD10) */ | ||
|  | 	SDMMC_RESPONSE_R3,		/*!< OCR register (CMD1, ACMD41) */ | ||
|  | 	SDMMC_RESPONSE_R4,		/*!< Fast IO response word */ | ||
|  | 	SDMMC_RESPONSE_R5,		/*!< Go IRQ state response word */ | ||
|  | 	SDMMC_RESPONSE_R6,		/*!< Published RCA response */ | ||
|  | 	SDMMC_RESPONSE_NONE		/*!< No response expected */ | ||
|  | } SDMMC_RESPONSE_T; | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief  Possible SDMMC card state types | ||
|  |  */ | ||
|  | typedef enum { | ||
|  | 	SDMMC_IDLE_ST = 0,	/*!< Idle state */ | ||
|  | 	SDMMC_READY_ST,		/*!< Ready state */ | ||
|  | 	SDMMC_IDENT_ST,		/*!< Identification State */ | ||
|  | 	SDMMC_STBY_ST,		/*!< standby state */ | ||
|  | 	SDMMC_TRAN_ST,		/*!< transfer state */ | ||
|  | 	SDMMC_DATA_ST,		/*!< Sending-data State */ | ||
|  | 	SDMMC_RCV_ST,		/*!< Receive-data State */ | ||
|  | 	SDMMC_PRG_ST,		/*!< Programming State */ | ||
|  | 	SDMMC_DIS_ST		/*!< Disconnect State */ | ||
|  | } SDMMC_STATE_T; | ||
|  | 
 | ||
|  | /* Function prototype for event setup function */ | ||
|  | typedef void (*SDMMC_EVSETUP_FUNC_T)(void *); | ||
|  | 
 | ||
|  | /* Function prototype for wait for event function */ | ||
|  | typedef uint32_t (*SDMMC_EVWAIT_FUNC_T)(void); | ||
|  | 
 | ||
|  | /* Function prototype for milliSecond delay function */ | ||
|  | typedef void (*SDMMC_MSDELAY_FUNC_T)(uint32_t); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief SD/MMC Card specific setup data structure | ||
|  |  */ | ||
|  | typedef struct { | ||
|  | 	uint32_t response[4];						/*!< Most recent response */ | ||
|  | 	uint32_t cid[4];							/*!< CID of acquired card  */ | ||
|  | 	uint32_t csd[4];							/*!< CSD of acquired card */ | ||
|  | 	uint32_t ext_csd[512 / 4];					/*!< Ext CSD */ | ||
|  | 	uint32_t card_type;							/*!< Card Type */ | ||
|  | 	uint16_t rca;								/*!< Relative address assigned to card */ | ||
|  | 	uint32_t speed;								/*!< Speed */ | ||
|  | 	uint32_t block_len;							/*!< Card sector size */ | ||
|  | 	uint64_t device_size;						/*!< Device Size */ | ||
|  | 	uint32_t blocknr;							/*!< Block Number */ | ||
|  | 	uint32_t clk_rate;							/*! Clock rate */ | ||
|  | 	SDMMC_EVSETUP_FUNC_T evsetup_cb;			/*!< Function to setup event information */ | ||
|  | 	SDMMC_EVWAIT_FUNC_T waitfunc_cb;			/*!< Function to wait for event */ | ||
|  | 	SDMMC_MSDELAY_FUNC_T msdelay_func;			/*!< Function to sleep in ms */ | ||
|  | } SDMMC_CARD_T; | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief SD/MMC commands, arguments and responses | ||
|  |  * Standard SD/MMC commands (3.1)       type  argument     response | ||
|  |  */ | ||
|  | /* class 1 */ | ||
|  | #define MMC_GO_IDLE_STATE         0		/* bc                          */
 | ||
|  | #define MMC_SEND_OP_COND          1		/* bcr  [31:0]  OCR        R3  */
 | ||
|  | #define MMC_ALL_SEND_CID          2		/* bcr                     R2  */
 | ||
|  | #define MMC_SET_RELATIVE_ADDR     3		/* ac   [31:16] RCA        R1  */
 | ||
|  | #define MMC_SET_DSR               4		/* bc   [31:16] RCA            */
 | ||
|  | #define MMC_SELECT_CARD           7		/* ac   [31:16] RCA        R1  */
 | ||
|  | #define MMC_SEND_EXT_CSD          8		/* bc                      R1  */
 | ||
|  | #define MMC_SEND_CSD              9		/* ac   [31:16] RCA        R2  */
 | ||
|  | #define MMC_SEND_CID             10		/* ac   [31:16] RCA        R2  */
 | ||
|  | #define MMC_STOP_TRANSMISSION    12		/* ac                      R1b */
 | ||
|  | #define MMC_SEND_STATUS          13		/* ac   [31:16] RCA        R1  */
 | ||
|  | #define MMC_GO_INACTIVE_STATE    15		/* ac   [31:16] RCA            */
 | ||
|  | 
 | ||
|  | /* class 2 */ | ||
|  | #define MMC_SET_BLOCKLEN         16		/* ac   [31:0]  block len  R1  */
 | ||
|  | #define MMC_READ_SINGLE_BLOCK    17		/* adtc [31:0]  data addr  R1  */
 | ||
|  | #define MMC_READ_MULTIPLE_BLOCK  18		/* adtc [31:0]  data addr  R1  */
 | ||
|  | 
 | ||
|  | /* class 3 */ | ||
|  | #define MMC_WRITE_DAT_UNTIL_STOP 20		/* adtc [31:0]  data addr  R1  */
 | ||
|  | 
 | ||
|  | /* class 4 */ | ||
|  | #define MMC_SET_BLOCK_COUNT      23		/* adtc [31:0]  data addr  R1  */
 | ||
|  | #define MMC_WRITE_BLOCK          24		/* adtc [31:0]  data addr  R1  */
 | ||
|  | #define MMC_WRITE_MULTIPLE_BLOCK 25		/* adtc                    R1  */
 | ||
|  | #define MMC_PROGRAM_CID          26		/* adtc                    R1  */
 | ||
|  | #define MMC_PROGRAM_CSD          27		/* adtc                    R1  */
 | ||
|  | 
 | ||
|  | /* class 6 */ | ||
|  | #define MMC_SET_WRITE_PROT       28		/* ac   [31:0]  data addr  R1b */
 | ||
|  | #define MMC_CLR_WRITE_PROT       29		/* ac   [31:0]  data addr  R1b */
 | ||
|  | #define MMC_SEND_WRITE_PROT      30		/* adtc [31:0]  wpdata addr R1  */
 | ||
|  | 
 | ||
|  | /* class 5 */ | ||
|  | #define MMC_ERASE_GROUP_START    35		/* ac   [31:0]  data addr  R1  */
 | ||
|  | #define MMC_ERASE_GROUP_END      36		/* ac   [31:0]  data addr  R1  */
 | ||
|  | #define MMC_ERASE                37		/* ac                      R1b */
 | ||
|  | #define SD_ERASE_WR_BLK_START    32		/* ac   [31:0]  data addr  R1  */
 | ||
|  | #define SD_ERASE_WR_BLK_END      33		/* ac   [31:0]  data addr  R1  */
 | ||
|  | #define SD_ERASE                 38		/* ac                      R1b */
 | ||
|  | 
 | ||
|  | /* class 9 */ | ||
|  | #define MMC_FAST_IO              39		/* ac   <Complex>          R4  */
 | ||
|  | #define MMC_GO_IRQ_STATE         40		/* bcr                     R5  */
 | ||
|  | 
 | ||
|  | /* class 7 */ | ||
|  | #define MMC_LOCK_UNLOCK          42		/* adtc                    R1b */
 | ||
|  | 
 | ||
|  | /* class 8 */ | ||
|  | #define MMC_APP_CMD              55		/* ac   [31:16] RCA        R1  */
 | ||
|  | #define MMC_GEN_CMD              56		/* adtc [0]     RD/WR      R1b */
 | ||
|  | 
 | ||
|  | /* SD commands                           type  argument     response */ | ||
|  | /* class 8 */ | ||
|  | /* This is basically the same command as for MMC with some quirks. */ | ||
|  | #define SD_SEND_RELATIVE_ADDR     3		/* ac                      R6  */
 | ||
|  | #define SD_CMD8                   8		/* bcr  [31:0]  OCR        R3  */
 | ||
|  | 
 | ||
|  | /* Application commands */ | ||
|  | #define SD_APP_SET_BUS_WIDTH      6		/* ac   [1:0]   bus width  R1   */
 | ||
|  | #define SD_APP_OP_COND           41		/* bcr  [31:0]  OCR        R1 (R4)  */
 | ||
|  | #define SD_APP_SEND_SCR          51		/* adtc                    R1   */
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief MMC status in R1<br> | ||
|  |  * Type<br> | ||
|  |  *   e : error bit<br> | ||
|  |  *   s : status bit<br> | ||
|  |  *   r : detected and set for the actual command response<br> | ||
|  |  *   x : detected and set during command execution. the host must poll | ||
|  |  *       the card by sending status command in order to read these bits. | ||
|  |  * Clear condition<br> | ||
|  |  *   a : according to the card state<br> | ||
|  |  *   b : always related to the previous command. Reception of | ||
|  |  *       a valid command will clear it (with a delay of one command)<br> | ||
|  |  *   c : clear by read<br> | ||
|  |  */ | ||
|  | 
 | ||
|  | #define R1_OUT_OF_RANGE         (1UL << 31)	/* er, c */
 | ||
|  | #define R1_ADDRESS_ERROR        (1 << 30)	/* erx, c */
 | ||
|  | #define R1_BLOCK_LEN_ERROR      (1 << 29)	/* er, c */
 | ||
|  | #define R1_ERASE_SEQ_ERROR      (1 << 28)	/* er, c */
 | ||
|  | #define R1_ERASE_PARAM          (1 << 27)	/* ex, c */
 | ||
|  | #define R1_WP_VIOLATION         (1 << 26)	/* erx, c */
 | ||
|  | #define R1_CARD_IS_LOCKED       (1 << 25)	/* sx, a */
 | ||
|  | #define R1_LOCK_UNLOCK_FAILED   (1 << 24)	/* erx, c */
 | ||
|  | #define R1_COM_CRC_ERROR        (1 << 23)	/* er, b */
 | ||
|  | #define R1_ILLEGAL_COMMAND      (1 << 22)	/* er, b */
 | ||
|  | #define R1_CARD_ECC_FAILED      (1 << 21)	/* ex, c */
 | ||
|  | #define R1_CC_ERROR             (1 << 20)	/* erx, c */
 | ||
|  | #define R1_ERROR                (1 << 19)	/* erx, c */
 | ||
|  | #define R1_UNDERRUN             (1 << 18)	/* ex, c */
 | ||
|  | #define R1_OVERRUN              (1 << 17)	/* ex, c */
 | ||
|  | #define R1_CID_CSD_OVERWRITE    (1 << 16)	/* erx, c, CID/CSD overwrite */
 | ||
|  | #define R1_WP_ERASE_SKIP        (1 << 15)	/* sx, c */
 | ||
|  | #define R1_CARD_ECC_DISABLED    (1 << 14)	/* sx, a */
 | ||
|  | #define R1_ERASE_RESET          (1 << 13)	/* sr, c */
 | ||
|  | #define R1_STATUS(x)            (x & 0xFFFFE000)
 | ||
|  | #define R1_CURRENT_STATE(x)     ((x & 0x00001E00) >> 9)	/* sx, b (4 bits) */
 | ||
|  | #define R1_READY_FOR_DATA       (1 << 8)	/* sx, a */
 | ||
|  | #define R1_APP_CMD              (1 << 5)	/* sr, c */
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief SD/MMC card OCR register bits | ||
|  |  */ | ||
|  | #define OCR_ALL_READY           (1UL << 31)	/* Card Power up status bit */
 | ||
|  | #define OCR_HC_CCS              (1 << 30)	/* High capacity card */
 | ||
|  | #define OCR_VOLTAGE_RANGE_MSK   (0x00FF8000)
 | ||
|  | 
 | ||
|  | #define SD_SEND_IF_ARG          0x000001AA
 | ||
|  | #define SD_SEND_IF_ECHO_MSK     0x000000FF
 | ||
|  | #define SD_SEND_IF_RESP         0x000000AA
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief R3 response definitions | ||
|  |  */ | ||
|  | #define CMDRESP_R3_OCR_VAL(n)           (((uint32_t) n) & 0xFFFFFF)
 | ||
|  | #define CMDRESP_R3_S18A                 (((uint32_t) 1 ) << 24)
 | ||
|  | #define CMDRESP_R3_HC_CCS               (((uint32_t) 1 ) << 30)
 | ||
|  | #define CMDRESP_R3_INIT_COMPLETE        (((uint32_t) 1 ) << 31)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief R6 response definitions | ||
|  |  */ | ||
|  | #define CMDRESP_R6_RCA_VAL(n)           (((uint32_t) (n >> 16)) & 0xFFFF)
 | ||
|  | #define CMDRESP_R6_CARD_STATUS(n)       (((uint32_t) (n & 0x1FFF)) | \
 | ||
|  | 										 ((n & (1 << 13)) ? (1 << 19) : 0) | \ | ||
|  | 										 ((n & (1 << 14)) ? (1 << 22) : 0) | \ | ||
|  | 										 ((n & (1 << 15)) ? (1 << 23) : 0)) | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief R7 response definitions | ||
|  |  */ | ||
|  | /** Echo-back of check-pattern */ | ||
|  | #define CMDRESP_R7_CHECK_PATTERN(n)     (((uint32_t) n ) & 0xFF)
 | ||
|  | /** Voltage accepted */ | ||
|  | #define CMDRESP_R7_VOLTAGE_ACCEPTED     (((uint32_t) 1 ) << 8)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief CMD3 command definitions | ||
|  |  */ | ||
|  | /** Card Address */ | ||
|  | #define CMD3_RCA(n)         (((uint32_t) (n & 0xFFFF) ) << 16)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief CMD7 command definitions | ||
|  |  */ | ||
|  | /** Card Address */ | ||
|  | #define CMD7_RCA(n)         (((uint32_t) (n & 0xFFFF) ) << 16)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief CMD8 command definitions | ||
|  |  */ | ||
|  | /** Check pattern */ | ||
|  | #define CMD8_CHECKPATTERN(n)            (((uint32_t) (n & 0xFF) ) << 0)
 | ||
|  | /** Recommended pattern */ | ||
|  | #define CMD8_DEF_PATTERN                    (0xAA)
 | ||
|  | /** Voltage supplied.*/ | ||
|  | #define CMD8_VOLTAGESUPPLIED_27_36     (((uint32_t) 1 ) << 8)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief CMD9 command definitions | ||
|  |  */ | ||
|  | #define CMD9_RCA(n)         (((uint32_t) (n & 0xFFFF) ) << 16)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief CMD13 command definitions | ||
|  |  */ | ||
|  | #define CMD13_RCA(n)            (((uint32_t) (n & 0xFFFF) ) << 16)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief APP_CMD command definitions | ||
|  |  */ | ||
|  | #define CMD55_RCA(n)            (((uint32_t) (n & 0xFFFF) ) << 16)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief ACMD41 command definitions | ||
|  |  */ | ||
|  | #define ACMD41_OCR(n)                   (((uint32_t) n) & 0xFFFFFF)
 | ||
|  | #define ACMD41_S18R                     (((uint32_t) 1 ) << 24)
 | ||
|  | #define ACMD41_XPC                      (((uint32_t) 1 ) << 28)
 | ||
|  | #define ACMD41_HCS                      (((uint32_t) 1 ) << 30)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief ACMD6 command definitions | ||
|  |  */ | ||
|  | #define ACMD6_BUS_WIDTH(n)              ((uint32_t) n & 0x03)
 | ||
|  | #define ACMD6_BUS_WIDTH_1               (0)
 | ||
|  | #define ACMD6_BUS_WIDTH_4               (2)
 | ||
|  | 
 | ||
|  | /** @brief Card type defines
 | ||
|  |  */ | ||
|  | #define CARD_TYPE_SD    (1 << 0)
 | ||
|  | #define CARD_TYPE_4BIT  (1 << 1)
 | ||
|  | #define CARD_TYPE_8BIT  (1 << 2)
 | ||
|  | #define CARD_TYPE_HC    (OCR_HC_CCS)/*!< high capacity card > 2GB */
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief SD/MMC sector size in bytes | ||
|  |  */ | ||
|  | #define MMC_SECTOR_SIZE     512
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief Typical enumeration clock rate | ||
|  |  */ | ||
|  | #define SD_MMC_ENUM_CLOCK       400000
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief Max MMC clock rate | ||
|  |  */ | ||
|  | #define MMC_MAX_CLOCK           20000000
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief Type 0 MMC card max clock rate | ||
|  |  */ | ||
|  | #define MMC_LOW_BUS_MAX_CLOCK   26000000
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief Type 1 MMC card max clock rate | ||
|  |  */ | ||
|  | #define MMC_HIGH_BUS_MAX_CLOCK  52000000
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief Max SD clock rate | ||
|  |  */ | ||
|  | #define SD_MAX_CLOCK            25000000
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | } | ||
|  | #endif
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | #endif /* __SDMMC_H */
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 |