1
2
3
4
5
6
7
8#ifndef LINUX_MMC_CORE_H
9#define LINUX_MMC_CORE_H
10
11#include <linux/interrupt.h>
12#include <linux/completion.h>
13
14struct request;
15struct mmc_data;
16struct mmc_request;
17
18struct mmc_command {
19 u32 opcode;
20 u32 arg;
21#define MMC_CMD23_ARG_REL_WR (1 << 31)
22#define MMC_CMD23_ARG_PACKED ((0 << 31) | (1 << 30))
23#define MMC_CMD23_ARG_TAG_REQ (1 << 29)
24 u32 resp[4];
25 unsigned int flags;
26#define MMC_RSP_PRESENT (1 << 0)
27#define MMC_RSP_136 (1 << 1)
28#define MMC_RSP_CRC (1 << 2)
29#define MMC_RSP_BUSY (1 << 3)
30#define MMC_RSP_OPCODE (1 << 4)
31
32#define MMC_CMD_MASK (3 << 5)
33#define MMC_CMD_AC (0 << 5)
34#define MMC_CMD_ADTC (1 << 5)
35#define MMC_CMD_BC (2 << 5)
36#define MMC_CMD_BCR (3 << 5)
37
38#define MMC_RSP_SPI_S1 (1 << 7)
39#define MMC_RSP_SPI_S2 (1 << 8)
40#define MMC_RSP_SPI_B4 (1 << 9)
41#define MMC_RSP_SPI_BUSY (1 << 10)
42
43
44
45
46
47
48#define MMC_RSP_NONE (0)
49#define MMC_RSP_R1 (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE)
50#define MMC_RSP_R1B (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE|MMC_RSP_BUSY)
51#define MMC_RSP_R2 (MMC_RSP_PRESENT|MMC_RSP_136|MMC_RSP_CRC)
52#define MMC_RSP_R3 (MMC_RSP_PRESENT)
53#define MMC_RSP_R4 (MMC_RSP_PRESENT)
54#define MMC_RSP_R5 (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE)
55#define MMC_RSP_R6 (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE)
56#define MMC_RSP_R7 (MMC_RSP_PRESENT|MMC_RSP_CRC|MMC_RSP_OPCODE)
57
58#define mmc_resp_type(cmd) ((cmd)->flags & (MMC_RSP_PRESENT|MMC_RSP_136|MMC_RSP_CRC|MMC_RSP_BUSY|MMC_RSP_OPCODE))
59
60
61
62
63
64
65#define MMC_RSP_SPI_R1 (MMC_RSP_SPI_S1)
66#define MMC_RSP_SPI_R1B (MMC_RSP_SPI_S1|MMC_RSP_SPI_BUSY)
67#define MMC_RSP_SPI_R2 (MMC_RSP_SPI_S1|MMC_RSP_SPI_S2)
68#define MMC_RSP_SPI_R3 (MMC_RSP_SPI_S1|MMC_RSP_SPI_B4)
69#define MMC_RSP_SPI_R4 (MMC_RSP_SPI_S1|MMC_RSP_SPI_B4)
70#define MMC_RSP_SPI_R5 (MMC_RSP_SPI_S1|MMC_RSP_SPI_S2)
71#define MMC_RSP_SPI_R7 (MMC_RSP_SPI_S1|MMC_RSP_SPI_B4)
72
73#define mmc_spi_resp_type(cmd) ((cmd)->flags & \
74 (MMC_RSP_SPI_S1|MMC_RSP_SPI_BUSY|MMC_RSP_SPI_S2|MMC_RSP_SPI_B4))
75
76
77
78
79#define mmc_cmd_type(cmd) ((cmd)->flags & MMC_CMD_MASK)
80
81 unsigned int retries;
82 int error;
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98 unsigned int busy_timeout;
99
100 bool sanitize_busy;
101
102 struct mmc_data *data;
103 struct mmc_request *mrq;
104};
105
106struct mmc_data {
107 unsigned int timeout_ns;
108 unsigned int timeout_clks;
109 unsigned int blksz;
110 unsigned int blocks;
111 int error;
112 unsigned int flags;
113
114#define MMC_DATA_WRITE (1 << 8)
115#define MMC_DATA_READ (1 << 9)
116
117 unsigned int bytes_xfered;
118
119 struct mmc_command *stop;
120 struct mmc_request *mrq;
121
122 unsigned int sg_len;
123 int sg_count;
124 struct scatterlist *sg;
125 s32 host_cookie;
126};
127
128struct mmc_host;
129struct mmc_request {
130 struct mmc_command *sbc;
131 struct mmc_command *cmd;
132 struct mmc_data *data;
133 struct mmc_command *stop;
134
135 struct completion completion;
136 void (*done)(struct mmc_request *);
137 struct mmc_host *host;
138};
139
140struct mmc_card;
141struct mmc_async_req;
142
143extern int mmc_stop_bkops(struct mmc_card *);
144extern int mmc_read_bkops_status(struct mmc_card *);
145extern struct mmc_async_req *mmc_start_req(struct mmc_host *,
146 struct mmc_async_req *, int *);
147extern int mmc_interrupt_hpi(struct mmc_card *);
148extern void mmc_wait_for_req(struct mmc_host *, struct mmc_request *);
149extern int mmc_wait_for_cmd(struct mmc_host *, struct mmc_command *, int);
150extern int mmc_app_cmd(struct mmc_host *, struct mmc_card *);
151extern int mmc_wait_for_app_cmd(struct mmc_host *, struct mmc_card *,
152 struct mmc_command *, int);
153extern void mmc_start_bkops(struct mmc_card *card, bool from_exception);
154extern int mmc_switch(struct mmc_card *, u8, u8, u8, unsigned int);
155extern int mmc_send_tuning(struct mmc_host *host, u32 opcode, int *cmd_error);
156extern int mmc_get_ext_csd(struct mmc_card *card, u8 **new_ext_csd);
157
158#define MMC_ERASE_ARG 0x00000000
159#define MMC_SECURE_ERASE_ARG 0x80000000
160#define MMC_TRIM_ARG 0x00000001
161#define MMC_DISCARD_ARG 0x00000003
162#define MMC_SECURE_TRIM1_ARG 0x80000001
163#define MMC_SECURE_TRIM2_ARG 0x80008000
164
165#define MMC_SECURE_ARGS 0x80000000
166#define MMC_TRIM_ARGS 0x00008001
167
168extern int mmc_erase(struct mmc_card *card, unsigned int from, unsigned int nr,
169 unsigned int arg);
170extern int mmc_can_erase(struct mmc_card *card);
171extern int mmc_can_trim(struct mmc_card *card);
172extern int mmc_can_discard(struct mmc_card *card);
173extern int mmc_can_sanitize(struct mmc_card *card);
174extern int mmc_can_secure_erase_trim(struct mmc_card *card);
175extern int mmc_erase_group_aligned(struct mmc_card *card, unsigned int from,
176 unsigned int nr);
177extern unsigned int mmc_calc_max_discard(struct mmc_card *card);
178
179extern int mmc_set_blocklen(struct mmc_card *card, unsigned int blocklen);
180extern int mmc_set_blockcount(struct mmc_card *card, unsigned int blockcount,
181 bool is_rel_write);
182extern int mmc_hw_reset(struct mmc_host *host);
183extern int mmc_can_reset(struct mmc_card *card);
184
185extern void mmc_set_data_timeout(struct mmc_data *, const struct mmc_card *);
186extern unsigned int mmc_align_data_size(struct mmc_card *, unsigned int);
187
188extern int __mmc_claim_host(struct mmc_host *host, atomic_t *abort);
189extern void mmc_release_host(struct mmc_host *host);
190
191extern void mmc_get_card(struct mmc_card *card);
192extern void mmc_put_card(struct mmc_card *card);
193
194extern int mmc_flush_cache(struct mmc_card *);
195
196extern int mmc_detect_card_removed(struct mmc_host *host);
197
198
199
200
201
202
203
204static inline void mmc_claim_host(struct mmc_host *host)
205{
206 __mmc_claim_host(host, NULL);
207}
208
209struct device_node;
210extern u32 mmc_vddrange_to_ocrmask(int vdd_min, int vdd_max);
211extern int mmc_of_parse_voltage(struct device_node *np, u32 *mask);
212
213#endif
214