Blame view
include/mmc.h
11 KB
71f951180 * Fix CONFIG_NET_... |
1 |
/* |
4a6ee172c fsl_esdhc: Use mm... |
2 |
* Copyright 2008,2010 Freescale Semiconductor, Inc |
272cc70b2 Add MMC Framework |
3 4 5 |
* Andy Fleming * * Based (loosely) on the Linux code |
71f951180 * Fix CONFIG_NET_... |
6 |
* |
1a4596601 Add GPL-2.0+ SPDX... |
7 |
* SPDX-License-Identifier: GPL-2.0+ |
71f951180 * Fix CONFIG_NET_... |
8 9 10 11 |
*/ #ifndef _MMC_H_ #define _MMC_H_ |
71f951180 * Fix CONFIG_NET_... |
12 |
|
272cc70b2 Add MMC Framework |
13 |
#include <linux/list.h> |
0d986e61e da850/omap-l138: ... |
14 |
#include <linux/compiler.h> |
272cc70b2 Add MMC Framework |
15 16 |
#define SD_VERSION_SD 0x20000 |
1741c64d6 mmc: check the re... |
17 |
#define SD_VERSION_3 (SD_VERSION_SD | 0x300) |
64f4a6192 mmc: support the ... |
18 19 20 |
#define SD_VERSION_2 (SD_VERSION_SD | 0x200) #define SD_VERSION_1_0 (SD_VERSION_SD | 0x100) #define SD_VERSION_1_10 (SD_VERSION_SD | 0x10a) |
272cc70b2 Add MMC Framework |
21 22 |
#define MMC_VERSION_MMC 0x10000 #define MMC_VERSION_UNKNOWN (MMC_VERSION_MMC) |
64f4a6192 mmc: support the ... |
23 24 25 26 27 28 29 30 31 32 |
#define MMC_VERSION_1_2 (MMC_VERSION_MMC | 0x102) #define MMC_VERSION_1_4 (MMC_VERSION_MMC | 0x104) #define MMC_VERSION_2_2 (MMC_VERSION_MMC | 0x202) #define MMC_VERSION_3 (MMC_VERSION_MMC | 0x300) #define MMC_VERSION_4 (MMC_VERSION_MMC | 0x400) #define MMC_VERSION_4_1 (MMC_VERSION_MMC | 0x401) #define MMC_VERSION_4_2 (MMC_VERSION_MMC | 0x402) #define MMC_VERSION_4_3 (MMC_VERSION_MMC | 0x403) #define MMC_VERSION_4_41 (MMC_VERSION_MMC | 0x429) #define MMC_VERSION_4_5 (MMC_VERSION_MMC | 0x405) |
272cc70b2 Add MMC Framework |
33 34 35 36 37 |
#define MMC_MODE_HS 0x001 #define MMC_MODE_HS_52MHz 0x010 #define MMC_MODE_4BIT 0x100 #define MMC_MODE_8BIT 0x200 |
d52ebf102 mmc: add generic ... |
38 |
#define MMC_MODE_SPI 0x400 |
b1f1e821d mmc: Access mode ... |
39 |
#define MMC_MODE_HC 0x800 |
272cc70b2 Add MMC Framework |
40 |
|
627220364 mmc:fix: Set mmc ... |
41 42 |
#define MMC_MODE_MASK_WIDTH_BITS (MMC_MODE_4BIT | MMC_MODE_8BIT) #define MMC_MODE_WIDTH_BITS_SHIFT 8 |
272cc70b2 Add MMC Framework |
43 |
#define SD_DATA_4BIT 0x00040000 |
79b91de95 include/mmc.h: Fi... |
44 |
#define IS_SD(x) (x->version & SD_VERSION_SD) |
272cc70b2 Add MMC Framework |
45 46 47 48 49 50 51 52 |
#define MMC_DATA_READ 1 #define MMC_DATA_WRITE 2 #define NO_CARD_ERR -16 /* No SD/MMC card inserted */ #define UNUSABLE_ERR -17 /* Unusable Card */ #define COMM_ERR -18 /* Communications Error */ #define TIMEOUT -19 |
e95504497 mmc: Split device... |
53 |
#define IN_PROGRESS -20 /* operation is in progress */ |
272cc70b2 Add MMC Framework |
54 |
|
341188b9c MMC: Consolidate ... |
55 56 57 58 59 |
#define MMC_CMD_GO_IDLE_STATE 0 #define MMC_CMD_SEND_OP_COND 1 #define MMC_CMD_ALL_SEND_CID 2 #define MMC_CMD_SET_RELATIVE_ADDR 3 #define MMC_CMD_SET_DSR 4 |
272cc70b2 Add MMC Framework |
60 |
#define MMC_CMD_SWITCH 6 |
341188b9c MMC: Consolidate ... |
61 |
#define MMC_CMD_SELECT_CARD 7 |
272cc70b2 Add MMC Framework |
62 |
#define MMC_CMD_SEND_EXT_CSD 8 |
341188b9c MMC: Consolidate ... |
63 64 |
#define MMC_CMD_SEND_CSD 9 #define MMC_CMD_SEND_CID 10 |
272cc70b2 Add MMC Framework |
65 |
#define MMC_CMD_STOP_TRANSMISSION 12 |
341188b9c MMC: Consolidate ... |
66 67 68 69 |
#define MMC_CMD_SEND_STATUS 13 #define MMC_CMD_SET_BLOCKLEN 16 #define MMC_CMD_READ_SINGLE_BLOCK 17 #define MMC_CMD_READ_MULTIPLE_BLOCK 18 |
272cc70b2 Add MMC Framework |
70 71 |
#define MMC_CMD_WRITE_SINGLE_BLOCK 24 #define MMC_CMD_WRITE_MULTIPLE_BLOCK 25 |
e6f99a561 MMC: add erase fu... |
72 73 74 |
#define MMC_CMD_ERASE_GROUP_START 35 #define MMC_CMD_ERASE_GROUP_END 36 #define MMC_CMD_ERASE 38 |
341188b9c MMC: Consolidate ... |
75 |
#define MMC_CMD_APP_CMD 55 |
d52ebf102 mmc: add generic ... |
76 77 |
#define MMC_CMD_SPI_READ_OCR 58 #define MMC_CMD_SPI_CRC_ON_OFF 59 |
3690d6d66 MMC: APIs to supp... |
78 79 80 81 |
#define MMC_CMD_RES_MAN 62 #define MMC_CMD62_ARG1 0xefac62ec #define MMC_CMD62_ARG2 0xcbaea7 |
341188b9c MMC: Consolidate ... |
82 |
|
341188b9c MMC: Consolidate ... |
83 |
#define SD_CMD_SEND_RELATIVE_ADDR 3 |
272cc70b2 Add MMC Framework |
84 |
#define SD_CMD_SWITCH_FUNC 6 |
341188b9c MMC: Consolidate ... |
85 86 87 |
#define SD_CMD_SEND_IF_COND 8 #define SD_CMD_APP_SET_BUS_WIDTH 6 |
e6f99a561 MMC: add erase fu... |
88 89 |
#define SD_CMD_ERASE_WR_BLK_START 32 #define SD_CMD_ERASE_WR_BLK_END 33 |
341188b9c MMC: Consolidate ... |
90 |
#define SD_CMD_APP_SEND_OP_COND 41 |
272cc70b2 Add MMC Framework |
91 92 93 94 95 96 97 98 |
#define SD_CMD_APP_SEND_SCR 51 /* SCR definitions in different words */ #define SD_HIGHSPEED_BUSY 0x00020000 #define SD_HIGHSPEED_SUPPORTED 0x00020000 #define MMC_HS_TIMING 0x00000100 #define MMC_HS_52MHZ 0x2 |
abe2c93ff mmc: coding style... |
99 100 |
#define OCR_BUSY 0x80000000 #define OCR_HCS 0x40000000 |
31cacbabf mmc: SEND_OP_COND... |
101 102 |
#define OCR_VOLTAGE_MASK 0x007FFF80 #define OCR_ACCESS_MODE 0x60000000 |
272cc70b2 Add MMC Framework |
103 |
|
e6f99a561 MMC: add erase fu... |
104 |
#define SECURE_ERASE 0x80000000 |
5d4fc8d90 mmc: checking sta... |
105 |
#define MMC_STATUS_MASK (~0x0206BF7F) |
abe2c93ff mmc: coding style... |
106 107 |
#define MMC_STATUS_RDY_FOR_DATA (1 << 8) #define MMC_STATUS_CURR_STATE (0xf << 9) |
ed018b21d mmc_spi: generate... |
108 |
#define MMC_STATUS_ERROR (1 << 19) |
5d4fc8d90 mmc: checking sta... |
109 |
|
d617c426a mmc: make mmc_sen... |
110 |
#define MMC_STATE_PRG (7 << 9) |
272cc70b2 Add MMC Framework |
111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 |
#define MMC_VDD_165_195 0x00000080 /* VDD voltage 1.65 - 1.95 */ #define MMC_VDD_20_21 0x00000100 /* VDD voltage 2.0 ~ 2.1 */ #define MMC_VDD_21_22 0x00000200 /* VDD voltage 2.1 ~ 2.2 */ #define MMC_VDD_22_23 0x00000400 /* VDD voltage 2.2 ~ 2.3 */ #define MMC_VDD_23_24 0x00000800 /* VDD voltage 2.3 ~ 2.4 */ #define MMC_VDD_24_25 0x00001000 /* VDD voltage 2.4 ~ 2.5 */ #define MMC_VDD_25_26 0x00002000 /* VDD voltage 2.5 ~ 2.6 */ #define MMC_VDD_26_27 0x00004000 /* VDD voltage 2.6 ~ 2.7 */ #define MMC_VDD_27_28 0x00008000 /* VDD voltage 2.7 ~ 2.8 */ #define MMC_VDD_28_29 0x00010000 /* VDD voltage 2.8 ~ 2.9 */ #define MMC_VDD_29_30 0x00020000 /* VDD voltage 2.9 ~ 3.0 */ #define MMC_VDD_30_31 0x00040000 /* VDD voltage 3.0 ~ 3.1 */ #define MMC_VDD_31_32 0x00080000 /* VDD voltage 3.1 ~ 3.2 */ #define MMC_VDD_32_33 0x00100000 /* VDD voltage 3.2 ~ 3.3 */ #define MMC_VDD_33_34 0x00200000 /* VDD voltage 3.3 ~ 3.4 */ #define MMC_VDD_34_35 0x00400000 /* VDD voltage 3.4 ~ 3.5 */ #define MMC_VDD_35_36 0x00800000 /* VDD voltage 3.5 ~ 3.6 */ #define MMC_SWITCH_MODE_CMD_SET 0x00 /* Change the command set */ #define MMC_SWITCH_MODE_SET_BITS 0x01 /* Set bits in EXT_CSD byte addressed by index which are 1 in value field */ #define MMC_SWITCH_MODE_CLEAR_BITS 0x02 /* Clear bits in EXT_CSD byte addressed by index, which are 1 in value field */ #define MMC_SWITCH_MODE_WRITE_BYTE 0x03 /* Set target byte to value */ #define SD_SWITCH_CHECK 0 #define SD_SWITCH_SWITCH 1 /* * EXT_CSD fields */ |
f866a46d6 mmc: report capac... |
144 |
#define EXT_CSD_GP_SIZE_MULT 143 /* R/W */ |
1937e5aa3 mmc: Fix erase_gr... |
145 |
#define EXT_CSD_PARTITIONS_ATTRIBUTE 156 /* R/W */ |
0560db18e mmc: change magic... |
146 |
#define EXT_CSD_PARTITIONING_SUPPORT 160 /* RO */ |
f866a46d6 mmc: report capac... |
147 |
#define EXT_CSD_RPMB_MULT 168 /* RO */ |
0560db18e mmc: change magic... |
148 |
#define EXT_CSD_ERASE_GROUP_DEF 175 /* R/W */ |
3690d6d66 MMC: APIs to supp... |
149 |
#define EXT_CSD_BOOT_BUS_WIDTH 177 |
0560db18e mmc: change magic... |
150 151 152 153 154 155 |
#define EXT_CSD_PART_CONF 179 /* R/W */ #define EXT_CSD_BUS_WIDTH 183 /* R/W */ #define EXT_CSD_HS_TIMING 185 /* R/W */ #define EXT_CSD_REV 192 /* RO */ #define EXT_CSD_CARD_TYPE 196 /* RO */ #define EXT_CSD_SEC_CNT 212 /* RO, 4 bytes */ |
f866a46d6 mmc: report capac... |
156 |
#define EXT_CSD_HC_WP_GRP_SIZE 221 /* RO */ |
0560db18e mmc: change magic... |
157 |
#define EXT_CSD_HC_ERASE_GRP_SIZE 224 /* RO */ |
8948ea830 mmc: detect boot ... |
158 |
#define EXT_CSD_BOOT_MULT 226 /* RO */ |
272cc70b2 Add MMC Framework |
159 160 161 162 |
/* * EXT_CSD field definitions */ |
abe2c93ff mmc: coding style... |
163 164 165 |
#define EXT_CSD_CMD_SET_NORMAL (1 << 0) #define EXT_CSD_CMD_SET_SECURE (1 << 1) #define EXT_CSD_CMD_SET_CPSECURE (1 << 2) |
272cc70b2 Add MMC Framework |
166 |
|
abe2c93ff mmc: coding style... |
167 168 |
#define EXT_CSD_CARD_TYPE_26 (1 << 0) /* Card can run at 26MHz */ #define EXT_CSD_CARD_TYPE_52 (1 << 1) /* Card can run at 52MHz */ |
272cc70b2 Add MMC Framework |
169 170 171 172 |
#define EXT_CSD_BUS_WIDTH_1 0 /* Card is in 1 bit mode */ #define EXT_CSD_BUS_WIDTH_4 1 /* Card is in 4 bit mode */ #define EXT_CSD_BUS_WIDTH_8 2 /* Card is in 8 bit mode */ |
341188b9c MMC: Consolidate ... |
173 |
|
3690d6d66 MMC: APIs to supp... |
174 175 176 177 178 179 180 181 |
#define EXT_CSD_BOOT_ACK_ENABLE (1 << 6) #define EXT_CSD_BOOT_PARTITION_ENABLE (1 << 3) #define EXT_CSD_PARTITION_ACCESS_ENABLE (1 << 0) #define EXT_CSD_PARTITION_ACCESS_DISABLE (0 << 0) #define EXT_CSD_BOOT_ACK(x) (x << 6) #define EXT_CSD_BOOT_PART_NUM(x) (x << 3) #define EXT_CSD_PARTITION_ACCESS(x) (x << 0) |
5a99b9de1 cmd_mmc.c: Add bo... |
182 183 184 |
#define EXT_CSD_BOOT_BUS_WIDTH_MODE(x) (x << 3) #define EXT_CSD_BOOT_BUS_WIDTH_RESET(x) (x << 2) #define EXT_CSD_BOOT_BUS_WIDTH_WIDTH(x) (x) |
3690d6d66 MMC: APIs to supp... |
185 |
|
1de97f985 Eliminated arch-s... |
186 187 |
#define R1_ILLEGAL_COMMAND (1 << 22) #define R1_APP_CMD (1 << 5) |
272cc70b2 Add MMC Framework |
188 |
#define MMC_RSP_PRESENT (1 << 0) |
abe2c93ff mmc: coding style... |
189 190 191 192 |
#define MMC_RSP_136 (1 << 1) /* 136 bit response */ #define MMC_RSP_CRC (1 << 2) /* expect valid crc */ #define MMC_RSP_BUSY (1 << 3) /* card may send busy */ #define MMC_RSP_OPCODE (1 << 4) /* response contains opcode */ |
272cc70b2 Add MMC Framework |
193 |
|
abe2c93ff mmc: coding style... |
194 195 |
#define MMC_RSP_NONE (0) #define MMC_RSP_R1 (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE) |
272cc70b2 Add MMC Framework |
196 197 |
#define MMC_RSP_R1b (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE| \ MMC_RSP_BUSY) |
abe2c93ff mmc: coding style... |
198 199 200 201 202 203 |
#define MMC_RSP_R2 (MMC_RSP_PRESENT|MMC_RSP_136|MMC_RSP_CRC) #define MMC_RSP_R3 (MMC_RSP_PRESENT) #define MMC_RSP_R4 (MMC_RSP_PRESENT) #define MMC_RSP_R5 (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE) #define MMC_RSP_R6 (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE) #define MMC_RSP_R7 (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE) |
272cc70b2 Add MMC Framework |
204 |
|
bc897b1d4 mmc: enable parti... |
205 206 207 |
#define MMCPART_NOAVAILABLE (0xff) #define PART_ACCESS_MASK (0x7) #define PART_SUPPORT (0x1) |
1937e5aa3 mmc: Fix erase_gr... |
208 |
#define PART_ENH_ATTRIB (0x1f) |
71f951180 * Fix CONFIG_NET_... |
209 |
|
8bfa195e4 mmc: Define a con... |
210 211 |
/* Maximum block size for MMC */ #define MMC_MAX_BLOCK_LEN 512 |
3690d6d66 MMC: APIs to supp... |
212 213 214 215 |
/* The number of MMC physical partitions. These consist of: * boot partitions (2), general purpose partitions (4) in MMC v4.4. */ #define MMC_NUM_BOOT_PARTITION 2 |
1de97f985 Eliminated arch-s... |
216 217 218 219 220 221 222 223 |
struct mmc_cid { unsigned long psn; unsigned short oid; unsigned char mid; unsigned char prv; unsigned char mdt; char pnm[7]; }; |
272cc70b2 Add MMC Framework |
224 225 226 227 |
struct mmc_cmd { ushort cmdidx; uint resp_type; uint cmdarg; |
0b453ffe2 mmc: fix response... |
228 |
uint response[4]; |
272cc70b2 Add MMC Framework |
229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 |
}; struct mmc_data { union { char *dest; const char *src; /* src buffers don't get written to */ }; uint flags; uint blocks; uint blocksize; }; struct mmc { struct list_head link; char name[32]; void *priv; uint voltages; uint version; |
bc897b1d4 mmc: enable parti... |
247 |
uint has_init; |
272cc70b2 Add MMC Framework |
248 249 250 251 252 253 254 255 |
uint f_min; uint f_max; int high_capacity; uint bus_width; uint clock; uint card_caps; uint host_caps; uint ocr; |
ab71188ce mmc: add setdsr s... |
256 257 |
uint dsr; uint dsr_imp; |
272cc70b2 Add MMC Framework |
258 259 |
uint scr[2]; uint csd[4]; |
0b453ffe2 mmc: fix response... |
260 |
uint cid[4]; |
272cc70b2 Add MMC Framework |
261 |
ushort rca; |
bc897b1d4 mmc: enable parti... |
262 263 |
char part_config; char part_num; |
272cc70b2 Add MMC Framework |
264 265 266 |
uint tran_speed; uint read_bl_len; uint write_bl_len; |
e6f99a561 MMC: add erase fu... |
267 |
uint erase_grp_size; |
272cc70b2 Add MMC Framework |
268 |
u64 capacity; |
f866a46d6 mmc: report capac... |
269 270 271 272 |
u64 capacity_user; u64 capacity_boot; u64 capacity_rpmb; u64 capacity_gp[4]; |
272cc70b2 Add MMC Framework |
273 274 275 276 277 |
block_dev_desc_t block_dev; int (*send_cmd)(struct mmc *mmc, struct mmc_cmd *cmd, struct mmc_data *data); void (*set_ios)(struct mmc *mmc); int (*init)(struct mmc *mmc); |
48972d907 mmc: Implement ca... |
278 |
int (*getcd)(struct mmc *mmc); |
d23d8d7e0 mmc: add support ... |
279 |
int (*getwp)(struct mmc *mmc); |
57418d213 Davinci MMCSD Sup... |
280 |
uint b_max; |
e95504497 mmc: Split device... |
281 282 283 284 |
char op_cond_pending; /* 1 if we are waiting on an op_cond command */ char init_in_progress; /* 1 if we have done mmc_start_init() */ char preinit; /* start init as early as possible */ uint op_cond_response; /* the response byte from the last op_cond */ |
272cc70b2 Add MMC Framework |
285 286 287 288 289 290 |
}; int mmc_register(struct mmc *mmc); int mmc_initialize(bd_t *bis); int mmc_init(struct mmc *mmc); int mmc_read(struct mmc *mmc, u64 src, uchar *dst, int size); |
4a6ee172c fsl_esdhc: Use mm... |
291 |
void mmc_set_clock(struct mmc *mmc, uint clock); |
272cc70b2 Add MMC Framework |
292 |
struct mmc *find_mmc_device(int dev_num); |
89716964d mmc: add function... |
293 |
int mmc_set_dev(int dev_num); |
272cc70b2 Add MMC Framework |
294 |
void print_mmc_devices(char separator); |
ea6ebe217 cmd_mmc: eliminat... |
295 |
int get_mmc_num(void); |
314284b15 mmc: Change board... |
296 |
int board_mmc_getcd(struct mmc *mmc); |
bc897b1d4 mmc: enable parti... |
297 |
int mmc_switch_part(int dev_num, unsigned int part_num); |
48972d907 mmc: Implement ca... |
298 |
int mmc_getcd(struct mmc *mmc); |
d23d8d7e0 mmc: add support ... |
299 |
int mmc_getwp(struct mmc *mmc); |
ab71188ce mmc: add setdsr s... |
300 |
int mmc_set_dsr(struct mmc *mmc, u16 val); |
3690d6d66 MMC: APIs to supp... |
301 302 303 |
/* Function to change the size of boot partition and rpmb partitions */ int mmc_boot_partition_size_change(struct mmc *mmc, unsigned long bootsize, unsigned long rpmbsize); |
792970b0a cmd_mmc.c: Add 'p... |
304 305 |
/* Function to modify the PARTITION_CONFIG field of EXT_CSD */ int mmc_set_part_conf(struct mmc *mmc, u8 ack, u8 part_num, u8 access); |
5a99b9de1 cmd_mmc.c: Add bo... |
306 307 |
/* Function to modify the BOOT_BUS_WIDTH field of EXT_CSD */ int mmc_set_boot_bus_width(struct mmc *mmc, u8 width, u8 reset, u8 mode); |
272cc70b2 Add MMC Framework |
308 |
|
e95504497 mmc: Split device... |
309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 |
/** * Start device initialization and return immediately; it does not block on * polling OCR (operation condition register) status. Then you should call * mmc_init, which would block on polling OCR status and complete the device * initializatin. * * @param mmc Pointer to a MMC device struct * @return 0 on success, IN_PROGRESS on waiting for OCR status, <0 on error. */ int mmc_start_init(struct mmc *mmc); /** * Set preinit flag of mmc device. * * This will cause the device to be pre-inited during mmc_initialize(), * which may save boot time if the device is not accessed until later. * Some eMMC devices take 200-300ms to init, but unfortunately they * must be sent a series of commands to even get them to start preparing * for operation. * * @param mmc Pointer to a MMC device struct * @param preinit preinit flag value */ void mmc_set_preinit(struct mmc *mmc, int preinit); |
1592ef859 AT91: MCI: add SD... |
333 |
#ifdef CONFIG_GENERIC_MMC |
8687d5c80 mmc: size optimiz... |
334 |
#ifdef CONFIG_MMC_SPI |
d52ebf102 mmc: add generic ... |
335 |
#define mmc_host_is_spi(mmc) ((mmc)->host_caps & MMC_MODE_SPI) |
8687d5c80 mmc: size optimiz... |
336 337 338 |
#else #define mmc_host_is_spi(mmc) 0 #endif |
d52ebf102 mmc: add generic ... |
339 |
struct mmc *mmc_spi_init(uint bus, uint cs, uint speed, uint mode); |
1592ef859 AT91: MCI: add SD... |
340 |
#else |
272cc70b2 Add MMC Framework |
341 342 |
int mmc_legacy_init(int verbose); #endif |
1592ef859 AT91: MCI: add SD... |
343 |
|
71f951180 * Fix CONFIG_NET_... |
344 |
#endif /* _MMC_H_ */ |