| 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 { | 
 | 27 | 	unsigned char		mmca_vsn; | 
 | 28 | 	unsigned short		cmdclass; | 
 | 29 | 	unsigned short		tacc_clks; | 
 | 30 | 	unsigned int		tacc_ns; | 
| Russell King | 37be4e7 | 2006-05-02 17:24:59 +0100 | [diff] [blame] | 31 | 	unsigned int		r2w_factor; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 32 | 	unsigned int		max_dtr; | 
 | 33 | 	unsigned int		read_blkbits; | 
| Russell King | a6f6c96 | 2006-01-03 22:38:44 +0000 | [diff] [blame] | 34 | 	unsigned int		write_blkbits; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 35 | 	unsigned int		capacity; | 
| Russell King | a6f6c96 | 2006-01-03 22:38:44 +0000 | [diff] [blame] | 36 | 	unsigned int		read_partial:1, | 
 | 37 | 				read_misalign:1, | 
| Russell King | ce11a16 | 2006-01-04 12:40:39 +0000 | [diff] [blame] | 38 | 				write_partial:1, | 
| Russell King | a6f6c96 | 2006-01-03 22:38:44 +0000 | [diff] [blame] | 39 | 				write_misalign:1; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 40 | }; | 
 | 41 |  | 
| Philip Langdale | bce40a3 | 2006-10-21 12:35:02 +0200 | [diff] [blame] | 42 | struct mmc_ext_csd { | 
 | 43 | 	unsigned int		hs_max_dtr; | 
| Pierre Ossman | 85a18ad | 2007-02-17 22:15:27 +0100 | [diff] [blame] | 44 | 	unsigned int		sectors; | 
| Philip Langdale | bce40a3 | 2006-10-21 12:35:02 +0200 | [diff] [blame] | 45 | }; | 
 | 46 |  | 
| Pierre Ossman | b57c43a | 2005-09-06 15:18:53 -0700 | [diff] [blame] | 47 | struct sd_scr { | 
 | 48 | 	unsigned char		sda_vsn; | 
 | 49 | 	unsigned char		bus_widths; | 
 | 50 | #define SD_SCR_BUS_WIDTH_1	(1<<0) | 
 | 51 | #define SD_SCR_BUS_WIDTH_4	(1<<2) | 
 | 52 | }; | 
 | 53 |  | 
| Pierre Ossman | 7ccd266 | 2006-11-08 23:03:10 +0100 | [diff] [blame] | 54 | struct sd_switch_caps { | 
 | 55 | 	unsigned int		hs_max_dtr; | 
 | 56 | }; | 
 | 57 |  | 
| Pierre Ossman | 35c66c1 | 2007-06-11 20:25:43 +0200 | [diff] [blame] | 58 | struct sdio_cccr { | 
 | 59 | 	unsigned int		sdio_vsn; | 
 | 60 | 	unsigned int		sd_vsn; | 
 | 61 | 	unsigned int		multi_block:1, | 
 | 62 | 				low_speed:1, | 
 | 63 | 				wide_bus:1, | 
 | 64 | 				high_power:1, | 
 | 65 | 				high_speed:1; | 
 | 66 | }; | 
 | 67 |  | 
| Pierre Ossman | 1a632f8 | 2007-07-30 15:15:30 +0200 | [diff] [blame] | 68 | struct sdio_cis { | 
 | 69 | 	unsigned short		vendor; | 
 | 70 | 	unsigned short		device; | 
 | 71 | 	unsigned short		blksize; | 
 | 72 | 	unsigned int		max_dtr; | 
 | 73 | }; | 
 | 74 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 75 | struct mmc_host; | 
