| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* | 
|  | 2 | *  linux/include/linux/mmc/card.h | 
|  | 3 | * | 
|  | 4 | * This program is free software; you can redistribute it and/or modify | 
|  | 5 | * it under the terms of the GNU General Public License version 2 as | 
|  | 6 | * published by the Free Software Foundation. | 
|  | 7 | * | 
|  | 8 | *  Card driver specific definitions. | 
|  | 9 | */ | 
|  | 10 | #ifndef LINUX_MMC_CARD_H | 
|  | 11 | #define LINUX_MMC_CARD_H | 
|  | 12 |  | 
| Pierre Ossman | aaac1b4 | 2007-02-28 15:33:10 +0100 | [diff] [blame] | 13 | #include <linux/mmc/core.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 |  | 
|  | 15 | struct mmc_cid { | 
|  | 16 | unsigned int		manfid; | 
|  | 17 | char			prod_name[8]; | 
|  | 18 | unsigned int		serial; | 
|  | 19 | unsigned short		oemid; | 
|  | 20 | unsigned short		year; | 
|  | 21 | unsigned char		hwrev; | 
|  | 22 | unsigned char		fwrev; | 
|  | 23 | unsigned char		month; | 
|  | 24 | }; | 
|  | 25 |  | 
|  | 26 | struct mmc_csd { | 
| Kyungmin Park | 6da24b7 | 2010-08-10 18:01:36 -0700 | [diff] [blame] | 27 | unsigned char		structure; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 28 | unsigned char		mmca_vsn; | 
|  | 29 | unsigned short		cmdclass; | 
|  | 30 | unsigned short		tacc_clks; | 
|  | 31 | unsigned int		tacc_ns; | 
| Russell King | 37be4e7 | 2006-05-02 17:24:59 +0100 | [diff] [blame] | 32 | unsigned int		r2w_factor; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 33 | unsigned int		max_dtr; | 
| Adrian Hunter | dfe86cb | 2010-08-11 14:17:46 -0700 | [diff] [blame] | 34 | unsigned int		erase_size;		/* In sectors */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 35 | unsigned int		read_blkbits; | 
| Russell King | a6f6c96 | 2006-01-03 22:38:44 +0000 | [diff] [blame] | 36 | unsigned int		write_blkbits; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 37 | unsigned int		capacity; | 
| Russell King | a6f6c96 | 2006-01-03 22:38:44 +0000 | [diff] [blame] | 38 | unsigned int		read_partial:1, | 
|  | 39 | read_misalign:1, | 
| Russell King | ce11a16 | 2006-01-04 12:40:39 +0000 | [diff] [blame] | 40 | write_partial:1, | 
| Russell King | a6f6c96 | 2006-01-03 22:38:44 +0000 | [diff] [blame] | 41 | write_misalign:1; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 42 | }; | 
|  | 43 |  | 
| Philip Langdale | bce40a3 | 2006-10-21 12:35:02 +0200 | [diff] [blame] | 44 | struct mmc_ext_csd { | 
| Jarkko Lavinen | b1ebe38 | 2009-09-22 16:44:34 -0700 | [diff] [blame] | 45 | u8			rev; | 
| Adrian Hunter | dfe86cb | 2010-08-11 14:17:46 -0700 | [diff] [blame] | 46 | u8			erase_group_def; | 
|  | 47 | u8			sec_feature_support; | 
| Jarkko Lavinen | b1ebe38 | 2009-09-22 16:44:34 -0700 | [diff] [blame] | 48 | unsigned int		sa_timeout;		/* Units: 100ns */ | 
| Philip Langdale | bce40a3 | 2006-10-21 12:35:02 +0200 | [diff] [blame] | 49 | unsigned int		hs_max_dtr; | 
| Pierre Ossman | 85a18ad | 2007-02-17 22:15:27 +0100 | [diff] [blame] | 50 | unsigned int		sectors; | 
| Hanumath Prasad | dfc13e8 | 2010-09-30 17:37:23 -0400 | [diff] [blame] | 51 | unsigned int		card_type; | 
| Adrian Hunter | dfe86cb | 2010-08-11 14:17:46 -0700 | [diff] [blame] | 52 | unsigned int		hc_erase_size;		/* In sectors */ | 
|  | 53 | unsigned int		hc_erase_timeout;	/* In milliseconds */ | 
|  | 54 | unsigned int		sec_trim_mult;	/* Secure trim multiplier  */ | 
|  | 55 | unsigned int		sec_erase_mult;	/* Secure erase multiplier */ | 
|  | 56 | unsigned int		trim_timeout;		/* In milliseconds */ | 
| Chuanxiao Dong | 709de99 | 2011-01-22 04:09:41 +0800 | [diff] [blame] | 57 | bool			enhanced_area_en;	/* enable bit */ | 
|  | 58 | unsigned long long	enhanced_area_offset;	/* Units: Byte */ | 
|  | 59 | unsigned int		enhanced_area_size;	/* Units: KB */ | 
| Philip Langdale | bce40a3 | 2006-10-21 12:35:02 +0200 | [diff] [blame] | 60 | }; | 
|  | 61 |  | 
| Pierre Ossman | b57c43a | 2005-09-06 15:18:53 -0700 | [diff] [blame] | 62 | struct sd_scr { | 
|  | 63 | unsigned char		sda_vsn; | 
|  | 64 | unsigned char		bus_widths; | 
|  | 65 | #define SD_SCR_BUS_WIDTH_1	(1<<0) | 
|  | 66 | #define SD_SCR_BUS_WIDTH_4	(1<<2) | 
|  | 67 | }; | 
|  | 68 |  | 
| Adrian Hunter | dfe86cb | 2010-08-11 14:17:46 -0700 | [diff] [blame] | 69 | struct sd_ssr { | 
|  | 70 | unsigned int		au;			/* In sectors */ | 
|  | 71 | unsigned int		erase_timeout;		/* In milliseconds */ | 
|  | 72 | unsigned int		erase_offset;		/* In milliseconds */ | 
|  | 73 | }; | 
|  | 74 |  | 
| Pierre Ossman | 7ccd266 | 2006-11-08 23:03:10 +0100 | [diff] [blame] | 75 | struct sd_switch_caps { | 
|  | 76 | unsigned int		hs_max_dtr; | 
|  | 77 | }; | 
|  | 78 |  | 
| Pierre Ossman | 35c66c1 | 2007-06-11 20:25:43 +0200 | [diff] [blame] | 79 | struct sdio_cccr { | 
|  | 80 | unsigned int		sdio_vsn; | 
|  | 81 | unsigned int		sd_vsn; | 
|  | 82 | unsigned int		multi_block:1, | 
|  | 83 | low_speed:1, | 
|  | 84 | wide_bus:1, | 
|  | 85 | high_power:1, | 
| Ohad Ben-Cohen | 006ebd5 | 2009-09-22 16:45:07 -0700 | [diff] [blame] | 86 | high_speed:1, | 
|  | 87 | disable_cd:1; | 
| Pierre Ossman | 35c66c1 | 2007-06-11 20:25:43 +0200 | [diff] [blame] | 88 | }; | 
|  | 89 |  | 
| Pierre Ossman | 1a632f8 | 2007-07-30 15:15:30 +0200 | [diff] [blame] | 90 | struct sdio_cis { | 
|  | 91 | unsigned short		vendor; | 
|  | 92 | unsigned short		device; | 
|  | 93 | unsigned short		blksize; | 
|  | 94 | unsigned int		max_dtr; | 
|  | 95 | }; | 
|  | 96 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 97 | struct mmc_host; | 
| Pierre Ossman | e29a7d7 | 2007-05-26 13:48:18 +0200 | [diff] [blame] | 98 | struct sdio_func; | 
| Pierre Ossman | 1a632f8 | 2007-07-30 15:15:30 +0200 | [diff] [blame] | 99 | struct sdio_func_tuple; | 
| Pierre Ossman | e29a7d7 | 2007-05-26 13:48:18 +0200 | [diff] [blame] | 100 |  | 
|  | 101 | #define SDIO_MAX_FUNCS		7 | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 102 |  | 
|  | 103 | /* | 
|  | 104 | * MMC device | 
|  | 105 | */ | 
|  | 106 | struct mmc_card { | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 107 | struct mmc_host		*host;		/* the host this device belongs to */ | 
|  | 108 | struct device		dev;		/* the device */ | 
|  | 109 | unsigned int		rca;		/* relative card address of device */ | 
| Pierre Ossman | 9c2c0af | 2006-12-26 15:25:58 +0100 | [diff] [blame] | 110 | unsigned int		type;		/* card type */ | 
|  | 111 | #define MMC_TYPE_MMC		0		/* MMC card */ | 
|  | 112 | #define MMC_TYPE_SD		1		/* SD card */ | 
| Pierre Ossman | 5c4e6f1 | 2007-05-21 20:23:20 +0200 | [diff] [blame] | 113 | #define MMC_TYPE_SDIO		2		/* SDIO card */ | 
| Michal Miroslaw | 7310ece | 2010-08-10 18:01:40 -0700 | [diff] [blame] | 114 | #define MMC_TYPE_SD_COMBO	3		/* SD combo (IO+mem) card */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 115 | unsigned int		state;		/* (our) card state */ | 
|  | 116 | #define MMC_STATE_PRESENT	(1<<0)		/* present in sysfs */ | 
| Pierre Ossman | bd76631 | 2007-05-01 16:11:57 +0200 | [diff] [blame] | 117 | #define MMC_STATE_READONLY	(1<<1)		/* card is read-only */ | 
|  | 118 | #define MMC_STATE_HIGHSPEED	(1<<2)		/* card is in high speed mode */ | 
|  | 119 | #define MMC_STATE_BLOCKADDR	(1<<3)		/* card uses block-addressing */ | 
| Hanumath Prasad | dfc13e8 | 2010-09-30 17:37:23 -0400 | [diff] [blame] | 120 | #define MMC_STATE_HIGHSPEED_DDR (1<<4)		/* card is in high speed mode */ | 
| Ohad Ben-Cohen | 7c979ec | 2009-09-22 16:45:18 -0700 | [diff] [blame] | 121 | unsigned int		quirks; 	/* card quirks */ | 
|  | 122 | #define MMC_QUIRK_LENIENT_FN0	(1<<0)		/* allow SDIO FN0 writes outside of the VS CCCR range */ | 
| Bing Zhao | 3fb7fb4 | 2010-03-05 13:43:25 -0800 | [diff] [blame] | 123 | #define MMC_QUIRK_BLKSZ_FOR_BYTE_MODE (1<<1)	/* use func->cur_blksize */ | 
|  | 124 | /* for byte mode */ | 
| Grazvydas Ignotas | 6f51be3 | 2010-08-10 18:01:50 -0700 | [diff] [blame] | 125 | #define MMC_QUIRK_NONSTD_SDIO	(1<<2)		/* non-standard SDIO card attached */ | 
|  | 126 | /* (missing CIA registers) */ | 
| Pierre Tardy | db99350 | 2011-02-06 19:03:47 +0100 | [diff] [blame] | 127 | #define MMC_QUIRK_BROKEN_CLK_GATING (1<<3)	/* clock gating the sdio bus will make card fail */ | 
| Pierre Ossman | e29a7d7 | 2007-05-26 13:48:18 +0200 | [diff] [blame] | 128 |  | 
| Adrian Hunter | dfe86cb | 2010-08-11 14:17:46 -0700 | [diff] [blame] | 129 | unsigned int		erase_size;	/* erase size in sectors */ | 
|  | 130 | unsigned int		erase_shift;	/* if erase unit is power 2 */ | 
|  | 131 | unsigned int		pref_erase;	/* in sectors */ | 
|  | 132 | u8			erased_byte;	/* value of erased bytes */ | 
|  | 133 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 134 | u32			raw_cid[4];	/* raw card CID */ | 
|  | 135 | u32			raw_csd[4];	/* raw card CSD */ | 
| Pierre Ossman | b57c43a | 2005-09-06 15:18:53 -0700 | [diff] [blame] | 136 | u32			raw_scr[2];	/* raw card SCR */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 137 | struct mmc_cid		cid;		/* card identification */ | 
|  | 138 | struct mmc_csd		csd;		/* card specific */ | 
| Philip Langdale | bce40a3 | 2006-10-21 12:35:02 +0200 | [diff] [blame] | 139 | struct mmc_ext_csd	ext_csd;	/* mmc v4 extended card specific */ | 
| Pierre Ossman | b57c43a | 2005-09-06 15:18:53 -0700 | [diff] [blame] | 140 | struct sd_scr		scr;		/* extra SD information */ | 
| Adrian Hunter | dfe86cb | 2010-08-11 14:17:46 -0700 | [diff] [blame] | 141 | struct sd_ssr		ssr;		/* yet more SD information */ | 
| Pierre Ossman | 7ccd266 | 2006-11-08 23:03:10 +0100 | [diff] [blame] | 142 | struct sd_switch_caps	sw_caps;	/* switch (CMD6) caps */ | 
| Pierre Ossman | e29a7d7 | 2007-05-26 13:48:18 +0200 | [diff] [blame] | 143 |  | 
|  | 144 | unsigned int		sdio_funcs;	/* number of SDIO functions */ | 
| Pierre Ossman | 35c66c1 | 2007-06-11 20:25:43 +0200 | [diff] [blame] | 145 | struct sdio_cccr	cccr;		/* common card info */ | 
| Pierre Ossman | 1a632f8 | 2007-07-30 15:15:30 +0200 | [diff] [blame] | 146 | struct sdio_cis		cis;		/* common tuple info */ | 
| Pierre Ossman | e29a7d7 | 2007-05-26 13:48:18 +0200 | [diff] [blame] | 147 | struct sdio_func	*sdio_func[SDIO_MAX_FUNCS]; /* SDIO functions (devices) */ | 
| Pierre Ossman | 759bdc7 | 2007-09-19 18:42:16 +0200 | [diff] [blame] | 148 | unsigned		num_info;	/* number of info strings */ | 
|  | 149 | const char		**info;		/* info strings */ | 
| Pierre Ossman | 1a632f8 | 2007-07-30 15:15:30 +0200 | [diff] [blame] | 150 | struct sdio_func_tuple	*tuples;	/* unknown common tuples */ | 
| Haavard Skinnemoen | f4b7f92 | 2008-07-24 14:18:58 +0200 | [diff] [blame] | 151 |  | 
|  | 152 | struct dentry		*debugfs_root; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 153 | }; | 
|  | 154 |  | 
| Pierre Tardy | 57f0adc | 2011-02-06 19:03:46 +0100 | [diff] [blame] | 155 | void mmc_fixup_device(struct mmc_card *dev); | 
|  | 156 |  | 
| Pierre Ossman | 9c2c0af | 2006-12-26 15:25:58 +0100 | [diff] [blame] | 157 | #define mmc_card_mmc(c)		((c)->type == MMC_TYPE_MMC) | 
|  | 158 | #define mmc_card_sd(c)		((c)->type == MMC_TYPE_SD) | 
| Pierre Ossman | 5c4e6f1 | 2007-05-21 20:23:20 +0200 | [diff] [blame] | 159 | #define mmc_card_sdio(c)	((c)->type == MMC_TYPE_SDIO) | 
| Pierre Ossman | 9c2c0af | 2006-12-26 15:25:58 +0100 | [diff] [blame] | 160 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 161 | #define mmc_card_present(c)	((c)->state & MMC_STATE_PRESENT) | 
| Pierre Ossman | a00fc09 | 2005-09-06 15:18:52 -0700 | [diff] [blame] | 162 | #define mmc_card_readonly(c)	((c)->state & MMC_STATE_READONLY) | 
| Philip Langdale | bce40a3 | 2006-10-21 12:35:02 +0200 | [diff] [blame] | 163 | #define mmc_card_highspeed(c)	((c)->state & MMC_STATE_HIGHSPEED) | 
| Philip Langdale | fba68bd | 2007-01-04 06:57:32 -0800 | [diff] [blame] | 164 | #define mmc_card_blockaddr(c)	((c)->state & MMC_STATE_BLOCKADDR) | 
| Hanumath Prasad | dfc13e8 | 2010-09-30 17:37:23 -0400 | [diff] [blame] | 165 | #define mmc_card_ddr_mode(c)	((c)->state & MMC_STATE_HIGHSPEED_DDR) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 166 |  | 
|  | 167 | #define mmc_card_set_present(c)	((c)->state |= MMC_STATE_PRESENT) | 
| Pierre Ossman | a00fc09 | 2005-09-06 15:18:52 -0700 | [diff] [blame] | 168 | #define mmc_card_set_readonly(c) ((c)->state |= MMC_STATE_READONLY) | 
| Philip Langdale | bce40a3 | 2006-10-21 12:35:02 +0200 | [diff] [blame] | 169 | #define mmc_card_set_highspeed(c) ((c)->state |= MMC_STATE_HIGHSPEED) | 
| Philip Langdale | fba68bd | 2007-01-04 06:57:32 -0800 | [diff] [blame] | 170 | #define mmc_card_set_blockaddr(c) ((c)->state |= MMC_STATE_BLOCKADDR) | 
| Hanumath Prasad | dfc13e8 | 2010-09-30 17:37:23 -0400 | [diff] [blame] | 171 | #define mmc_card_set_ddr_mode(c) ((c)->state |= MMC_STATE_HIGHSPEED_DDR) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 172 |  | 
| Ohad Ben-Cohen | 7c979ec | 2009-09-22 16:45:18 -0700 | [diff] [blame] | 173 | static inline int mmc_card_lenient_fn0(const struct mmc_card *c) | 
|  | 174 | { | 
|  | 175 | return c->quirks & MMC_QUIRK_LENIENT_FN0; | 
|  | 176 | } | 
|  | 177 |  | 
| Bing Zhao | 3fb7fb4 | 2010-03-05 13:43:25 -0800 | [diff] [blame] | 178 | static inline int mmc_blksz_for_byte_mode(const struct mmc_card *c) | 
|  | 179 | { | 
|  | 180 | return c->quirks & MMC_QUIRK_BLKSZ_FOR_BYTE_MODE; | 
|  | 181 | } | 
|  | 182 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 183 | #define mmc_card_name(c)	((c)->cid.prod_name) | 
| Kay Sievers | d1b2686 | 2008-11-08 21:37:46 +0100 | [diff] [blame] | 184 | #define mmc_card_id(c)		(dev_name(&(c)->dev)) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 185 |  | 
| Andy Shevchenko | 265cdc9 | 2010-09-17 20:32:25 -0400 | [diff] [blame] | 186 | #define mmc_dev_to_card(d)	container_of(d, struct mmc_card, dev) | 
| Andy Shevchenko | 453722b | 2010-08-20 10:46:46 +0300 | [diff] [blame] | 187 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 188 | #define mmc_list_to_card(l)	container_of(l, struct mmc_card, node) | 
|  | 189 | #define mmc_get_drvdata(c)	dev_get_drvdata(&(c)->dev) | 
|  | 190 | #define mmc_set_drvdata(c,d)	dev_set_drvdata(&(c)->dev, d) | 
|  | 191 |  | 
|  | 192 | /* | 
|  | 193 | * MMC device driver (e.g., Flash card, I/O card...) | 
|  | 194 | */ | 
|  | 195 | struct mmc_driver { | 
|  | 196 | struct device_driver drv; | 
|  | 197 | int (*probe)(struct mmc_card *); | 
|  | 198 | void (*remove)(struct mmc_card *); | 
|  | 199 | int (*suspend)(struct mmc_card *, pm_message_t); | 
|  | 200 | int (*resume)(struct mmc_card *); | 
|  | 201 | }; | 
|  | 202 |  | 
|  | 203 | extern int mmc_register_driver(struct mmc_driver *); | 
|  | 204 | extern void mmc_unregister_driver(struct mmc_driver *); | 
|  | 205 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 206 | #endif |