Blame view
include/mmc.h
8.46 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 7 8 9 10 11 12 13 14 15 16 |
* * See file CREDITS for list of people who contributed to this * project. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of |
abe2c93ff mmc: coding style... |
17 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
71f951180 * Fix CONFIG_NET_... |
18 19 20 21 22 23 24 25 26 27 |
* GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA */ #ifndef _MMC_H_ #define _MMC_H_ |
71f951180 * Fix CONFIG_NET_... |
28 |
|
272cc70b2 Add MMC Framework |
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
#include <linux/list.h> #define SD_VERSION_SD 0x20000 #define SD_VERSION_2 (SD_VERSION_SD | 0x20) #define SD_VERSION_1_0 (SD_VERSION_SD | 0x10) #define SD_VERSION_1_10 (SD_VERSION_SD | 0x1a) #define MMC_VERSION_MMC 0x10000 #define MMC_VERSION_UNKNOWN (MMC_VERSION_MMC) #define MMC_VERSION_1_2 (MMC_VERSION_MMC | 0x12) #define MMC_VERSION_1_4 (MMC_VERSION_MMC | 0x14) #define MMC_VERSION_2_2 (MMC_VERSION_MMC | 0x22) #define MMC_VERSION_3 (MMC_VERSION_MMC | 0x30) #define MMC_VERSION_4 (MMC_VERSION_MMC | 0x40) #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 ... |
47 |
#define MMC_MODE_SPI 0x400 |
b1f1e821d mmc: Access mode ... |
48 |
#define MMC_MODE_HC 0x800 |
272cc70b2 Add MMC Framework |
49 |
|
627220364 mmc:fix: Set mmc ... |
50 51 |
#define MMC_MODE_MASK_WIDTH_BITS (MMC_MODE_4BIT | MMC_MODE_8BIT) #define MMC_MODE_WIDTH_BITS_SHIFT 8 |
272cc70b2 Add MMC Framework |
52 |
#define SD_DATA_4BIT 0x00040000 |
79b91de95 include/mmc.h: Fi... |
53 |
#define IS_SD(x) (x->version & SD_VERSION_SD) |
272cc70b2 Add MMC Framework |
54 55 56 57 58 59 60 61 |
#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 |
341188b9c MMC: Consolidate ... |
62 63 64 65 66 |
#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 |
67 |
#define MMC_CMD_SWITCH 6 |
341188b9c MMC: Consolidate ... |
68 |
#define MMC_CMD_SELECT_CARD 7 |
272cc70b2 Add MMC Framework |
69 |
#define MMC_CMD_SEND_EXT_CSD 8 |
341188b9c MMC: Consolidate ... |
70 71 |
#define MMC_CMD_SEND_CSD 9 #define MMC_CMD_SEND_CID 10 |
272cc70b2 Add MMC Framework |
72 |
#define MMC_CMD_STOP_TRANSMISSION 12 |
341188b9c MMC: Consolidate ... |
73 74 75 76 |
#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 |
77 78 |
#define MMC_CMD_WRITE_SINGLE_BLOCK 24 #define MMC_CMD_WRITE_MULTIPLE_BLOCK 25 |
e6f99a561 MMC: add erase fu... |
79 80 81 |
#define MMC_CMD_ERASE_GROUP_START 35 #define MMC_CMD_ERASE_GROUP_END 36 #define MMC_CMD_ERASE 38 |
341188b9c MMC: Consolidate ... |
82 |
#define MMC_CMD_APP_CMD 55 |
d52ebf102 mmc: add generic ... |
83 84 |
#define MMC_CMD_SPI_READ_OCR 58 #define MMC_CMD_SPI_CRC_ON_OFF 59 |
341188b9c MMC: Consolidate ... |
85 |
|
341188b9c MMC: Consolidate ... |
86 |
#define SD_CMD_SEND_RELATIVE_ADDR 3 |
272cc70b2 Add MMC Framework |
87 |
#define SD_CMD_SWITCH_FUNC 6 |
341188b9c MMC: Consolidate ... |
88 89 90 |
#define SD_CMD_SEND_IF_COND 8 #define SD_CMD_APP_SET_BUS_WIDTH 6 |
e6f99a561 MMC: add erase fu... |
91 92 |
#define SD_CMD_ERASE_WR_BLK_START 32 #define SD_CMD_ERASE_WR_BLK_END 33 |
341188b9c MMC: Consolidate ... |
93 |
#define SD_CMD_APP_SEND_OP_COND 41 |
272cc70b2 Add MMC Framework |
94 95 96 97 98 99 100 101 |
#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... |
102 103 |
#define OCR_BUSY 0x80000000 #define OCR_HCS 0x40000000 |
31cacbabf mmc: SEND_OP_COND... |
104 105 |
#define OCR_VOLTAGE_MASK 0x007FFF80 #define OCR_ACCESS_MODE 0x60000000 |
272cc70b2 Add MMC Framework |
106 |
|
e6f99a561 MMC: add erase fu... |
107 |
#define SECURE_ERASE 0x80000000 |
5d4fc8d90 mmc: checking sta... |
108 |
#define MMC_STATUS_MASK (~0x0206BF7F) |
abe2c93ff mmc: coding style... |
109 110 |
#define MMC_STATUS_RDY_FOR_DATA (1 << 8) #define MMC_STATUS_CURR_STATE (0xf << 9) |
ed018b21d mmc_spi: generate... |
111 |
#define MMC_STATUS_ERROR (1 << 19) |
5d4fc8d90 mmc: checking sta... |
112 |
|
d617c426a mmc: make mmc_sen... |
113 |
#define MMC_STATE_PRG (7 << 9) |
272cc70b2 Add MMC Framework |
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 144 145 146 |
#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 */ |
0560db18e mmc: change magic... |
147 148 149 150 151 152 153 154 155 |
#define EXT_CSD_PARTITIONING_SUPPORT 160 /* RO */ #define EXT_CSD_ERASE_GROUP_DEF 175 /* R/W */ #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 */ #define EXT_CSD_HC_ERASE_GRP_SIZE 224 /* RO */ |
272cc70b2 Add MMC Framework |
156 157 158 159 |
/* * EXT_CSD field definitions */ |
abe2c93ff mmc: coding style... |
160 161 162 |
#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 |
163 |
|
abe2c93ff mmc: coding style... |
164 165 |
#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 |
166 167 168 169 |
#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 ... |
170 |
|
1de97f985 Eliminated arch-s... |
171 172 |
#define R1_ILLEGAL_COMMAND (1 << 22) #define R1_APP_CMD (1 << 5) |
272cc70b2 Add MMC Framework |
173 |
#define MMC_RSP_PRESENT (1 << 0) |
abe2c93ff mmc: coding style... |
174 175 176 177 |
#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 |
178 |
|
abe2c93ff mmc: coding style... |
179 180 |
#define MMC_RSP_NONE (0) #define MMC_RSP_R1 (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE) |
272cc70b2 Add MMC Framework |
181 182 |
#define MMC_RSP_R1b (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE| \ MMC_RSP_BUSY) |
abe2c93ff mmc: coding style... |
183 184 185 186 187 188 |
#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 |
189 |
|
bc897b1d4 mmc: enable parti... |
190 191 192 |
#define MMCPART_NOAVAILABLE (0xff) #define PART_ACCESS_MASK (0x7) #define PART_SUPPORT (0x1) |
71f951180 * Fix CONFIG_NET_... |
193 |
|
1de97f985 Eliminated arch-s... |
194 195 196 197 198 199 200 201 |
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 |
202 203 204 205 |
struct mmc_cmd { ushort cmdidx; uint resp_type; uint cmdarg; |
0b453ffe2 mmc: fix response... |
206 |
uint response[4]; |
272cc70b2 Add MMC Framework |
207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 |
uint flags; }; 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... |
226 |
uint has_init; |
272cc70b2 Add MMC Framework |
227 228 229 230 231 232 233 234 235 236 |
uint f_min; uint f_max; int high_capacity; uint bus_width; uint clock; uint card_caps; uint host_caps; uint ocr; uint scr[2]; uint csd[4]; |
0b453ffe2 mmc: fix response... |
237 |
uint cid[4]; |
272cc70b2 Add MMC Framework |
238 |
ushort rca; |
bc897b1d4 mmc: enable parti... |
239 240 |
char part_config; char part_num; |
272cc70b2 Add MMC Framework |
241 242 243 |
uint tran_speed; uint read_bl_len; uint write_bl_len; |
e6f99a561 MMC: add erase fu... |
244 |
uint erase_grp_size; |
272cc70b2 Add MMC Framework |
245 246 247 248 249 250 |
u64 capacity; 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... |
251 |
int (*getcd)(struct mmc *mmc); |
57418d213 Davinci MMCSD Sup... |
252 |
uint b_max; |
272cc70b2 Add MMC Framework |
253 254 255 256 257 258 |
}; 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... |
259 |
void mmc_set_clock(struct mmc *mmc, uint clock); |
272cc70b2 Add MMC Framework |
260 |
struct mmc *find_mmc_device(int dev_num); |
89716964d mmc: add function... |
261 |
int mmc_set_dev(int dev_num); |
272cc70b2 Add MMC Framework |
262 |
void print_mmc_devices(char separator); |
ea6ebe217 cmd_mmc: eliminat... |
263 |
int get_mmc_num(void); |
314284b15 mmc: Change board... |
264 |
int board_mmc_getcd(struct mmc *mmc); |
bc897b1d4 mmc: enable parti... |
265 |
int mmc_switch_part(int dev_num, unsigned int part_num); |
48972d907 mmc: Implement ca... |
266 |
int mmc_getcd(struct mmc *mmc); |
272cc70b2 Add MMC Framework |
267 |
|
1592ef859 AT91: MCI: add SD... |
268 |
#ifdef CONFIG_GENERIC_MMC |
d52ebf102 mmc: add generic ... |
269 270 |
#define mmc_host_is_spi(mmc) ((mmc)->host_caps & MMC_MODE_SPI) struct mmc *mmc_spi_init(uint bus, uint cs, uint speed, uint mode); |
1592ef859 AT91: MCI: add SD... |
271 |
#else |
272cc70b2 Add MMC Framework |
272 273 |
int mmc_legacy_init(int verbose); #endif |
1592ef859 AT91: MCI: add SD... |
274 |
|
71f951180 * Fix CONFIG_NET_... |
275 |
#endif /* _MMC_H_ */ |