blob: 660db667eab8295840ceaf51988aa2ea1e5dbc5a [file] [log] [blame]
Shashank Mittal52525ff2010-04-13 11:11:10 -07001/* Copyright (c) 2010, Code Aurora Forum. All rights reserved.
2
3 * Redistribution and use in source and binary forms, with or without
4 * modification, are permitted provided that the following conditions are
5 * met:
6 * * Redistributions of source code must retain the above copyright
7 * notice, this list of conditions and the following disclaimer.
8 * * Redistributions in binary form must reproduce the above
9 * copyright notice, this list of conditions and the following
10 * disclaimer in the documentation and/or other materials provided
11 * with the distribution.
12 * * Neither the name of Code Aurora Forum, Inc. nor the names of its
13 * contributors may be used to endorse or promote products derived
14 * from this software without specific prior written permission.
15 *
16 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
20 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
23 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
24 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
25 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
26 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29#ifndef __MMC_H__
30#define __MMC_H__
31
Shashank Mittal52525ff2010-04-13 11:11:10 -070032#ifndef MMC_SLOT
33#define MMC_SLOT 0
34#endif
35
Subbaraman Narayanamurthy4b43c352010-09-24 13:20:52 -070036#define MMC_BOOT_MCI_REG(offset) ((mmc_boot_mci_base) + offset)
Shashank Mittal52525ff2010-04-13 11:11:10 -070037
38/*
39 * Define Macros for SDCC Registers
40 */
41#define MMC_BOOT_MCI_POWER MMC_BOOT_MCI_REG(0x000) /* 8 bit */
42
43/* MCICMD output control - 6th bit */
44#ifdef PLATFORM_MSM7X30
45#define MMC_BOOT_MCI_OPEN_DRAIN (1 << 6)
46#define MMC_BOOT_MCI_PWR_OFF 0x00
47#define MMC_BOOT_MCI_PWR_UP 0x01
48#define MMC_BOOT_MCI_PWR_ON 0x01
49#else
50#define MMC_BOOT_MCI_OPEN_DRAIN (1 << 6)
51#define MMC_BOOT_MCI_PWR_OFF 0x00
52#define MMC_BOOT_MCI_PWR_UP 0x02
53#define MMC_BOOT_MCI_PWR_ON 0x03
54#endif
55
56#define MMC_BOOT_MCI_CLK MMC_BOOT_MCI_REG(0x004) /* 16 bits */
57/* Enable MCI bus clock - 0: clock disabled 1: enabled */
58#define MMC_BOOT_MCI_CLK_ENABLE (1 << 8)
59/* Disable clk o/p when bus idle- 0:always enabled 1:enabled when bus active */
60#define MMC_BOOT_MCI_CLK_PWRSAVE (1 << 9)
61/* Enable Widebus mode - 00: 1 bit mode 10:4 bit mode 01/11: 8 bit mode */
62#define MMC_BOOT_MCI_CLK_WIDEBUS_MODE (3 << 10)
63#define MMC_BOOT_MCI_CLK_WIDEBUS_1_BIT 0
64#define MMC_BOOT_MCI_CLK_WIDEBUS_4_BIT (2 << 10)
65#define MMC_BOOT_MCI_CLK_WIDEBUS_8_BIT (1 << 10)
66/* Enable flow control- 0: disable 1: enable */
67#define MMC_BOOT_MCI_CLK_ENA_FLOW (1 << 12)
68/* Set/clear to select rising/falling edge for data/cmd output */
69#define MMC_BOOT_MCI_CLK_INVERT_OUT (1 << 13)
70/* Select to lach data/cmd coming in falling/rising/feedbk/loopbk of MCIclk */
71#define MMC_BOOT_MCI_CLK_IN_FALLING 0x0
72#define MMC_BOOT_MCI_CLK_IN_RISING (1 << 14)
73#define MMC_BOOT_MCI_CLK_IN_FEEDBACK (2 << 14)
74#define MMC_BOOT_MCI_CLK_IN_LOOPBACK (3 << 14)
75
76/* Bus Width */
77#define MMC_BOOT_BUS_WIDTH_1_BIT 0
78#define MMC_BOOT_BUS_WIDTH_4_BIT 2
79#define MMC_BOOT_BUS_WIDTH_8_BIT 3
80
81#define MMC_BOOT_MCI_ARGUMENT MMC_BOOT_MCI_REG(0x008) /* 32 bits */
82
83#define MMC_BOOT_MCI_CMD MMC_BOOT_MCI_REG(0x00C) /* 16 bits */
84/* Command Index: 0 -5 */
85/* Waits for response if set */
86#define MMC_BOOT_MCI_CMD_RESPONSE (1 << 6)
87/* Receives a 136-bit long response if set */
88#define MMC_BOOT_MCI_CMD_LONGRSP (1 << 7)
89/* If set, CPSM disables command timer and waits for interrupt */
90#define MMC_BOOT_MCI_CMD_INTERRUPT (1 << 8)
91/* If set waits for CmdPend before starting to send a command */
92#define MMC_BOOT_MCI_CMD_PENDING (1 << 9)
93/* CPSM is enabled if set */
94#define MMC_BOT_MCI_CMD_ENABLE (1 << 10)
95/* If set PROG_DONE status bit asserted when busy is de-asserted */
96#define MMC_BOOT_MCI_CMD_PROG_ENA (1 << 11)
97/* To indicate that this is a Command with Data (for SDIO interrupts) */
98#define MMC_BOOT_MCI_CMD_DAT_CMD (1 << 12)
99/* Signals the next command to be an abort (stop) command. Always read 0 */
100#define MMC_BOOT_MCI_CMD_MCIABORT (1 << 13)
101/* Waits for Command Completion Signal if set */
102#define MMC_BOOT_MCI_CMD_CCS_ENABLE (1 << 14)
103/* If set sends CCS disable sequence */
104#define MMC_BOOT_MCI_CMD_CCS_DISABLE (1 << 15)
105
106#define MMC_BOOT_MCI_RESP_CMD MMC_BOOT_MCI_REG(0x010)
107
108#define MMC_BOOT_MCI_RESP_0 MMC_BOOT_MCI_REG(0x014)
109#define MMC_BOOT_MCI_RESP_1 MMC_BOOT_MCI_REG(0x018)
110#define MMC_BOOT_MCI_RESP_2 MMC_BOOT_MCI_REG(0x01C)
111#define MMC_BOOT_MCI_RESP_3 MMC_BOOT_MCI_REG(0x020)
112
113#define MMC_BOOT_MCI_DATA_TIMER MMC_BOOT_MCI_REG(0x024)
114#define MMC_BOOT_MCI_DATA_LENGTH MMC_BOOT_MCI_REG(0x028)
115#define MMC_BOOT_MCI_DATA_CTL MMC_BOOT_MCI_REG(0x02C) /* 16 bits */
116/* Data transfer enabled */
117#define MMC_BOOT_MCI_DATA_ENABLE (1 << 0)
118/* Data transfer direction - 0: controller to card 1:card to controller */
119#define MMC_BOOT_MCI_DATA_DIR (1 << 1)
120/* Data transfer mode - 0: block data transfer 1: stream data transfer */
121#define MMC_BOOT_MCI_DATA_MODE (1 << 2)
122/* Enable DM interface - 0: DM disabled 1: DM enabled */
123#define MMC_BOOT_MCI_DATA_DM_ENABLE (1 << 3)
124/* Data block length in bytes (1-4096) */
125#define MMC_BOOT_MCI_BLKSIZE_POS 4
126#define MMC_BOOT_MCI_DATA_COUNT MMC_BOOT_MCI_REG(0x030)
127#define MMC_BOOT_MCI_STATUS MMC_BOOT_MCI_REG(0x034)
128/* Command response received - CRC check failed */
129#define MMC_BOOT_MCI_STAT_CMD_CRC_FAIL (1 << 0)
130/* Data block sent/received - CRC check failed */
131#define MMC_BOOT_MCI_STAT_DATA_CRC_FAIL (1 << 1)
132/* Command resonse timeout */
133#define MMC_BOOT_MCI_STAT_CMD_TIMEOUT (1 << 2)
134/* Data timeout */
135#define MMC_BOOT_MCI_STAT_DATA_TIMEOUT (1 << 3)
136/* Transmit FIFO underrun error */
137#define MMC_BOOT_MCI_STAT_TX_UNDRUN (1 << 4)
138/* Receive FIFO overrun error */
139#define MMC_BOOT_MCI_STAT_RX_OVRRUN (1 << 5)
140/* Command response received - CRC check passed */
141#define MMC_BOOT_MCI_STAT_CMD_RESP_END (1 << 6)
142/* Command sent - no response required */
143#define MMC_BOOT_MCI_STAT_CMD_SENT (1 << 7)
144/* Data end - data counter zero */
145#define MMC_BOOT_MCI_STAT_DATA_END (1 << 8)
146/* Start bit not detected on all data signals in wide bus mode */
147#define MMC_BOOT_MCI_STAT_START_BIT_ERR (1 << 9)
148/* Data block sent/received - CRC check passed */
149#define MMC_BOOT_MCI_STAT_DATA_BLK_END (1 << 10)
150/* Command transfer in progress */
151#define MMC_BOOT_MCI_STAT_CMD_ACTIVE (1 << 11)
152/* Data transmit in progress */
153#define MMC_BOOT_MCI_STAT_TX_ACTIVE (1 << 12)
154/* Data receive in progress */
155#define MMC_BOOT_MCI_STAT_RX_ACTIVE (1 << 13)
156/* Transmit FIFO half full */
157#define MMC_BOOT_MCI_STAT_TX_FIFO_HFULL (1 << 14)
158/* Receive FIFO half full */
159#define MMC_BOOT_MCI_STAT_RX_FIFO_HFULL (1 << 15)
160/* Transmit FIFO full */
161#define MMC_BOOT_MCI_STAT_TX_FIFO_FULL (1 << 16)
162/* Receive FIFO full */
163#define MMC_BOOT_MCI_STAT_RX_FIFO_FULL (1 << 17)
164/* Transmit FIFO empty */
165#define MMC_BOOT_MCI_STAT_TX_FIFO_EMPTY (1 << 18)
166/* Receive FIFO empty */
167#define MMC_BOOT_MCI_STAT_RX_FIFO_EMPTY (1 << 19)
168/* Data available in transmit FIFO */
169#define MMC_BOOT_MCI_STAT_TX_DATA_AVLBL (1 << 20)
170/* Data available in receive FIFO */
171#define MMC_BOOT_MCI_STAT_RX_DATA_AVLBL (1 << 21)
172/* SDIO interrupt indicator for wake-up */
173#define MMC_BOOT_MCI_STAT_SDIO_INTR (1 << 22)
174/* Programming done */
175#define MMC_BOOT_MCI_STAT_PROG_DONE (1 << 23)
176/* CE-ATA command completion signal detected */
177#define MMC_BOOT_MCI_STAT_ATA_CMD_CMPL (1 << 24)
178/* SDIO interrupt indicator for normal operation */
179#define MMC_BOOT_MCI_STAT_SDIO_INTR_OP (1 << 25)
180/* Commpand completion signal timeout */
181#define MMC_BOOT_MCI_STAT_CCS_TIMEOUT (1 << 26)
182
183#define MMC_BOOT_MCI_STATIC_STATUS (MMC_BOOT_MCI_STAT_CMD_CRC_FAIL| \
184 MMC_BOOT_MCI_STAT_DATA_CRC_FAIL| \
185 MMC_BOOT_MCI_STAT_CMD_TIMEOUT| \
186 MMC_BOOT_MCI_STAT_DATA_TIMEOUT| \
187 MMC_BOOT_MCI_STAT_TX_UNDRUN| \
188 MMC_BOOT_MCI_STAT_RX_OVRRUN| \
189 MMC_BOOT_MCI_STAT_CMD_RESP_END| \
190 MMC_BOOT_MCI_STAT_CMD_SENT| \
191 MMC_BOOT_MCI_STAT_DATA_END| \
192 MMC_BOOT_MCI_STAT_START_BIT_ERR| \
193 MMC_BOOT_MCI_STAT_DATA_BLK_END| \
194 MMC_BOOT_MCI_SDIO_INTR_CLR| \
195 MMC_BOOT_MCI_STAT_PROG_DONE| \
196 MMC_BOOT_MCI_STAT_ATA_CMD_CMPL |\
197 MMC_BOOT_MCI_STAT_CCS_TIMEOUT)
198
199#define MMC_BOOT_MCI_CLEAR MMC_BOOT_MCI_REG(0x038)
200#define MMC_BOOT_MCI_CMD_CRC_FAIL_CLR (1 << 0)
201#define MMC_BOOT_MCI_DATA_CRC_FAIL_CLR (1 << 1)
202#define MMC_BOOT_MCI_CMD_TIMEOUT_CLR (1 << 2)
203#define MMC_BOOT_MCI_DATA_TIMEOUT_CLR (1 << 3)
204#define MMC_BOOT_MCI_TX_UNDERRUN_CLR (1 << 4)
205#define MMC_BOOT_MCI_RX_OVERRUN_CLR (1 << 5)
206#define MMC_BOOT_MCI_CMD_RESP_END_CLR (1 << 6)
207#define MMC_BOOT_MCI_CMD_SENT_CLR (1 << 7)
208#define MMC_BOOT_MCI_DATA_END_CLR (1 << 8)
209#define MMC_BOOT_MCI_START_BIT_ERR_CLR (1 << 9)
210#define MMC_BOOT_MCI_DATA_BLK_END_CLR (1 << 10)
211#define MMC_BOOT_MCI_SDIO_INTR_CLR (1 << 22)
212#define MMC_BOOT_MCI_PROG_DONE_CLR (1 << 23)
213#define MMC_BOOT_MCI_ATA_CMD_COMPLR_CLR (1 << 24)
214#define MMC_BOOT_MCI_CCS_TIMEOUT_CLR (1 << 25)
215
216#define MMC_BOOT_MCI_INT_MASK0 MMC_BOOT_MCI_REG(0x03C)
217#define MMC_BOOT_MCI_CMD_CRC_FAIL_MASK (1 << 0)
218#define MMC_BOOT_MCI_DATA_CRC_FAIL_MASK (1 << 1)
219#define MMC_BOOT_MCI_CMD_TIMEOUT_MASK (1 << 2)
220#define MMC_BOOT_MCI_DATA_TIMEOUT_MASK (1 << 3)
221#define MMC_BOOT_MCI_TX_OVERRUN_MASK (1 << 4)
222#define MMC_BOOT_MCI_RX_OVERRUN_MASK (1 << 5)
223#define MMC_BOOT_MCI_CMD_RESP_END_MASK (1 << 6)
224#define MMC_BOOT_MCI_CMD_SENT_MASK (1 << 7)
225#define MMC_BOOT_MCI_DATA_END_MASK (1 << 8)
226#define MMC_BOOT_MCI_START_BIT_ERR_MASK (1 << 9)
227#define MMC_BOOT_MCI_DATA_BLK_END_MASK (1 << 10)
228#define MMC_BOOT_MCI_CMD_ACTIVE_MASK (1 << 11)
229#define MMC_BOOT_MCI_TX_ACTIVE_MASK (1 << 12)
230#define MMC_BOOT_MCI_RX_ACTIVE_MASK (1 << 13)
231#define MMC_BOOT_MCI_TX_FIFO_HFULL_MASK (1 << 14)
232#define MMC_BOOT_MCI_RX_FIFO_HFULL_MASK (1 << 15)
233#define MMC_BOOT_MCI_TX_FIFO_FULL_MASK (1 << 16)
234#define MMC_BOOT_MCI_RX_FIFO_FULL_MASK (1 << 17)
235#define MMC_BOOT_MCI_TX_FIFO_EMPTY_MASK (1 << 18)
236#define MMC_BOOT_MCI_RX_FIFO_EMPTY_MASK (1 << 19)
237#define MMC_BOOT_MCI_TX_DATA_AVLBL_MASK (1 << 20)
238#define MMC_BOOT_MCI_RX_DATA_AVLBL_MASK (1 << 21)
239#define MMC_BOOT_MCI_SDIO_INT_MASK (1 << 22)
240#define MMC_BOOT_MCI_PROG_DONE_MASK (1 << 23)
241#define MMC_BOOT_MCI_ATA_CMD_COMPL_MASK (1 << 24)
242#define MMC_BOOT_MCI_SDIO_INT_OPER_MASK (1 << 25)
243#define MMC_BOOT_MCI_CCS_TIME_OUT_MASK (1 << 26)
244
245#define MMC_BOOT_MCI_INT_MASK1 MMC_BOOT_MCI_REG(0x040)
246
247#define MMC_BOOT_MCI_FIFO_COUNT MMC_BOOT_MCI_REG(0x044)
248
249#define MMC_BOOT_MCI_CCS_TIMER MMC_BOOT_MCI_REG(0x0058)
250
251#define MMC_BOOT_MCI_FIFO MMC_BOOT_MCI_REG(0x080)
252
Subbaraman Narayanamurthy1ea479e2010-10-08 14:54:16 -0700253/* Card status */
254#define MMC_BOOT_CARD_STATUS(x) ((x>>9) & 0x0F)
255#define MMC_BOOT_TRAN_STATE 4
Subbaraman Narayanamurthy7d347742010-10-29 21:24:08 -0700256#define MMC_BOOT_PROG_STATE 7
Subbaraman Narayanamurthy1ea479e2010-10-08 14:54:16 -0700257
Shashank Mittal52525ff2010-04-13 11:11:10 -0700258/* SD Memory Card bus commands */
259#define CMD0_GO_IDLE_STATE 0
260#define CMD1_SEND_OP_COND 1
261#define CMD2_ALL_SEND_CID 2
262#define CMD3_SEND_RELATIVE_ADDR 3
263#define CMD4_SET_DSR 4
264#define CMD6_SWITCH_FUNC 6
Subbaraman Narayanamurthy1ea479e2010-10-08 14:54:16 -0700265#define ACMD6_SET_BUS_WIDTH 6 /* SD card */
Shashank Mittal52525ff2010-04-13 11:11:10 -0700266#define CMD7_SELECT_DESELECT_CARD 7
267#define CMD8_SEND_EXT_CSD 8
Subbaraman Narayanamurthy1ea479e2010-10-08 14:54:16 -0700268#define CMD8_SEND_IF_COND 8 /* SD card */
Shashank Mittal52525ff2010-04-13 11:11:10 -0700269#define CMD9_SEND_CSD 9
270#define CMD10_SEND_CID 10
271#define CMD12_STOP_TRANSMISSION 12
272#define CMD13_SEND_STATUS 13
273#define CMD15_GO_INACTIVE_STATUS 15
274#define CMD16_SET_BLOCKLEN 16
275#define CMD17_READ_SINGLE_BLOCK 17
276#define CMD18_READ_MULTIPLE_BLOCK 18
277#define CMD24_WRITE_SINGLE_BLOCK 24
278#define CMD25_WRITE_MULTIPLE_BLOCK 25
279#define CMD32_ERASE_WR_BLK_START 32
280#define CMD33_ERASE_WR_BLK_END 33
281#define CMD38_ERASE 38
Subbaraman Narayanamurthy1ea479e2010-10-08 14:54:16 -0700282#define ACMD41_SEND_OP_COND 41 /* SD card */
283#define ACMD51_SEND_SCR 51 /* SD card */
284#define CMD55_APP_CMD 55 /* SD card */
Shashank Mittal52525ff2010-04-13 11:11:10 -0700285
286/* Switch Function Modes */
287#define MMC_BOOT_SWITCH_FUNC_CHECK 0
288#define MMC_BOOT_SWITCH_FUNC_SET 1
289
290/* OCR Register */
291#define MMC_BOOT_OCR_17_19 (1 << 7)
292#define MMC_BOOT_OCR_27_36 (0x1FF << 15)
293#define MMC_BOOT_OCR_SEC_MODE (2 << 29)
294#define MMC_BOOT_OCR_BUSY (1 << 31)
295
296/* Commands type */
297#define MMC_BOOT_CMD_BCAST (1 << 0)
298#define MMC_BOOT_CMD_BCAST_W_RESP (1 << 1)
299#define MMC_BOOT_CMD_ADDRESS (1 << 2)
300#define MMC_BOOT_CMD_ADDR_DATA_XFER (1 << 3)
301
302/* Response types */
303#define MMC_BOOT_RESP_NONE 0
304#define MMC_BOOT_RESP_R1 (1 << 0)
305#define MMC_BOOT_RESP_R1B (1 << 1)
306#define MMC_BOOT_RESP_R2 (1 << 2)
307#define MMC_BOOT_RESP_R3 (1 << 3)
308#define MMC_BOOT_RESP_R6 (1 << 6)
309#define MMC_BOOT_RESP_R7 (1 << 7)
310
311#define IS_RESP_136_BITS(x) (x & MMC_BOOT_RESP_R2)
312#define CHECK_FOR_BUSY_AT_RESP(x)
313
314/* Card Status bits (R1 register) */
315#define MMC_BOOT_R1_AKE_SEQ_ERROR (1 << 3)
316#define MMC_BOOT_R1_APP_CMD (1 << 5)
317#define MMC_BOOT_R1_RDY_FOR_DATA (1 << 6)
318#define MMC_BOOT_R1_CURR_STATE_IDLE (0 << 9)
319#define MMC_BOOT_R1_CURR_STATE_RDY (1 << 9)
320#define MMC_BOOT_R1_CURR_STATE_IDENT (2 << 9)
321#define MMC_BOOT_R1_CURR_STATE_STBY (3 << 9)
322#define MMC_BOOT_R1_CURR_STATE_TRAN (4 << 9)
323#define MMC_BOOT_R1_CURR_STATE_DATA (5 << 9)
324#define MMC_BOOT_R1_CURR_STATE_RCV (6 << 9)
325#define MMC_BOOT_R1_CURR_STATE_PRG (7 << 9)
326#define MMC_BOOT_R1_CURR_STATE_DIS (8 << 9)
327#define MMC_BOOT_R1_ERASE_RESET (1 << 13)
328#define MMC_BOOT_R1_CARD_ECC_DISABLED (1 << 14)
329#define MMC_BOOT_R1_WP_ERASE_SKIP (1 << 15)
330#define MMC_BOOT_R1_ERROR (1 << 19)
331#define MMC_BOOT_R1_CC_ERROR (1 << 20)
332#define MMC_BOOT_R1_CARD_ECC_FAILED (1 << 21)
333#define MMC_BOOT_R1_ILLEGAL_CMD (1 << 22)
334#define MMC_BOOT_R1_COM_CRC_ERR (1 << 23)
335#define MMC_BOOT_R1_LOCK_UNLOCK_FAIL (1 << 24)
336#define MMC_BOOT_R1_CARD_IS_LOCKED (1 << 25)
337#define MMC_BOOT_R1_WP_VIOLATION (1 << 26)
338#define MMC_BOOT_R1_ERASE_PARAM (1 << 27)
339#define MMC_BOOT_R1_ERASE_SEQ_ERR (1 << 28)
340#define MMC_BOOT_R1_BLOCK_LEN_ERR (1 << 29)
341#define MMC_BOOT_R1_ADDR_ERR (1 << 30)
342#define MMC_BOOT_R1_OUT_OF_RANGE (1 << 31)
343
344/* Macros for Common Errors */
345#define MMC_BOOT_E_SUCCESS 0
346#define MMC_BOOT_E_FAILURE 1
347#define MMC_BOOT_E_TIMEOUT 2
348#define MMC_BOOT_E_INVAL 3
349#define MMC_BOOT_E_CRC_FAIL 4
350#define MMC_BOOT_E_INIT_FAIL 5
351#define MMC_BOOT_E_CMD_INDX_MISMATCH 6
352#define MMC_BOOT_E_RESP_VERIFY_FAIL 7
353#define MMC_BOOT_E_NOT_SUPPORTED 8
354#define MMC_BOOT_E_CARD_BUSY 9
355#define MMC_BOOT_E_MEM_ALLOC_FAIL 10
356#define MMC_BOOT_E_CLK_ENABLE_FAIL 11
357#define MMC_BOOT_E_CMMC_DECODE_FAIL 12
358#define MMC_BOOT_E_CID_DECODE_FAIL 13
359#define MMC_BOOT_E_BLOCKLEN_ERR 14
360#define MMC_BOOT_E_ADDRESS_ERR 15
361#define MMC_BOOT_E_DATA_CRC_FAIL 16
362#define MMC_BOOT_E_DATA_TIMEOUT 17
363#define MMC_BOOT_E_RX_OVRRUN 18
364#define MMC_BOOT_E_VREG_SET_FAILED 19
365#define MMC_BOOT_E_GPIO_CFG_FAIL 20
366
367/* EXT_CSD */
368#define MMC_BOOT_ACCESS_WRITE 0x3
369#define MMC_BOOT_EXT_CMMC_HS_TIMING 185
370#define MMC_BOOT_EXT_CMMC_BUS_WIDTH 183
371
Subbaraman Narayanamurthy1ea479e2010-10-08 14:54:16 -0700372/* For SD */
373#define MMC_BOOT_SD_HC_VOLT_SUPPLIED 0x000001AA
374#define MMC_BOOT_SD_NEG_OCR 0x00FF8000
375#define MMC_BOOT_SD_HC_HCS 0x40000000
376#define MMC_BOOT_SD_DEV_READY 0x80000000
377#define MMC_BOOT_SD_SWITCH_HS 0x80FFFF01
378
Shashank Mittal52525ff2010-04-13 11:11:10 -0700379/* Data structure definitions */
380struct mmc_boot_command
381{
382 unsigned int cmd_index;
383 unsigned int argument;
384 unsigned int cmd_type;
385
386 unsigned int resp[4];
387 unsigned int resp_type;
388 unsigned int prg_enabled;
389 unsigned int xfer_mode;
390};
391
392#define MMC_BOOT_XFER_MODE_BLOCK 0
393#define MMC_BOOT_XFER_MODE_STREAM 1
394
395/* CSD Register.
396 * Note: not all the fields have been defined here
397 */
398struct mmc_boot_csd
399{
400 unsigned int cmmc_structure;
401 unsigned int card_cmd_class;
402 unsigned int write_blk_len;
403 unsigned int read_blk_len;
404 unsigned int r2w_factor;
405 unsigned int sector_size;
406 unsigned int c_size_mult;
407 unsigned int c_size;
408 unsigned int nsac_clk_cycle;
409 unsigned int taac_ns;
410 unsigned int tran_speed;
411 unsigned int erase_blk_len:1;
412 unsigned int read_blk_misalign:1;
413 unsigned int write_blk_misalign:1;
414 unsigned int read_blk_partial:1;
415 unsigned int write_blk_partial:1;
416};
417
418/* CID Register */
419struct mmc_boot_cid
420{
421 unsigned int mid; /* 8 bit manufacturer id*/
422 unsigned int oid; /* 16 bits 2 character ASCII - OEM ID*/
423 unsigned char pnm[7];/* 6 character ASCII - product name*/
424 unsigned int prv; /* 8 bits - product revision */
425 unsigned int psn; /* 32 bits - product serial number */
426 unsigned int month; /* 4 bits manufacturing month */
427 unsigned int year; /* 4 bits manufacturing year */
428};
429
430/* SCR Register */
431struct mmc_boot_scr
432{
433 unsigned int scr_structure;
434 unsigned int mmc_spec;
435#define MMC_BOOT_SCR_MMC_SPEC_V1_01 0
436#define MMC_BOOT_SCR_MMC_SPEC_V1_10 1
437#define MMC_BOOT_SCR_MMC_SPEC_V2_00 2
438 unsigned int data_stat_after_erase;
439 unsigned int mmc_security;
440#define MMC_BOOT_SCR_NO_SECURITY 0
441#define MMC_BOOT_SCR_SECURITY_UNUSED 1
442#define MMC_BOOT_SCR_SECURITY_V1_01 2
443#define MMC_BOOT_SCR_SECURITY_V2_00 3
444 unsigned int mmc_bus_width;
445#define MMC_BOOT_SCR_BUS_WIDTH_1_BIT (1<<0)
446#define MMC_BOOT_SCR_BUS_WIDTH_4_BIT (1<<2)
447};
448
449struct mmc_boot_card
450{
451 unsigned int rca;
452 unsigned int ocr;
453 unsigned int capacity;
454 unsigned int type;
455#define MMC_BOOT_TYPE_STD_SD 0
456#define MMC_BOOT_TYPE_SDHC 1
457#define MMC_BOOT_TYPE_SDIO 2
Subbaraman Narayanamurthy1ea479e2010-10-08 14:54:16 -0700458#define MMC_BOOT_TYPE_MMCHC 3
Shashank Mittal52525ff2010-04-13 11:11:10 -0700459 unsigned int status;
460#define MMC_BOOT_STATUS_INACTIVE 0
461#define MMC_BOOT_STATUS_ACTIVE 1
462 unsigned int rd_timeout_ns;
463 unsigned int wr_timeout_ns;
464 unsigned int rd_block_len;
465 unsigned int wr_block_len;
466 //unsigned int data_xfer_len;
467 struct mmc_boot_cid cid;
468 struct mmc_boot_csd csd;
469 struct mmc_boot_scr scr;
470};
471
472#define MMC_BOOT_XFER_MULTI_BLOCK 0
473#define MMC_BOOT_XFER_SINGLE_BLOCK 1
474
475struct mmc_boot_host
476{
477 unsigned int mclk_rate;
478 unsigned int pclk_rate;
479 unsigned int ocr;
480 unsigned int cmd_retry;
481 unsigned int clk_enabled;
482};
483
484
485/* MACRO used to evoke regcomp */
486#define REGCOMP_CKRTN(regx, str, errhandle) \
487 do { \
488 if(regcomp(regx, str, REG_EXTENDED) != 0) { \
489 printf("Error building regex: %s\n", str); \
490 goto errhandle; \
491 } \
492 } while(0);
493
494
495#define GET_LWORD_FROM_BYTE(x) ((unsigned)*(x) | \
496 ((unsigned)*(x+1) << 8) | \
497 ((unsigned)*(x+2) << 16) | \
498 ((unsigned)*(x+3) << 24))
499
500#define PUT_LWORD_TO_BYTE(x, y) do{*(x) = y & 0xff; \
501 *(x+1) = (y >> 8) & 0xff; \
502 *(x+2) = (y >> 16) & 0xff; \
503 *(x+3) = (y >> 24) & 0xff; }while(0)
504
505#define GET_PAR_NUM_FROM_POS(x) (((x & 0x0000FF00) >> 8) + (x & 0x000000FF))
506
507/* Some useful define used to access the MBR/EBR table */
508#define BLOCK_SIZE 0x200
509#define TABLE_ENTRY_0 0x1BE
510#define TABLE_ENTRY_1 0x1CE
511#define TABLE_ENTRY_2 0x1DE
512#define TABLE_ENTRY_3 0x1EE
513#define TABLE_SIGNATURE 0x1FE
514#define TABLE_ENTRY_SIZE 0x010
515
516#define OFFSET_STATUS 0x00
517#define OFFSET_TYPE 0x04
518#define OFFSET_FIRST_SEC 0x08
519#define OFFSET_SIZE 0x0C
520#define COPYBUFF_SIZE (1024 * 16)
521#define BINARY_IN_TABLE_SIZE (16 * 512)
522#define MAX_FILE_ENTRIES 20
523
Ajay Dudani02704632010-08-30 14:40:07 -0700524#define MMC_MODEM_TYPE 0x06
525#define MMC_MODEM_TYPE2 0x0C
526#define MMC_SBL1_TYPE 0x4D
527#define MMC_SBL2_TYPE 0x51
528#define MMC_SBL3_TYPE 0x45
529#define MMC_RPM_TYPE 0x47
530#define MMC_TZ_TYPE 0x46
Subbaraman Narayanamurthy4dfe44a2010-10-19 15:34:41 -0700531#define MMC_MODEM_ST1_TYPE 0x4A
532#define MMC_MODEM_ST2_TYPE 0x4B
533#define MMC_EFS2_TYPE 0x4E
Ajay Dudani02704632010-08-30 14:40:07 -0700534
535#define MMC_ABOOT_TYPE 0x4C
536#define MMC_BOOT_TYPE 0x48
537#define MMC_SYSTEM_TYPE 0x82
538#define MMC_USERDATA_TYPE 0x83
Shashank Mittal85b91f62010-10-30 10:12:38 -0700539#define MMC_RECOVERY_TYPE 0x60
Shashank Mittal52525ff2010-04-13 11:11:10 -0700540
541#define MMC_RCA 2
542
543struct mbr_entry
544{
545 unsigned dstatus;
546 unsigned dtype ;
547 unsigned dfirstsec;
548 unsigned dsize;
549 unsigned char name[64];
550};
551
552/* Can be used to unpack array of upto 32 bits data */
553#define UNPACK_BITS(array, start, len, size_of) \
554 ({ \
555 unsigned int indx = (start) / (size_of); \
556 unsigned int offset = (start) % (size_of); \
557 unsigned int mask = (((len)<(size_of))? 1<<(len):0) - 1; \
558 unsigned int unpck = array[indx] >> offset; \
559 unsigned int indx2 = ((start) + (len) - 1) / (size_of); \
560 if(indx2 > indx) \
561 unpck |= array[indx2] << ((size_of) - offset); \
562 unpck & mask; \
563 })
564
565#define MMC_BOOT_MAX_COMMAND_RETRY 10
566#define MMC_BOOT_RD_BLOCK_LEN 512
567#define MMC_BOOT_WR_BLOCK_LEN 512
568
Shashank Mittal7afbf282010-06-02 19:48:31 -0700569/* We have 16 32-bits FIFO registers */
570#define MMC_BOOT_MCI_FIFO_COUNT 16
571#define MMC_BOOT_MCI_HFIFO_COUNT ( MMC_BOOT_MCI_FIFO_COUNT / 2 )
572#define MMC_BOOT_MCI_FIFO_SIZE ( MMC_BOOT_MCI_FIFO_COUNT * 4 )
Shashank Mittal52525ff2010-04-13 11:11:10 -0700573
574/*Need to put at proper place*/
575#define SDC1_CLK 19 /* Secure Digital Card clocks */
576#define SDC1_PCLK 20
577#define SDC2_CLK 21
578#define SDC2_PCLK 22
579#define SDC3_CLK 23
580#define SDC3_PCLK 24
581#define SDC4_CLK 25
582#define SDC4_PCLK 26
583
584#define MAX_PARTITIONS 64
585
586#define MMC_BOOT_CHECK_PATTERN 0xAA /* 10101010b */
587
588#define MMC_CLK_400KHZ 400000
589#define MMC_CLK_144KHZ 144000
590#define MMC_CLK_20MHZ 20000000
591#define MMC_CLK_25MHZ 25000000
Shashank Mittal7afbf282010-06-02 19:48:31 -0700592#define MMC_CLK_48MHZ 48000000
Shashank Mittal52525ff2010-04-13 11:11:10 -0700593#define MMC_CLK_50MHZ 49152000
594
595#define MMC_CLK_ENABLE 1
596#define MMC_CLK_DISABLE 0
597
598#endif
599