| Pierre Ossman | e29a7d7 | 2007-05-26 13:48:18 +0200 | [diff] [blame] | 76 | struct sdio_func; | 
| Pierre Ossman | 1a632f8 | 2007-07-30 15:15:30 +0200 | [diff] [blame] | 77 | struct sdio_func_tuple; | 
| Pierre Ossman | e29a7d7 | 2007-05-26 13:48:18 +0200 | [diff] [blame] | 78 |  | 
 | 79 | #define SDIO_MAX_FUNCS		7 | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 80 |  | 
 | 81 | /* | 
 | 82 |  * MMC device | 
 | 83 |  */ | 
 | 84 | struct mmc_card { | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 85 | 	struct mmc_host		*host;		/* the host this device belongs to */ | 
 | 86 | 	struct device		dev;		/* the device */ | 
 | 87 | 	unsigned int		rca;		/* relative card address of device */ | 
| Pierre Ossman | 9c2c0af | 2006-12-26 15:25:58 +0100 | [diff] [blame] | 88 | 	unsigned int		type;		/* card type */ | 
 | 89 | #define MMC_TYPE_MMC		0		/* MMC card */ | 
 | 90 | #define MMC_TYPE_SD		1		/* SD card */ | 
| Pierre Ossman | 5c4e6f1 | 2007-05-21 20:23:20 +0200 | [diff] [blame] | 91 | #define MMC_TYPE_SDIO		2		/* SDIO card */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 92 | 	unsigned int		state;		/* (our) card state */ | 
 | 93 | #define MMC_STATE_PRESENT	(1<<0)		/* present in sysfs */ | 
| Pierre Ossman | bd76631 | 2007-05-01 16:11:57 +0200 | [diff] [blame] | 94 | #define MMC_STATE_READONLY	(1<<1)		/* card is read-only */ | 
 | 95 | #define MMC_STATE_HIGHSPEED	(1<<2)		/* card is in high speed mode */ | 
 | 96 | #define MMC_STATE_BLOCKADDR	(1<<3)		/* card uses block-addressing */ | 
| Pierre Ossman | e29a7d7 | 2007-05-26 13:48:18 +0200 | [diff] [blame] | 97 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 98 | 	u32			raw_cid[4];	/* raw card CID */ | 
 | 99 | 	u32			raw_csd[4];	/* raw card CSD */ | 
| Pierre Ossman | b57c43a | 2005-09-06 15:18:53 -0700 | [diff] [blame] | 100 | 	u32			raw_scr[2];	/* raw card SCR */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 101 | 	struct mmc_cid		cid;		/* card identification */ | 
 | 102 | 	struct mmc_csd		csd;		/* card specific */ | 
| Philip Langdale | bce40a3 | 2006-10-21 12:35:02 +0200 | [diff] [blame] | 103 | 	struct mmc_ext_csd	ext_csd;	/* mmc v4 extended card specific */ | 
| Pierre Ossman | b57c43a | 2005-09-06 15:18:53 -0700 | [diff] [blame] | 104 | 	struct sd_scr		scr;		/* extra SD information */ | 
| Pierre Ossman | 7ccd266 | 2006-11-08 23:03:10 +0100 | [diff] [blame] | 105 | 	struct sd_switch_caps	sw_caps;	/* switch (CMD6) caps */ | 
| Pierre Ossman | e29a7d7 | 2007-05-26 13:48:18 +0200 | [diff] [blame] | 106 |  | 
 | 107 | 	unsigned int		sdio_funcs;	/* number of SDIO functions */ | 
| Pierre Ossman | 35c66c1 | 2007-06-11 20:25:43 +0200 | [diff] [blame] | 108 | 	struct sdio_cccr	cccr;		/* common card info */ | 
| Pierre Ossman | 1a632f8 | 2007-07-30 15:15:30 +0200 | [diff] [blame] | 109 | 	struct sdio_cis		cis;		/* common tuple info */ | 
| Pierre Ossman | e29a7d7 | 2007-05-26 13:48:18 +0200 | [diff] [blame] | 110 | 	struct sdio_func	*sdio_func[SDIO_MAX_FUNCS]; /* SDIO functions (devices) */ | 
| Pierre Ossman | 759bdc7 | 2007-09-19 18:42:16 +0200 | [diff] [blame] | 111 | 	unsigned		num_info;	/* number of info strings */ | 
 | 112 | 	const char		**info;		/* info strings */ | 
| Pierre Ossman | 1a632f8 | 2007-07-30 15:15:30 +0200 | [diff] [blame] | 113 | 	struct sdio_func_tuple	*tuples;	/* unknown common tuples */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 114 | }; | 
 | 115 |  | 
