| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2007-02-28 15:33:10 +01:00
										 |  |  |  *  linux/include/linux/mmc/core.h | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License version 2 as | 
					
						
							|  |  |  |  * published by the Free Software Foundation. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2007-02-28 15:33:10 +01:00
										 |  |  | #ifndef LINUX_MMC_CORE_H
 | 
					
						
							|  |  |  | #define LINUX_MMC_CORE_H
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <linux/interrupt.h>
 | 
					
						
							| 
									
										
										
										
											2012-01-30 11:46:54 -05:00
										 |  |  | #include <linux/completion.h>
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | struct request; | 
					
						
							|  |  |  | struct mmc_data; | 
					
						
							|  |  |  | struct mmc_request; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct mmc_command { | 
					
						
							|  |  |  | 	u32			opcode; | 
					
						
							|  |  |  | 	u32			arg; | 
					
						
							| 
									
										
										
										
											2013-02-06 17:02:46 +09:00
										 |  |  | #define MMC_CMD23_ARG_REL_WR	(1 << 31)
 | 
					
						
							|  |  |  | #define MMC_CMD23_ARG_PACKED	((0 << 31) | (1 << 30))
 | 
					
						
							|  |  |  | #define MMC_CMD23_ARG_TAG_REQ	(1 << 29)
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	u32			resp[4]; | 
					
						
							|  |  |  | 	unsigned int		flags;		/* expected response type */ | 
					
						
							| 
									
										
										
										
											2006-02-02 12:23:12 +00:00
										 |  |  | #define MMC_RSP_PRESENT	(1 << 0)
 | 
					
						
							|  |  |  | #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 */
 | 
					
						
							| 
									
										
										
										
											2007-08-08 09:09:01 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define MMC_CMD_MASK	(3 << 5)		/* non-SPI command type */
 | 
					
						
							| 
									
										
										
										
											2006-02-02 12:23:12 +00:00
										 |  |  | #define MMC_CMD_AC	(0 << 5)
 | 
					
						
							|  |  |  | #define MMC_CMD_ADTC	(1 << 5)
 | 
					
						
							|  |  |  | #define MMC_CMD_BC	(2 << 5)
 | 
					
						
							|  |  |  | #define MMC_CMD_BCR	(3 << 5)
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-08 09:09:01 -07:00
										 |  |  | #define MMC_RSP_SPI_S1	(1 << 7)		/* one status byte */
 | 
					
						
							|  |  |  | #define MMC_RSP_SPI_S2	(1 << 8)		/* second byte */
 | 
					
						
							|  |  |  | #define MMC_RSP_SPI_B4	(1 << 9)		/* four data bytes */
 | 
					
						
							|  |  |  | #define MMC_RSP_SPI_BUSY (1 << 10)		/* card may send busy */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2007-08-08 09:09:01 -07:00
										 |  |  |  * These are the native response types, and correspond to valid bit | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  * patterns of the above flags.  One additional valid pattern | 
					
						
							|  |  |  |  * is all zeros, which means we don't expect a response. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2006-02-02 12:23:12 +00:00
										 |  |  | #define MMC_RSP_NONE	(0)
 | 
					
						
							|  |  |  | #define MMC_RSP_R1	(MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE)
 | 
					
						
							|  |  |  | #define MMC_RSP_R1B	(MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE|MMC_RSP_BUSY)
 | 
					
						
							|  |  |  | #define MMC_RSP_R2	(MMC_RSP_PRESENT|MMC_RSP_136|MMC_RSP_CRC)
 | 
					
						
							|  |  |  | #define MMC_RSP_R3	(MMC_RSP_PRESENT)
 | 
					
						
							| 
									
										
										
										
											2007-05-21 20:23:20 +02:00
										 |  |  | #define MMC_RSP_R4	(MMC_RSP_PRESENT)
 | 
					
						
							| 
									
										
										
										
											2007-05-22 20:25:21 +02:00
										 |  |  | #define MMC_RSP_R5	(MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE)
 | 
					
						
							| 
									
										
										
										
											2007-01-04 07:04:47 -08:00
										 |  |  | #define MMC_RSP_R6	(MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE)
 | 
					
						
							| 
									
										
										
										
											2007-01-04 06:57:32 -08:00
										 |  |  | #define MMC_RSP_R7	(MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE)
 | 
					
						
							| 
									
										
										
										
											2006-02-02 12:23:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define mmc_resp_type(cmd)	((cmd)->flags & (MMC_RSP_PRESENT|MMC_RSP_136|MMC_RSP_CRC|MMC_RSP_BUSY|MMC_RSP_OPCODE))
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-08 09:09:01 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * These are the SPI response types for MMC, SD, and SDIO cards. | 
					
						
							|  |  |  |  * Commands return R1, with maybe more info.  Zero is an error type; | 
					
						
							|  |  |  |  * callers must always provide the appropriate MMC_RSP_SPI_Rx flags. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define MMC_RSP_SPI_R1	(MMC_RSP_SPI_S1)
 | 
					
						
							|  |  |  | #define MMC_RSP_SPI_R1B	(MMC_RSP_SPI_S1|MMC_RSP_SPI_BUSY)
 | 
					
						
							|  |  |  | #define MMC_RSP_SPI_R2	(MMC_RSP_SPI_S1|MMC_RSP_SPI_S2)
 | 
					
						
							|  |  |  | #define MMC_RSP_SPI_R3	(MMC_RSP_SPI_S1|MMC_RSP_SPI_B4)
 | 
					
						
							|  |  |  | #define MMC_RSP_SPI_R4	(MMC_RSP_SPI_S1|MMC_RSP_SPI_B4)
 | 
					
						
							|  |  |  | #define MMC_RSP_SPI_R5	(MMC_RSP_SPI_S1|MMC_RSP_SPI_S2)
 | 
					
						
							|  |  |  | #define MMC_RSP_SPI_R7	(MMC_RSP_SPI_S1|MMC_RSP_SPI_B4)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define mmc_spi_resp_type(cmd)	((cmd)->flags & \
 | 
					
						
							|  |  |  | 		(MMC_RSP_SPI_S1|MMC_RSP_SPI_BUSY|MMC_RSP_SPI_S2|MMC_RSP_SPI_B4)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-02 12:23:12 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * These are the command types. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2006-02-17 20:23:29 +00:00
										 |  |  | #define mmc_cmd_type(cmd)	((cmd)->flags & MMC_CMD_MASK)
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	unsigned int		retries;	/* max number of retries */ | 
					
						
							|  |  |  | 	unsigned int		error;		/* command error */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-22 22:18:46 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Standard errno values are used for errors, but some have specific | 
					
						
							|  |  |  |  * meaning in the MMC layer: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ETIMEDOUT    Card took too long to respond | 
					
						
							|  |  |  |  * EILSEQ       Basic format problem with the received or sent data | 
					
						
							|  |  |  |  *              (e.g. CRC check failed, incorrect opcode in response | 
					
						
							|  |  |  |  *              or bad end bit) | 
					
						
							|  |  |  |  * EINVAL       Request cannot be performed because of restrictions | 
					
						
							|  |  |  |  *              in hardware and/or the driver | 
					
						
							|  |  |  |  * ENOMEDIUM    Host can determine that the slot is empty and is | 
					
						
							|  |  |  |  *              actively failing requests | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-11 16:13:41 -05:00
										 |  |  | 	unsigned int		cmd_timeout_ms;	/* in milliseconds */ | 
					
						
							| 
									
										
											  
											
												mmc: add erase, secure erase, trim and secure trim operations
SD/MMC cards tend to support an erase operation.  In addition, eMMC v4.4
cards can support secure erase, trim and secure trim operations that are
all variants of the basic erase command.
SD/MMC device attributes "erase_size" and "preferred_erase_size" have been
added.
"erase_size" is the minimum size, in bytes, of an erase operation.  For
MMC, "erase_size" is the erase group size reported by the card.  Note that
"erase_size" does not apply to trim or secure trim operations where the
minimum size is always one 512 byte sector.  For SD, "erase_size" is 512
if the card is block-addressed, 0 otherwise.
SD/MMC cards can erase an arbitrarily large area up to and
including the whole card.  When erasing a large area it may
be desirable to do it in smaller chunks for three reasons:
    1. A single erase command will make all other I/O on the card
       wait.  This is not a problem if the whole card is being erased, but
       erasing one partition will make I/O for another partition on the
       same card wait for the duration of the erase - which could be a
       several minutes.
    2. To be able to inform the user of erase progress.
    3. The erase timeout becomes too large to be very useful.
       Because the erase timeout contains a margin which is multiplied by
       the size of the erase area, the value can end up being several
       minutes for large areas.
"erase_size" is not the most efficient unit to erase (especially for SD
where it is just one sector), hence "preferred_erase_size" provides a good
chunk size for erasing large areas.
For MMC, "preferred_erase_size" is the high-capacity erase size if a card
specifies one, otherwise it is based on the capacity of the card.
For SD, "preferred_erase_size" is the allocation unit size specified by
the card.
"preferred_erase_size" is in bytes.
Signed-off-by: Adrian Hunter <adrian.hunter@nokia.com>
Acked-by: Jens Axboe <axboe@kernel.dk>
Cc: Kyungmin Park <kmpark@infradead.org>
Cc: Madhusudhan Chikkature <madhu.cr@ti.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Ben Gardiner <bengardiner@nanometrics.ca>
Cc: <linux-mmc@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
											
										 
											2010-08-11 14:17:46 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	struct mmc_data		*data;		/* data segment associated with cmd */ | 
					
						
							| 
									
										
										
										
											2005-10-28 16:28:04 +01:00
										 |  |  | 	struct mmc_request	*mrq;		/* associated request */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct mmc_data { | 
					
						
							|  |  |  | 	unsigned int		timeout_ns;	/* data timeout (in ns, max 80ms) */ | 
					
						
							|  |  |  | 	unsigned int		timeout_clks;	/* data timeout (in clocks) */ | 
					
						
							| 
									
										
										
										
											2006-05-19 21:48:03 +01:00
										 |  |  | 	unsigned int		blksz;		/* data block size */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	unsigned int		blocks;		/* number of blocks */ | 
					
						
							|  |  |  | 	unsigned int		error;		/* data error */ | 
					
						
							|  |  |  | 	unsigned int		flags; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MMC_DATA_WRITE	(1 << 8)
 | 
					
						
							|  |  |  | #define MMC_DATA_READ	(1 << 9)
 | 
					
						
							|  |  |  | #define MMC_DATA_STREAM	(1 << 10)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	unsigned int		bytes_xfered; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	struct mmc_command	*stop;		/* stop command */ | 
					
						
							| 
									
										
										
										
											2005-10-28 16:28:04 +01:00
										 |  |  | 	struct mmc_request	*mrq;		/* associated request */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	unsigned int		sg_len;		/* size of scatter list */ | 
					
						
							|  |  |  | 	struct scatterlist	*sg;		/* I/O scatter list */ | 
					
						
							| 
									
										
										
										
											2011-07-01 18:55:22 +02:00
										 |  |  | 	s32			host_cookie;	/* host private data */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-14 14:28:17 -05:00
										 |  |  | struct mmc_host; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | struct mmc_request { | 
					
						
							| 
									
										
										
										
											2011-05-23 15:06:36 -05:00
										 |  |  | 	struct mmc_command	*sbc;		/* SET_BLOCK_COUNT for multiblock */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	struct mmc_command	*cmd; | 
					
						
							|  |  |  | 	struct mmc_data		*data; | 
					
						
							|  |  |  | 	struct mmc_command	*stop; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-01 18:55:22 +02:00
										 |  |  | 	struct completion	completion; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	void			(*done)(struct mmc_request *);/* completion function */ | 
					
						
							| 
									
										
										
										
											2013-01-14 14:28:17 -05:00
										 |  |  | 	struct mmc_host		*host; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct mmc_card; | 
					
						
							| 
									
										
										
										
											2011-07-01 18:55:22 +02:00
										 |  |  | struct mmc_async_req; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-17 08:42:02 +00:00
										 |  |  | extern int mmc_stop_bkops(struct mmc_card *); | 
					
						
							|  |  |  | extern int mmc_read_bkops_status(struct mmc_card *); | 
					
						
							| 
									
										
										
										
											2011-07-01 18:55:22 +02:00
										 |  |  | extern struct mmc_async_req *mmc_start_req(struct mmc_host *, | 
					
						
							|  |  |  | 					   struct mmc_async_req *, int *); | 
					
						
							| 
									
										
										
										
											2011-10-18 01:26:42 -04:00
										 |  |  | extern int mmc_interrupt_hpi(struct mmc_card *); | 
					
						
							| 
									
										
										
										
											2007-07-11 20:22:11 +02:00
										 |  |  | extern void mmc_wait_for_req(struct mmc_host *, struct mmc_request *); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | extern int mmc_wait_for_cmd(struct mmc_host *, struct mmc_command *, int); | 
					
						
							| 
									
										
										
										
											2011-04-26 18:56:29 -04:00
										 |  |  | extern int mmc_app_cmd(struct mmc_host *, struct mmc_card *); | 
					
						
							| 
									
										
										
										
											2006-12-24 22:46:55 +01:00
										 |  |  | extern int mmc_wait_for_app_cmd(struct mmc_host *, struct mmc_card *, | 
					
						
							| 
									
										
										
										
											2005-09-06 15:18:50 -07:00
										 |  |  | 	struct mmc_command *, int); | 
					
						
							| 
									
										
										
										
											2012-09-17 08:42:02 +00:00
										 |  |  | extern void mmc_start_bkops(struct mmc_card *card, bool from_exception); | 
					
						
							|  |  |  | extern int __mmc_switch(struct mmc_card *, u8, u8, u8, unsigned int, bool); | 
					
						
							| 
									
										
										
										
											2011-04-11 16:13:43 -05:00
										 |  |  | extern int mmc_switch(struct mmc_card *, u8, u8, u8, unsigned int); | 
					
						
							| 
									
										
										
										
											2013-02-06 17:02:46 +09:00
										 |  |  | extern int mmc_send_ext_csd(struct mmc_card *card, u8 *ext_csd); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												mmc: add erase, secure erase, trim and secure trim operations
SD/MMC cards tend to support an erase operation.  In addition, eMMC v4.4
cards can support secure erase, trim and secure trim operations that are
all variants of the basic erase command.
SD/MMC device attributes "erase_size" and "preferred_erase_size" have been
added.
"erase_size" is the minimum size, in bytes, of an erase operation.  For
MMC, "erase_size" is the erase group size reported by the card.  Note that
"erase_size" does not apply to trim or secure trim operations where the
minimum size is always one 512 byte sector.  For SD, "erase_size" is 512
if the card is block-addressed, 0 otherwise.
SD/MMC cards can erase an arbitrarily large area up to and
including the whole card.  When erasing a large area it may
be desirable to do it in smaller chunks for three reasons:
    1. A single erase command will make all other I/O on the card
       wait.  This is not a problem if the whole card is being erased, but
       erasing one partition will make I/O for another partition on the
       same card wait for the duration of the erase - which could be a
       several minutes.
    2. To be able to inform the user of erase progress.
    3. The erase timeout becomes too large to be very useful.
       Because the erase timeout contains a margin which is multiplied by
       the size of the erase area, the value can end up being several
       minutes for large areas.
"erase_size" is not the most efficient unit to erase (especially for SD
where it is just one sector), hence "preferred_erase_size" provides a good
chunk size for erasing large areas.
For MMC, "preferred_erase_size" is the high-capacity erase size if a card
specifies one, otherwise it is based on the capacity of the card.
For SD, "preferred_erase_size" is the allocation unit size specified by
the card.
"preferred_erase_size" is in bytes.
Signed-off-by: Adrian Hunter <adrian.hunter@nokia.com>
Acked-by: Jens Axboe <axboe@kernel.dk>
Cc: Kyungmin Park <kmpark@infradead.org>
Cc: Madhusudhan Chikkature <madhu.cr@ti.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Ben Gardiner <bengardiner@nanometrics.ca>
Cc: <linux-mmc@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
											
										 
											2010-08-11 14:17:46 -07:00
										 |  |  | #define MMC_ERASE_ARG		0x00000000
 | 
					
						
							|  |  |  | #define MMC_SECURE_ERASE_ARG	0x80000000
 | 
					
						
							|  |  |  | #define MMC_TRIM_ARG		0x00000001
 | 
					
						
							| 
									
										
										
										
											2011-10-18 09:34:04 +09:00
										 |  |  | #define MMC_DISCARD_ARG		0x00000003
 | 
					
						
							| 
									
										
											  
											
												mmc: add erase, secure erase, trim and secure trim operations
SD/MMC cards tend to support an erase operation.  In addition, eMMC v4.4
cards can support secure erase, trim and secure trim operations that are
all variants of the basic erase command.
SD/MMC device attributes "erase_size" and "preferred_erase_size" have been
added.
"erase_size" is the minimum size, in bytes, of an erase operation.  For
MMC, "erase_size" is the erase group size reported by the card.  Note that
"erase_size" does not apply to trim or secure trim operations where the
minimum size is always one 512 byte sector.  For SD, "erase_size" is 512
if the card is block-addressed, 0 otherwise.
SD/MMC cards can erase an arbitrarily large area up to and
including the whole card.  When erasing a large area it may
be desirable to do it in smaller chunks for three reasons:
    1. A single erase command will make all other I/O on the card
       wait.  This is not a problem if the whole card is being erased, but
       erasing one partition will make I/O for another partition on the
       same card wait for the duration of the erase - which could be a
       several minutes.
    2. To be able to inform the user of erase progress.
    3. The erase timeout becomes too large to be very useful.
       Because the erase timeout contains a margin which is multiplied by
       the size of the erase area, the value can end up being several
       minutes for large areas.
"erase_size" is not the most efficient unit to erase (especially for SD
where it is just one sector), hence "preferred_erase_size" provides a good
chunk size for erasing large areas.
For MMC, "preferred_erase_size" is the high-capacity erase size if a card
specifies one, otherwise it is based on the capacity of the card.
For SD, "preferred_erase_size" is the allocation unit size specified by
the card.
"preferred_erase_size" is in bytes.
Signed-off-by: Adrian Hunter <adrian.hunter@nokia.com>
Acked-by: Jens Axboe <axboe@kernel.dk>
Cc: Kyungmin Park <kmpark@infradead.org>
Cc: Madhusudhan Chikkature <madhu.cr@ti.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Ben Gardiner <bengardiner@nanometrics.ca>
Cc: <linux-mmc@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
											
										 
											2010-08-11 14:17:46 -07:00
										 |  |  | #define MMC_SECURE_TRIM1_ARG	0x80000001
 | 
					
						
							|  |  |  | #define MMC_SECURE_TRIM2_ARG	0x80008000
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MMC_SECURE_ARGS		0x80000000
 | 
					
						
							|  |  |  | #define MMC_TRIM_ARGS		0x00008001
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern int mmc_erase(struct mmc_card *card, unsigned int from, unsigned int nr, | 
					
						
							|  |  |  | 		     unsigned int arg); | 
					
						
							|  |  |  | extern int mmc_can_erase(struct mmc_card *card); | 
					
						
							|  |  |  | extern int mmc_can_trim(struct mmc_card *card); | 
					
						
							| 
									
										
										
										
											2011-10-18 09:34:04 +09:00
										 |  |  | extern int mmc_can_discard(struct mmc_card *card); | 
					
						
							| 
									
										
										
										
											2011-10-14 14:15:48 +09:00
										 |  |  | extern int mmc_can_sanitize(struct mmc_card *card); | 
					
						
							| 
									
										
											  
											
												mmc: add erase, secure erase, trim and secure trim operations
SD/MMC cards tend to support an erase operation.  In addition, eMMC v4.4
cards can support secure erase, trim and secure trim operations that are
all variants of the basic erase command.
SD/MMC device attributes "erase_size" and "preferred_erase_size" have been
added.
"erase_size" is the minimum size, in bytes, of an erase operation.  For
MMC, "erase_size" is the erase group size reported by the card.  Note that
"erase_size" does not apply to trim or secure trim operations where the
minimum size is always one 512 byte sector.  For SD, "erase_size" is 512
if the card is block-addressed, 0 otherwise.
SD/MMC cards can erase an arbitrarily large area up to and
including the whole card.  When erasing a large area it may
be desirable to do it in smaller chunks for three reasons:
    1. A single erase command will make all other I/O on the card
       wait.  This is not a problem if the whole card is being erased, but
       erasing one partition will make I/O for another partition on the
       same card wait for the duration of the erase - which could be a
       several minutes.
    2. To be able to inform the user of erase progress.
    3. The erase timeout becomes too large to be very useful.
       Because the erase timeout contains a margin which is multiplied by
       the size of the erase area, the value can end up being several
       minutes for large areas.
"erase_size" is not the most efficient unit to erase (especially for SD
where it is just one sector), hence "preferred_erase_size" provides a good
chunk size for erasing large areas.
For MMC, "preferred_erase_size" is the high-capacity erase size if a card
specifies one, otherwise it is based on the capacity of the card.
For SD, "preferred_erase_size" is the allocation unit size specified by
the card.
"preferred_erase_size" is in bytes.
Signed-off-by: Adrian Hunter <adrian.hunter@nokia.com>
Acked-by: Jens Axboe <axboe@kernel.dk>
Cc: Kyungmin Park <kmpark@infradead.org>
Cc: Madhusudhan Chikkature <madhu.cr@ti.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Ben Gardiner <bengardiner@nanometrics.ca>
Cc: <linux-mmc@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
											
										 
											2010-08-11 14:17:46 -07:00
										 |  |  | extern int mmc_can_secure_erase_trim(struct mmc_card *card); | 
					
						
							|  |  |  | extern int mmc_erase_group_aligned(struct mmc_card *card, unsigned int from, | 
					
						
							|  |  |  | 				   unsigned int nr); | 
					
						
							| 
									
										
										
										
											2011-06-28 17:16:02 +03:00
										 |  |  | extern unsigned int mmc_calc_max_discard(struct mmc_card *card); | 
					
						
							| 
									
										
											  
											
												mmc: add erase, secure erase, trim and secure trim operations
SD/MMC cards tend to support an erase operation.  In addition, eMMC v4.4
cards can support secure erase, trim and secure trim operations that are
all variants of the basic erase command.
SD/MMC device attributes "erase_size" and "preferred_erase_size" have been
added.
"erase_size" is the minimum size, in bytes, of an erase operation.  For
MMC, "erase_size" is the erase group size reported by the card.  Note that
"erase_size" does not apply to trim or secure trim operations where the
minimum size is always one 512 byte sector.  For SD, "erase_size" is 512
if the card is block-addressed, 0 otherwise.
SD/MMC cards can erase an arbitrarily large area up to and
including the whole card.  When erasing a large area it may
be desirable to do it in smaller chunks for three reasons:
    1. A single erase command will make all other I/O on the card
       wait.  This is not a problem if the whole card is being erased, but
       erasing one partition will make I/O for another partition on the
       same card wait for the duration of the erase - which could be a
       several minutes.
    2. To be able to inform the user of erase progress.
    3. The erase timeout becomes too large to be very useful.
       Because the erase timeout contains a margin which is multiplied by
       the size of the erase area, the value can end up being several
       minutes for large areas.
"erase_size" is not the most efficient unit to erase (especially for SD
where it is just one sector), hence "preferred_erase_size" provides a good
chunk size for erasing large areas.
For MMC, "preferred_erase_size" is the high-capacity erase size if a card
specifies one, otherwise it is based on the capacity of the card.
For SD, "preferred_erase_size" is the allocation unit size specified by
the card.
"preferred_erase_size" is in bytes.
Signed-off-by: Adrian Hunter <adrian.hunter@nokia.com>
Acked-by: Jens Axboe <axboe@kernel.dk>
Cc: Kyungmin Park <kmpark@infradead.org>
Cc: Madhusudhan Chikkature <madhu.cr@ti.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Ben Gardiner <bengardiner@nanometrics.ca>
Cc: <linux-mmc@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
											
										 
											2010-08-11 14:17:46 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-24 13:20:26 +03:00
										 |  |  | extern int mmc_set_blocklen(struct mmc_card *card, unsigned int blocklen); | 
					
						
							| 
									
										
										
										
											2012-08-06 17:12:30 +02:00
										 |  |  | extern int mmc_set_blockcount(struct mmc_card *card, unsigned int blockcount, | 
					
						
							|  |  |  | 			      bool is_rel_write); | 
					
						
							| 
									
										
										
										
											2011-08-29 16:42:11 +03:00
										 |  |  | extern int mmc_hw_reset(struct mmc_host *host); | 
					
						
							|  |  |  | extern int mmc_hw_reset_check(struct mmc_host *host); | 
					
						
							|  |  |  | extern int mmc_can_reset(struct mmc_card *card); | 
					
						
							| 
									
										
										
										
											2010-08-24 13:20:26 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-24 19:16:54 +02:00
										 |  |  | extern void mmc_set_data_timeout(struct mmc_data *, const struct mmc_card *); | 
					
						
							| 
									
										
										
										
											2008-06-28 12:52:45 +02:00
										 |  |  | extern unsigned int mmc_align_data_size(struct mmc_card *, unsigned int); | 
					
						
							| 
									
										
										
										
											2006-09-07 15:57:12 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-30 16:21:52 +02:00
										 |  |  | extern int __mmc_claim_host(struct mmc_host *host, atomic_t *abort); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | extern void mmc_release_host(struct mmc_host *host); | 
					
						
							| 
									
										
										
										
											2009-09-22 16:44:30 -07:00
										 |  |  | extern int mmc_try_claim_host(struct mmc_host *host); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-14 14:03:21 +09:00
										 |  |  | extern int mmc_flush_cache(struct mmc_card *); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-28 16:22:00 +02:00
										 |  |  | extern int mmc_detect_card_removed(struct mmc_host *host); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-30 16:21:52 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  *	mmc_claim_host - exclusively claim a host | 
					
						
							|  |  |  |  *	@host: mmc host to claim | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *	Claim a host for a set of operations. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static inline void mmc_claim_host(struct mmc_host *host) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	__mmc_claim_host(host, NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-26 22:54:17 +03:00
										 |  |  | extern u32 mmc_vddrange_to_ocrmask(int vdd_min, int vdd_max); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-27 16:04:03 -04:00
										 |  |  | #endif /* LINUX_MMC_CORE_H */
 |