| Pierre Ossman | 9c2c0af | 2006-12-26 15:25:58 +0100 | [diff] [blame] | 116 | #define mmc_card_mmc(c)		((c)->type == MMC_TYPE_MMC) | 
 | 117 | #define mmc_card_sd(c)		((c)->type == MMC_TYPE_SD) | 
| Pierre Ossman | 5c4e6f1 | 2007-05-21 20:23:20 +0200 | [diff] [blame] | 118 | #define mmc_card_sdio(c)	((c)->type == MMC_TYPE_SDIO) | 
| Pierre Ossman | 9c2c0af | 2006-12-26 15:25:58 +0100 | [diff] [blame] | 119 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 120 | #define mmc_card_present(c)	((c)->state & MMC_STATE_PRESENT) | 
| Pierre Ossman | a00fc09 | 2005-09-06 15:18:52 -0700 | [diff] [blame] | 121 | #define mmc_card_readonly(c)	((c)->state & MMC_STATE_READONLY) | 
| Philip Langdale | bce40a3 | 2006-10-21 12:35:02 +0200 | [diff] [blame] | 122 | #define mmc_card_highspeed(c)	((c)->state & MMC_STATE_HIGHSPEED) | 
| Philip Langdale | fba68bd | 2007-01-04 06:57:32 -0800 | [diff] [blame] | 123 | #define mmc_card_blockaddr(c)	((c)->state & MMC_STATE_BLOCKADDR) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 124 |  | 
 | 125 | #define mmc_card_set_present(c)	((c)->state |= MMC_STATE_PRESENT) | 
| Pierre Ossman | a00fc09 | 2005-09-06 15:18:52 -0700 | [diff] [blame] | 126 | #define mmc_card_set_readonly(c) ((c)->state |= MMC_STATE_READONLY) | 
| Philip Langdale | bce40a3 | 2006-10-21 12:35:02 +0200 | [diff] [blame] | 127 | #define mmc_card_set_highspeed(c) ((c)->state |= MMC_STATE_HIGHSPEED) | 
| Philip Langdale | fba68bd | 2007-01-04 06:57:32 -0800 | [diff] [blame] | 128 | #define mmc_card_set_blockaddr(c) ((c)->state |= MMC_STATE_BLOCKADDR) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 129 |  | 
 | 130 | #define mmc_card_name(c)	((c)->cid.prod_name) | 
 | 131 | #define mmc_card_id(c)		((c)->dev.bus_id) | 
 | 132 |  | 
 | 133 | #define mmc_list_to_card(l)	container_of(l, struct mmc_card, node) | 
 | 134 | #define mmc_get_drvdata(c)	dev_get_drvdata(&(c)->dev) | 
 | 135 | #define mmc_set_drvdata(c,d)	dev_set_drvdata(&(c)->dev, d) | 
 | 136 |  | 
 | 137 | /* | 
 | 138 |  * MMC device driver (e.g., Flash card, I/O card...) | 
 | 139 |  */ | 
 | 140 | struct mmc_driver { | 
 | 141 | 	struct device_driver drv; | 
 | 142 | 	int (*probe)(struct mmc_card *); | 
 | 143 | 	void (*remove)(struct mmc_card *); | 
 | 144 | 	int (*suspend)(struct mmc_card *, pm_message_t); | 
 | 145 | 	int (*resume)(struct mmc_card *); | 
 | 146 | }; | 
 | 147 |  | 
 | 148 | extern int mmc_register_driver(struct mmc_driver *); | 
 | 149 | extern void mmc_unregister_driver(struct mmc_driver *); | 
 | 150 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 151 | #endif |