xref: /rk3399_ARM-atf/include/drivers/cadence/cdns_sdmmc.h (revision beba20403e23ab128711c2c8c9d480a3a40b804c)
1ddaf02d1SJit Loon Lim /*
2ddaf02d1SJit Loon Lim  * Copyright (c) 2022, ARM Limited and Contributors. All rights reserved.
3ddaf02d1SJit Loon Lim  * Copyright (c) 2022-2023, Intel Corporation. All rights reserved.
4*beba2040SSieu Mun Tang  * Copyright (c) 2024, Altera Corporation. All rights reserved.
5ddaf02d1SJit Loon Lim  *
6ddaf02d1SJit Loon Lim  * SPDX-License-Identifier: BSD-3-Clause
7ddaf02d1SJit Loon Lim  */
8ddaf02d1SJit Loon Lim 
9ddaf02d1SJit Loon Lim #ifndef CDN_MMC_H
10ddaf02d1SJit Loon Lim #define CDN_MMC_H
11ddaf02d1SJit Loon Lim 
12ddaf02d1SJit Loon Lim #include <drivers/cadence/cdns_combo_phy.h>
13ddaf02d1SJit Loon Lim #include <drivers/mmc.h>
14ddaf02d1SJit Loon Lim 
15ddaf02d1SJit Loon Lim #if MMC_DEVICE_TYPE == 0
16ddaf02d1SJit Loon Lim #define CONFIG_DMA_ADDR_T_64BIT			0
17ddaf02d1SJit Loon Lim #endif
18ddaf02d1SJit Loon Lim 
19ddaf02d1SJit Loon Lim #define MMC_REG_BASE				SOCFPGA_MMC_REG_BASE
20ddaf02d1SJit Loon Lim #define COMBO_PHY_REG				0x0
21ddaf02d1SJit Loon Lim #define SDHC_EXTENDED_WR_MODE_MASK		0xFFFFFFF7
22ddaf02d1SJit Loon Lim #define SDHC_DLL_RESET_MASK			0x00000001
23*beba2040SSieu Mun Tang #define MMC_MAX_BLOCK_LEN 512U
24*beba2040SSieu Mun Tang 
25ddaf02d1SJit Loon Lim /* HRS09 */
26ddaf02d1SJit Loon Lim #define SDHC_PHY_SW_RESET			BIT(0)
27ddaf02d1SJit Loon Lim #define SDHC_PHY_INIT_COMPLETE			BIT(1)
28ddaf02d1SJit Loon Lim #define SDHC_EXTENDED_RD_MODE(x)		((x) << 2)
29ddaf02d1SJit Loon Lim #define EXTENDED_WR_MODE			3
30ddaf02d1SJit Loon Lim #define SDHC_EXTENDED_WR_MODE(x)		((x) << 3)
31*beba2040SSieu Mun Tang #define RDCMD_EN				(3 << 15)
32*beba2040SSieu Mun Tang #define PHY_SW_RESET_EN				(1 << 0)
33*beba2040SSieu Mun Tang #define PHY_INIT_COMPLETE_BIT			(1 << 1)
34ddaf02d1SJit Loon Lim #define SDHC_RDCMD_EN(x)			((x) << 15)
35ddaf02d1SJit Loon Lim #define SDHC_RDDATA_EN(x)			((x) << 16)
36ddaf02d1SJit Loon Lim 
37ddaf02d1SJit Loon Lim /* CMD_DATA_OUTPUT */
38ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS16				0x40
39ddaf02d1SJit Loon Lim 
40ddaf02d1SJit Loon Lim /* This value determines the interval by which DAT line timeouts are detected */
41ddaf02d1SJit Loon Lim /* The interval can be computed as below: */
42ddaf02d1SJit Loon Lim /* • 1111b - Reserved */
43ddaf02d1SJit Loon Lim /* • 1110b - t_sdmclk*2(27+2) */
44ddaf02d1SJit Loon Lim /* • 1101b - t_sdmclk*2(26+2) */
45ddaf02d1SJit Loon Lim #define READ_CLK				0xa << 16
46ddaf02d1SJit Loon Lim #define WRITE_CLK				0xe << 16
47ddaf02d1SJit Loon Lim #define DTC_VAL					0xE
48ddaf02d1SJit Loon Lim 
49ddaf02d1SJit Loon Lim /* SRS00 */
50ddaf02d1SJit Loon Lim /* System Address / Argument 2 / 32-bit block count
51ddaf02d1SJit Loon Lim  * This field is used as:
52ddaf02d1SJit Loon Lim  * • 32-bit Block Count register
53ddaf02d1SJit Loon Lim  * • SDMA system memory address
54ddaf02d1SJit Loon Lim  * • Auto CMD23 Argument
55ddaf02d1SJit Loon Lim  */
56ddaf02d1SJit Loon Lim #define SAAR					(1)
57ddaf02d1SJit Loon Lim 
58ddaf02d1SJit Loon Lim /* SRS01 */
59ddaf02d1SJit Loon Lim /* Transfer Block Size
60ddaf02d1SJit Loon Lim  * This field defines block size for block data transfers
61ddaf02d1SJit Loon Lim  */
62ddaf02d1SJit Loon Lim #define BLOCK_SIZE				0
63ddaf02d1SJit Loon Lim 
64ddaf02d1SJit Loon Lim /* SDMA Buffer Boundary
65ddaf02d1SJit Loon Lim  * System address boundary can be set for SDMA engine.
66ddaf02d1SJit Loon Lim  */
67ddaf02d1SJit Loon Lim #define SDMA_BUF				7 << 12
68ddaf02d1SJit Loon Lim 
69ddaf02d1SJit Loon Lim /* Block Count For Current Transfer
70ddaf02d1SJit Loon Lim  * To set the number of data blocks can be defined for next transfer
71ddaf02d1SJit Loon Lim  */
72ddaf02d1SJit Loon Lim #define BLK_COUNT_CT				16
73ddaf02d1SJit Loon Lim 
74ddaf02d1SJit Loon Lim /* SRS03 */
75ddaf02d1SJit Loon Lim #define CMD_START				(U(1) << 31)
76ddaf02d1SJit Loon Lim #define CMD_USE_HOLD_REG			(1 << 29)
77ddaf02d1SJit Loon Lim #define CMD_UPDATE_CLK_ONLY			(1 << 21)
78ddaf02d1SJit Loon Lim #define CMD_SEND_INIT				(1 << 15)
79ddaf02d1SJit Loon Lim #define CMD_STOP_ABORT_CMD			(4 << 22)
80ddaf02d1SJit Loon Lim #define CMD_RESUME_CMD				(2 << 22)
81ddaf02d1SJit Loon Lim #define CMD_SUSPEND_CMD				(1 << 22)
82*beba2040SSieu Mun Tang #define DATA_PRESENT				(0x20)
83*beba2040SSieu Mun Tang #define CMD_IDX_CHK_ENABLE			(0x10)
84ddaf02d1SJit Loon Lim #define CMD_WRITE				(0 << 4)
85ddaf02d1SJit Loon Lim #define CMD_READ				(1 << 4)
86ddaf02d1SJit Loon Lim #define	MULTI_BLK_READ				(1 << 5)
87ddaf02d1SJit Loon Lim #define RESP_ERR				(1 << 7)
88*beba2040SSieu Mun Tang #define CMD_CHECK_RESP_CRC			(0x08)
89*beba2040SSieu Mun Tang #define RES_TYPE_SEL_48				(0x2)
90*beba2040SSieu Mun Tang #define RES_TYPE_SEL_136			(0x1)
91*beba2040SSieu Mun Tang #define RES_TYPE_SEL_48_B			(0x3)
92*beba2040SSieu Mun Tang #define RES_TYPE_SEL_NO				(0x3)
93ddaf02d1SJit Loon Lim #define DMA_ENABLED				(1 << 0)
94ddaf02d1SJit Loon Lim #define BLK_CNT_EN				(1 << 1)
95ddaf02d1SJit Loon Lim #define AUTO_CMD_EN				(2 << 2)
96ddaf02d1SJit Loon Lim #define COM_IDX					24
97ddaf02d1SJit Loon Lim #define ERROR_INT				(1 << 15)
98ddaf02d1SJit Loon Lim #define INT_SBE					(1 << 13)
99ddaf02d1SJit Loon Lim #define INT_HLE					(1 << 12)
100ddaf02d1SJit Loon Lim #define INT_FRUN				(1 << 11)
101ddaf02d1SJit Loon Lim #define INT_DRT					(1 << 9)
102ddaf02d1SJit Loon Lim #define INT_RTO					(1 << 8)
103ddaf02d1SJit Loon Lim #define INT_DCRC				(1 << 7)
104ddaf02d1SJit Loon Lim #define INT_RCRC				(1 << 6)
105ddaf02d1SJit Loon Lim #define INT_RXDR				(1 << 5)
106ddaf02d1SJit Loon Lim #define INT_TXDR				(1 << 4)
107ddaf02d1SJit Loon Lim #define INT_DTO					(1 << 3)
108ddaf02d1SJit Loon Lim #define INT_CMD_DONE				(1 << 0)
109ddaf02d1SJit Loon Lim #define TRAN_COMP				(1 << 1)
110ddaf02d1SJit Loon Lim 
111ddaf02d1SJit Loon Lim /* SRS09 */
112ddaf02d1SJit Loon Lim #define STATUS_DATA_BUSY			BIT(2)
113*beba2040SSieu Mun Tang #define CI					16
114*beba2040SSieu Mun Tang #define CHECK_CARD				BIT(CI)
115ddaf02d1SJit Loon Lim 
116ddaf02d1SJit Loon Lim /* SRS10 */
117*beba2040SSieu Mun Tang #define BIT1					(0 << 1)
118*beba2040SSieu Mun Tang #define BIT4					(1 << 1)
119*beba2040SSieu Mun Tang #define BIT8					(1 << 5)
120*beba2040SSieu Mun Tang 
121ddaf02d1SJit Loon Lim /* LED Control
122ddaf02d1SJit Loon Lim  * State of this bit directly drives led port of the host
123ddaf02d1SJit Loon Lim  * in order to control the external LED diode
124ddaf02d1SJit Loon Lim  * Default value 0 << 1
125ddaf02d1SJit Loon Lim  */
126ddaf02d1SJit Loon Lim #define LEDC					BIT(0)
127*beba2040SSieu Mun Tang #define LEDC_OFF				(0 << 1)
128ddaf02d1SJit Loon Lim 
129ddaf02d1SJit Loon Lim /* Data Transfer Width
130ddaf02d1SJit Loon Lim  * Bit used to configure DAT bus width to 1 or 4
131ddaf02d1SJit Loon Lim  * Default value 1 << 1
132ddaf02d1SJit Loon Lim  */
133ddaf02d1SJit Loon Lim #define DT_WIDTH				BIT(1)
134*beba2040SSieu Mun Tang #define DTW_4BIT				(1 << 1)
135ddaf02d1SJit Loon Lim 
136ddaf02d1SJit Loon Lim /* Extended Data Transfer Width
137ddaf02d1SJit Loon Lim  * This bit is to enable/disable 8-bit DAT bus width mode
138ddaf02d1SJit Loon Lim  * Default value 1 << 5
139ddaf02d1SJit Loon Lim  */
140*beba2040SSieu Mun Tang #define EDTW_8BIT				BIT(5)
141ddaf02d1SJit Loon Lim 
142ddaf02d1SJit Loon Lim /* High Speed Enable
143ddaf02d1SJit Loon Lim  * Selects operating mode to Default Speed (HSE=0) or High Speed (HSE=1)
144ddaf02d1SJit Loon Lim  */
145ddaf02d1SJit Loon Lim #define HS_EN					BIT(2)
146ddaf02d1SJit Loon Lim 
147ddaf02d1SJit Loon Lim /* here 0 defines the 64 Kb size */
148ddaf02d1SJit Loon Lim #define MAX_64KB_PAGE				0
149ddaf02d1SJit Loon Lim #define EMMC_DESC_SIZE				(1<<20)
150*beba2040SSieu Mun Tang #define DTCV_OFFSET				(0x22E)
151*beba2040SSieu Mun Tang #define DTCV_VAL				(0xE)
152*beba2040SSieu Mun Tang #define CICE_OFFSET				(0x20E)
153*beba2040SSieu Mun Tang #define SRS_12_CC_EN				(1 << 0)
154ddaf02d1SJit Loon Lim /* SRS11 */
155ddaf02d1SJit Loon Lim /* Software Reset For All
156ddaf02d1SJit Loon Lim  * When set to 1, the entire slot is reset
157ddaf02d1SJit Loon Lim  * After completing the reset operation, SRFA bit is automatically cleared
158ddaf02d1SJit Loon Lim  */
159ddaf02d1SJit Loon Lim #define SRFA					BIT(24)
160ddaf02d1SJit Loon Lim 
161ddaf02d1SJit Loon Lim /* Software Reset For CMD Line
162ddaf02d1SJit Loon Lim  * When set to 1, resets the logic related to the command generation and response checking
163ddaf02d1SJit Loon Lim  */
164ddaf02d1SJit Loon Lim #define SRCMD					BIT(25)
165ddaf02d1SJit Loon Lim 
166ddaf02d1SJit Loon Lim /* Software Reset For DAT Line
167ddaf02d1SJit Loon Lim  * When set to 1, resets the logic related to the data path,
168ddaf02d1SJit Loon Lim  * including data buffers and the DMA logic
169ddaf02d1SJit Loon Lim  */
170ddaf02d1SJit Loon Lim #define SRDAT					BIT(26)
171ddaf02d1SJit Loon Lim 
172*beba2040SSieu Mun Tang 
173*beba2040SSieu Mun Tang /* SRS12 */
174*beba2040SSieu Mun Tang /* Error mask */
175*beba2040SSieu Mun Tang #define SRS12_ERR_MASK				0xFFFF8000U
176*beba2040SSieu Mun Tang #define CDNS_CSD_BYTE_MASK			0x000000FFU
177*beba2040SSieu Mun Tang 
178ddaf02d1SJit Loon Lim /* SRS15 */
179ddaf02d1SJit Loon Lim /* UHS Mode Select
180ddaf02d1SJit Loon Lim  * Used to select one of UHS-I modes.
181ddaf02d1SJit Loon Lim  * • 000b - SDR12
182ddaf02d1SJit Loon Lim  * • 001b - SDR25
183ddaf02d1SJit Loon Lim  * • 010b - SDR50
184ddaf02d1SJit Loon Lim  * • 011b - SDR104
185ddaf02d1SJit Loon Lim  * • 100b - DDR50
186ddaf02d1SJit Loon Lim  */
187ddaf02d1SJit Loon Lim #define SDR12_MODE				0 << 16
188ddaf02d1SJit Loon Lim #define SDR25_MODE				1 << 16
189ddaf02d1SJit Loon Lim #define SDR50_MODE				2 << 16
190ddaf02d1SJit Loon Lim #define SDR104_MODE				3 << 16
191ddaf02d1SJit Loon Lim #define DDR50_MODE				4 << 16
192ddaf02d1SJit Loon Lim /* 1.8V Signaling Enable
193ddaf02d1SJit Loon Lim  * • 0 - for Default Speed, High Speed mode
194ddaf02d1SJit Loon Lim  * • 1 - for UHS-I mode
195ddaf02d1SJit Loon Lim  */
196ddaf02d1SJit Loon Lim #define V18SE					BIT(19)
197ddaf02d1SJit Loon Lim 
198ddaf02d1SJit Loon Lim /* CMD23 Enable
199ddaf02d1SJit Loon Lim  * In result of Card Identification process,
200ddaf02d1SJit Loon Lim  * Host Driver set this bit to 1 if Card supports CMD23
201ddaf02d1SJit Loon Lim  */
202ddaf02d1SJit Loon Lim #define CMD23_EN				BIT(27)
203ddaf02d1SJit Loon Lim 
204ddaf02d1SJit Loon Lim /* Host Version 4.00 Enable
205ddaf02d1SJit Loon Lim  * • 0 - Version 3.00
206ddaf02d1SJit Loon Lim  * • 1 - Version 4.00
207ddaf02d1SJit Loon Lim  */
208ddaf02d1SJit Loon Lim #define HV4E					BIT(28)
209ddaf02d1SJit Loon Lim /* Conf depends on SRS15.HV4E */
210ddaf02d1SJit Loon Lim #define SDMA					0 << 3
211ddaf02d1SJit Loon Lim #define ADMA2_32				2 << 3
212ddaf02d1SJit Loon Lim #define ADMA2_64				3 << 3
213*beba2040SSieu Mun Tang #define DMA_SEL_BIT				3 << 3
214*beba2040SSieu Mun Tang #define DMA_SEL_BIT_2				2 << 3
215*beba2040SSieu Mun Tang #define DMA_SEL_BIT_3				3 << 3
216ddaf02d1SJit Loon Lim 
217ddaf02d1SJit Loon Lim /* Preset Value Enable
218ddaf02d1SJit Loon Lim  * Setting this bit to 1 triggers an automatically update of SRS11
219ddaf02d1SJit Loon Lim  */
220ddaf02d1SJit Loon Lim #define PVE					BIT(31)
221ddaf02d1SJit Loon Lim 
222ddaf02d1SJit Loon Lim #define BIT_AD_32				0 << 29
223ddaf02d1SJit Loon Lim #define BIT_AD_64				1 << 29
224ddaf02d1SJit Loon Lim 
225ddaf02d1SJit Loon Lim /* SW RESET REG*/
226ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS00				(0x00)
227ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS00_SWR			BIT(0)
228ddaf02d1SJit Loon Lim 
229ddaf02d1SJit Loon Lim /* PHY access port */
230ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS04				0x10
231ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS04_ADDR			GENMASK(5, 0)
232ddaf02d1SJit Loon Lim 
233ddaf02d1SJit Loon Lim /* PHY data access port */
234ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS05				0x14
235ddaf02d1SJit Loon Lim 
236ddaf02d1SJit Loon Lim /* eMMC control registers */
237ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS06				0x18
238ddaf02d1SJit Loon Lim 
239ddaf02d1SJit Loon Lim /* SRS */
240ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS_BASE			0x200
241ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS00				0x200
242ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS01				0x204
243ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS02				0x208
244ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS03				0x20c
245ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS04				0x210
246ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS05				0x214
247ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS06				0x218
248ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS07				0x21C
249ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS08				0x220
250ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS09				0x224
251ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS09_CI			BIT(16)
252ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS10				0x228
253ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS11				0x22C
254ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS12				0x230
255ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS13				0x234
256ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS14				0x238
257ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS15				0x23c
258*beba2040SSieu Mun Tang #define SDHC_CDNS_SRS16				0x240
259ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS21				0x254
260ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS22				0x258
261ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS23				0x25c
262*beba2040SSieu Mun Tang #define SDHC_CDNS_SRS24				0x260
263*beba2040SSieu Mun Tang #define SDHC_CDNS_SRS25				0x264
264*beba2040SSieu Mun Tang 
265*beba2040SSieu Mun Tang /* SRS00 */
266*beba2040SSieu Mun Tang #define SAAR					(1)
267*beba2040SSieu Mun Tang 
268*beba2040SSieu Mun Tang /* SRS03 */
269*beba2040SSieu Mun Tang #define CMD_START				(U(1) << 31)
270*beba2040SSieu Mun Tang #define CMD_USE_HOLD_REG			(1 << 29)
271*beba2040SSieu Mun Tang #define CMD_UPDATE_CLK_ONLY			(1 << 21)
272*beba2040SSieu Mun Tang #define CMD_SEND_INIT				(1 << 15)
273*beba2040SSieu Mun Tang #define CMD_STOP_ABORT_CMD			(4 << 22)
274*beba2040SSieu Mun Tang #define CMD_RESUME_CMD				(2 << 22)
275*beba2040SSieu Mun Tang #define CMD_SUSPEND_CMD				(1 << 22)
276*beba2040SSieu Mun Tang #define DMA_ENABLED				(1 << 0)
277*beba2040SSieu Mun Tang #define BLK_CNT_EN				(1 << 1)
278*beba2040SSieu Mun Tang #define AUTO_CMD_EN				(2 << 2)
279*beba2040SSieu Mun Tang #define COM_IDX					24
280*beba2040SSieu Mun Tang #define ERROR_INT				(1 << 15)
281*beba2040SSieu Mun Tang #define INT_SBE					(1 << 13)
282*beba2040SSieu Mun Tang #define INT_HLE					(1 << 12)
283*beba2040SSieu Mun Tang #define INT_FRUN				(1 << 11)
284*beba2040SSieu Mun Tang #define INT_DRT					(1 << 9)
285*beba2040SSieu Mun Tang #define INT_RTO					(1 << 8)
286*beba2040SSieu Mun Tang #define INT_DCRC				(1 << 7)
287*beba2040SSieu Mun Tang #define INT_RCRC				(1 << 6)
288*beba2040SSieu Mun Tang #define INT_RXDR				(1 << 5)
289*beba2040SSieu Mun Tang #define INT_TXDR				(1 << 4)
290*beba2040SSieu Mun Tang #define INT_DTO					(1 << 3)
291*beba2040SSieu Mun Tang #define INT_CMD_DONE				(1 << 0)
292*beba2040SSieu Mun Tang #define TRAN_COMP				(1 << 1)
293*beba2040SSieu Mun Tang #define CDNS_HOST_CMD_INHIBIT			(BIT(0))
294*beba2040SSieu Mun Tang #define CDNS_HOST_DATA_INHIBIT			(BIT(1))
295*beba2040SSieu Mun Tang #define ACE_CMD_12				(BIT(2))
296*beba2040SSieu Mun Tang 
297*beba2040SSieu Mun Tang #define PAGE_BUFFER_LEN				(64 * 1024)
298ddaf02d1SJit Loon Lim 
299ddaf02d1SJit Loon Lim /* HRS07 */
300ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS07				0x1c
301ddaf02d1SJit Loon Lim #define SDHC_IDELAY_VAL(x)			((x) << 0)
302ddaf02d1SJit Loon Lim #define SDHC_RW_COMPENSATE(x)			((x) << 16)
303ddaf02d1SJit Loon Lim 
304ddaf02d1SJit Loon Lim /* PHY reset port */
305ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS09				0x24
306ddaf02d1SJit Loon Lim 
307ddaf02d1SJit Loon Lim /* HRS10 */
308ddaf02d1SJit Loon Lim /* PHY reset port */
309ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS10				0x28
310ddaf02d1SJit Loon Lim 
311ddaf02d1SJit Loon Lim /* HCSDCLKADJ DATA; DDR Mode */
312ddaf02d1SJit Loon Lim #define SDHC_HCSDCLKADJ(x)			((x) << 16)
313ddaf02d1SJit Loon Lim 
314ddaf02d1SJit Loon Lim /* Pinmux headers will reomove after ATF driver implementation */
315ddaf02d1SJit Loon Lim #define PINMUX_SDMMC_SEL			0x0
316ddaf02d1SJit Loon Lim #define PIN0SEL					0x00
317ddaf02d1SJit Loon Lim #define PIN1SEL					0x04
318ddaf02d1SJit Loon Lim #define PIN2SEL					0x08
319ddaf02d1SJit Loon Lim #define PIN3SEL					0x0C
320ddaf02d1SJit Loon Lim #define PIN4SEL					0x10
321ddaf02d1SJit Loon Lim #define PIN5SEL					0x14
322ddaf02d1SJit Loon Lim #define PIN6SEL					0x18
323ddaf02d1SJit Loon Lim #define PIN7SEL					0x1C
324ddaf02d1SJit Loon Lim #define PIN8SEL					0x20
325ddaf02d1SJit Loon Lim #define PIN9SEL					0x24
326ddaf02d1SJit Loon Lim #define PIN10SEL				0x28
327ddaf02d1SJit Loon Lim 
328ddaf02d1SJit Loon Lim /* HRS16 */
329ddaf02d1SJit Loon Lim #define SDHC_WRCMD0_DLY(x)			((x) << 0)
330ddaf02d1SJit Loon Lim #define SDHC_WRCMD1_DLY(x)			((x) << 4)
331ddaf02d1SJit Loon Lim #define SDHC_WRDATA0_DLY(x)			((x) << 8)
332ddaf02d1SJit Loon Lim #define SDHC_WRDATA1_DLY(x)			((x) << 12)
333ddaf02d1SJit Loon Lim #define SDHC_WRCMD0_SDCLK_DLY(x)		((x) << 16)
334ddaf02d1SJit Loon Lim #define SDHC_WRCMD1_SDCLK_DLY(x)		((x) << 20)
335ddaf02d1SJit Loon Lim #define SDHC_WRDATA0_SDCLK_DLY(x)		((x) << 24)
336ddaf02d1SJit Loon Lim #define SDHC_WRDATA1_SDCLK_DLY(x)		((x) << 28)
337ddaf02d1SJit Loon Lim 
338ddaf02d1SJit Loon Lim /* Shared Macros */
339ddaf02d1SJit Loon Lim #define SDMMC_CDN(_reg)				(SDMMC_CDN_REG_BASE + \
340ddaf02d1SJit Loon Lim 								(SDMMC_CDN_##_reg))
341ddaf02d1SJit Loon Lim 
342ddaf02d1SJit Loon Lim /* MMC Peripheral Definition */
343ddaf02d1SJit Loon Lim #define SOCFPGA_MMC_BLOCK_MASK			(SOCFPGA_MMC_BLOCK_SIZE - U(1))
344ddaf02d1SJit Loon Lim #define SOCFPGA_MMC_BOOT_CLK_RATE		(400 * 1000)
345ddaf02d1SJit Loon Lim #define MMC_RESPONSE_NONE			0
346ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS03_VALUE			0x01020013
347ddaf02d1SJit Loon Lim 
348ddaf02d1SJit Loon Lim /* Value randomly chosen for eMMC RCA, it should be > 1 */
349ddaf02d1SJit Loon Lim #define MMC_FIX_RCA				6
350ddaf02d1SJit Loon Lim #define RCA_SHIFT_OFFSET			16
351ddaf02d1SJit Loon Lim 
352ddaf02d1SJit Loon Lim #define CMD_EXTCSD_PARTITION_CONFIG		179
353ddaf02d1SJit Loon Lim #define CMD_EXTCSD_BUS_WIDTH			183
354ddaf02d1SJit Loon Lim #define CMD_EXTCSD_HS_TIMING			185
355ddaf02d1SJit Loon Lim #define CMD_EXTCSD_SEC_CNT			212
356ddaf02d1SJit Loon Lim 
357ddaf02d1SJit Loon Lim #define PART_CFG_BOOT_PARTITION1_ENABLE		(U(1) << 3)
358ddaf02d1SJit Loon Lim #define PART_CFG_PARTITION1_ACCESS		(U(1) << 0)
359ddaf02d1SJit Loon Lim 
360ddaf02d1SJit Loon Lim /* Values in EXT CSD register */
361ddaf02d1SJit Loon Lim #define MMC_BUS_WIDTH_1				U(0)
362ddaf02d1SJit Loon Lim #define MMC_BUS_WIDTH_4				U(1)
363ddaf02d1SJit Loon Lim #define MMC_BUS_WIDTH_8				U(2)
364ddaf02d1SJit Loon Lim #define MMC_BUS_WIDTH_DDR_4			U(5)
365ddaf02d1SJit Loon Lim #define MMC_BUS_WIDTH_DDR_8			U(6)
366ddaf02d1SJit Loon Lim #define MMC_BOOT_MODE_BACKWARD			(U(0) << 3)
367ddaf02d1SJit Loon Lim #define MMC_BOOT_MODE_HS_TIMING			(U(1) << 3)
368ddaf02d1SJit Loon Lim #define MMC_BOOT_MODE_DDR			(U(2) << 3)
369ddaf02d1SJit Loon Lim 
370ddaf02d1SJit Loon Lim #define EXTCSD_SET_CMD				(U(0) << 24)
371ddaf02d1SJit Loon Lim #define EXTCSD_SET_BITS				(U(1) << 24)
372ddaf02d1SJit Loon Lim #define EXTCSD_CLR_BITS				(U(2) << 24)
373ddaf02d1SJit Loon Lim #define EXTCSD_WRITE_BYTES			(U(3) << 24)
374ddaf02d1SJit Loon Lim #define EXTCSD_CMD(x)				(((x) & 0xff) << 16)
375ddaf02d1SJit Loon Lim #define EXTCSD_VALUE(x)				(((x) & 0xff) << 8)
376ddaf02d1SJit Loon Lim #define EXTCSD_CMD_SET_NORMAL			U(1)
377ddaf02d1SJit Loon Lim 
378ddaf02d1SJit Loon Lim #define CSD_TRAN_SPEED_UNIT_MASK		GENMASK(2, 0)
379ddaf02d1SJit Loon Lim #define CSD_TRAN_SPEED_MULT_MASK		GENMASK(6, 3)
380ddaf02d1SJit Loon Lim #define CSD_TRAN_SPEED_MULT_SHIFT		3
381ddaf02d1SJit Loon Lim 
382ddaf02d1SJit Loon Lim #define STATUS_CURRENT_STATE(x)			(((x) & 0xf) << 9)
383ddaf02d1SJit Loon Lim #define STATUS_READY_FOR_DATA			BIT(8)
384ddaf02d1SJit Loon Lim #define STATUS_SWITCH_ERROR			BIT(7)
385ddaf02d1SJit Loon Lim #define MMC_GET_STATE(x)			(((x) >> 9) & 0xf)
386ddaf02d1SJit Loon Lim #define MMC_STATE_IDLE				0
387ddaf02d1SJit Loon Lim #define MMC_STATE_READY				1
388ddaf02d1SJit Loon Lim #define MMC_STATE_IDENT				2
389ddaf02d1SJit Loon Lim #define MMC_STATE_STBY				3
390ddaf02d1SJit Loon Lim #define MMC_STATE_TRAN				4
391ddaf02d1SJit Loon Lim #define MMC_STATE_DATA				5
392ddaf02d1SJit Loon Lim #define MMC_STATE_RCV				6
393ddaf02d1SJit Loon Lim #define MMC_STATE_PRG				7
394ddaf02d1SJit Loon Lim #define MMC_STATE_DIS				8
395ddaf02d1SJit Loon Lim #define MMC_STATE_BTST				9
396ddaf02d1SJit Loon Lim #define MMC_STATE_SLP				10
397ddaf02d1SJit Loon Lim 
398ddaf02d1SJit Loon Lim #define MMC_FLAG_CMD23				(U(1) << 0)
399ddaf02d1SJit Loon Lim 
400ddaf02d1SJit Loon Lim #define CMD8_CHECK_PATTERN			U(0xAA)
401ddaf02d1SJit Loon Lim #define VHS_2_7_3_6_V				BIT(8)
402ddaf02d1SJit Loon Lim 
403ddaf02d1SJit Loon Lim /*ADMA table component*/
404ddaf02d1SJit Loon Lim #define ADMA_DESC_ATTR_VALID			BIT(0)
405ddaf02d1SJit Loon Lim #define ADMA_DESC_ATTR_END			BIT(1)
406ddaf02d1SJit Loon Lim #define ADMA_DESC_ATTR_INT			BIT(2)
407ddaf02d1SJit Loon Lim #define ADMA_DESC_ATTR_ACT1			BIT(4)
408ddaf02d1SJit Loon Lim #define ADMA_DESC_ATTR_ACT2			BIT(5)
409ddaf02d1SJit Loon Lim #define ADMA_DESC_TRANSFER_DATA			ADMA_DESC_ATTR_ACT2
410ddaf02d1SJit Loon Lim 
411*beba2040SSieu Mun Tang #define HRS_09_EXTENDED_RD_MODE			(1 << 2)
412*beba2040SSieu Mun Tang #define HRS_09_EXTENDED_WR_MODE			(1 << 3)
413*beba2040SSieu Mun Tang #define HRS_09_RDCMD_EN				(1 << 15)
414*beba2040SSieu Mun Tang #define HRS_09_RDDATA_EN			(1 << 16)
415*beba2040SSieu Mun Tang #define HRS_10_HCSDCLKADJ_VAL			(3)
416*beba2040SSieu Mun Tang 
417*beba2040SSieu Mun Tang #define SRS11_SRFA				(1 << 24)
418*beba2040SSieu Mun Tang #define SRS11_SRFA_CHK(x)			(x >> 24)
419*beba2040SSieu Mun Tang #define CDNS_TIMEOUT				(5000)
420*beba2040SSieu Mun Tang 
421*beba2040SSieu Mun Tang #define SDHCI_MAKE_CMD(c, f) (((c & 0xff) << 8) | (f & 0xff))
422*beba2040SSieu Mun Tang 
423*beba2040SSieu Mun Tang /* Card busy and present */
424*beba2040SSieu Mun Tang #define CARD_BUSY				1
425*beba2040SSieu Mun Tang #define CARD_NOT_BUSY				0
426*beba2040SSieu Mun Tang 
427*beba2040SSieu Mun Tang /* 500 ms delay to read the RINST register */
428*beba2040SSieu Mun Tang #define DELAY_MS_SRS_READ			500
429*beba2040SSieu Mun Tang #define DELAY_RES				10
430*beba2040SSieu Mun Tang 
431*beba2040SSieu Mun Tang /* Check DV dfi_init val=0 */
432*beba2040SSieu Mun Tang #define IO_MASK_END_DATA			0x0
433*beba2040SSieu Mun Tang 
434*beba2040SSieu Mun Tang /* Check DV dfi_init val=2; DDR Mode */
435*beba2040SSieu Mun Tang #define IO_MASK_END_DATA_DDR			0x2
436*beba2040SSieu Mun Tang #define IO_MASK_START_DATA			0x0
437*beba2040SSieu Mun Tang #define DATA_SELECT_OE_END_DATA			0x1
438*beba2040SSieu Mun Tang 
439*beba2040SSieu Mun Tang #define TIMEOUT					100000
440*beba2040SSieu Mun Tang 
441*beba2040SSieu Mun Tang /* General define */
442*beba2040SSieu Mun Tang #define SDHC_REG_MASK				UINT_MAX
443*beba2040SSieu Mun Tang #define SD_HOST_BLOCK_SIZE			0x200
444*beba2040SSieu Mun Tang #define DTCVVAL_DEFAULT_VAL			0xE
445*beba2040SSieu Mun Tang #define CDMMC_DMA_MAX_BUFFER_SIZE		64*1024
446*beba2040SSieu Mun Tang #define CDNSMMC_ADDRESS_MASK			U(0x0f)
447*beba2040SSieu Mun Tang #define CONFIG_CDNS_DESC_COUNT			8
448*beba2040SSieu Mun Tang #define SD_HOST_CLK				200000000
449*beba2040SSieu Mun Tang 
450ddaf02d1SJit Loon Lim enum sd_opcode {
451ddaf02d1SJit Loon Lim 	SD_GO_IDLE_STATE = 0,
452ddaf02d1SJit Loon Lim 	SD_ALL_SEND_CID = 2,
453ddaf02d1SJit Loon Lim 	SD_SEND_RELATIVE_ADDR = 3,
454ddaf02d1SJit Loon Lim 	SDIO_SEND_OP_COND = 5, /* SDIO cards only */
455ddaf02d1SJit Loon Lim 	SD_SWITCH = 6,
456ddaf02d1SJit Loon Lim 	SD_SELECT_CARD = 7,
457ddaf02d1SJit Loon Lim 	SD_SEND_IF_COND = 8,
458ddaf02d1SJit Loon Lim 	SD_SEND_CSD = 9,
459ddaf02d1SJit Loon Lim 	SD_SEND_CID = 10,
460ddaf02d1SJit Loon Lim 	SD_VOL_SWITCH = 11,
461ddaf02d1SJit Loon Lim 	SD_STOP_TRANSMISSION = 12,
462ddaf02d1SJit Loon Lim 	SD_SEND_STATUS = 13,
463ddaf02d1SJit Loon Lim 	SD_GO_INACTIVE_STATE = 15,
464ddaf02d1SJit Loon Lim 	SD_SET_BLOCK_SIZE = 16,
465ddaf02d1SJit Loon Lim 	SD_READ_SINGLE_BLOCK = 17,
466ddaf02d1SJit Loon Lim 	SD_READ_MULTIPLE_BLOCK = 18,
467ddaf02d1SJit Loon Lim 	SD_SEND_TUNING_BLOCK = 19,
468ddaf02d1SJit Loon Lim 	SD_SET_BLOCK_COUNT = 23,
469ddaf02d1SJit Loon Lim 	SD_WRITE_SINGLE_BLOCK = 24,
470ddaf02d1SJit Loon Lim 	SD_WRITE_MULTIPLE_BLOCK = 25,
471ddaf02d1SJit Loon Lim 	SD_ERASE_BLOCK_START = 32,
472ddaf02d1SJit Loon Lim 	SD_ERASE_BLOCK_END = 33,
473ddaf02d1SJit Loon Lim 	SD_ERASE_BLOCK_OPERATION = 38,
474ddaf02d1SJit Loon Lim 	SD_APP_CMD = 55,
475ddaf02d1SJit Loon Lim 	SD_SPI_READ_OCR = 58, /* SPI mode only */
476ddaf02d1SJit Loon Lim 	SD_SPI_CRC_ON_OFF = 59, /* SPI mode only */
477ddaf02d1SJit Loon Lim };
478ddaf02d1SJit Loon Lim 
479ddaf02d1SJit Loon Lim enum sd_app_cmd {
480ddaf02d1SJit Loon Lim 	SD_APP_SET_BUS_WIDTH = 6,
481ddaf02d1SJit Loon Lim 	SD_APP_SEND_STATUS = 13,
482ddaf02d1SJit Loon Lim 	SD_APP_SEND_NUM_WRITTEN_BLK = 22,
483ddaf02d1SJit Loon Lim 	SD_APP_SET_WRITE_BLK_ERASE_CNT = 23,
484ddaf02d1SJit Loon Lim 	SD_APP_SEND_OP_COND = 41,
485ddaf02d1SJit Loon Lim 	SD_APP_CLEAR_CARD_DETECT = 42,
486ddaf02d1SJit Loon Lim 	SD_APP_SEND_SCR = 51,
487ddaf02d1SJit Loon Lim };
488ddaf02d1SJit Loon Lim 
489*beba2040SSieu Mun Tang enum sd_opr_modes {
490*beba2040SSieu Mun Tang 	SD_HOST_OPR_MODE_HV4E_0_SDMA_32 = 0,
491*beba2040SSieu Mun Tang 	SD_HOST_OPR_MODE_HV4E_1_SDMA_32,
492*beba2040SSieu Mun Tang 	SD_HOST_OPR_MODE_HV4E_1_SDMA_64,
493*beba2040SSieu Mun Tang 	SD_HOST_OPR_MODE_HV4E_0_ADMA_32,
494*beba2040SSieu Mun Tang 	SD_HOST_OPR_MODE_HV4E_0_ADMA_64,
495*beba2040SSieu Mun Tang 	SD_HOST_OPR_MODE_HV4E_1_ADMA_32,
496*beba2040SSieu Mun Tang 	SD_HOST_OPR_MODE_HV4E_1_ADMA_64,
497*beba2040SSieu Mun Tang };
498*beba2040SSieu Mun Tang 
499ddaf02d1SJit Loon Lim struct cdns_sdmmc_sdhc {
500ddaf02d1SJit Loon Lim 	uint32_t	sdhc_extended_rd_mode;
501ddaf02d1SJit Loon Lim 	uint32_t	sdhc_extended_wr_mode;
502ddaf02d1SJit Loon Lim 	uint32_t	sdhc_hcsdclkadj;
503ddaf02d1SJit Loon Lim 	uint32_t	sdhc_idelay_val;
504ddaf02d1SJit Loon Lim 	uint32_t	sdhc_rdcmd_en;
505ddaf02d1SJit Loon Lim 	uint32_t	sdhc_rddata_en;
506ddaf02d1SJit Loon Lim 	uint32_t	sdhc_rw_compensate;
507ddaf02d1SJit Loon Lim 	uint32_t	sdhc_sdcfsh;
508ddaf02d1SJit Loon Lim 	uint32_t	sdhc_sdcfsl;
509ddaf02d1SJit Loon Lim 	uint32_t	sdhc_wrcmd0_dly;
510ddaf02d1SJit Loon Lim 	uint32_t	sdhc_wrcmd0_sdclk_dly;
511ddaf02d1SJit Loon Lim 	uint32_t	sdhc_wrcmd1_dly;
512ddaf02d1SJit Loon Lim 	uint32_t	sdhc_wrcmd1_sdclk_dly;
513ddaf02d1SJit Loon Lim 	uint32_t	sdhc_wrdata0_dly;
514ddaf02d1SJit Loon Lim 	uint32_t	sdhc_wrdata0_sdclk_dly;
515ddaf02d1SJit Loon Lim 	uint32_t	sdhc_wrdata1_dly;
516ddaf02d1SJit Loon Lim 	uint32_t	sdhc_wrdata1_sdclk_dly;
517ddaf02d1SJit Loon Lim };
518ddaf02d1SJit Loon Lim 
519ddaf02d1SJit Loon Lim enum sdmmc_device_mode {
520ddaf02d1SJit Loon Lim 	SD_DS_ID, /* Identification */
521ddaf02d1SJit Loon Lim 	SD_DS, /* Default speed */
522ddaf02d1SJit Loon Lim 	SD_HS, /* High speed */
523ddaf02d1SJit Loon Lim 	SD_UHS_SDR12, /* Ultra high speed SDR12 */
524ddaf02d1SJit Loon Lim 	SD_UHS_SDR25, /* Ultra high speed SDR25 */
525ddaf02d1SJit Loon Lim 	SD_UHS_SDR50, /* Ultra high speed SDR`50 */
526ddaf02d1SJit Loon Lim 	SD_UHS_SDR104, /* Ultra high speed SDR104 */
527ddaf02d1SJit Loon Lim 	SD_UHS_DDR50, /* Ultra high speed DDR50 */
528ddaf02d1SJit Loon Lim 	EMMC_SDR_BC, /* SDR backward compatible */
529ddaf02d1SJit Loon Lim 	EMMC_SDR, /* SDR */
530ddaf02d1SJit Loon Lim 	EMMC_DDR, /* DDR */
531ddaf02d1SJit Loon Lim 	EMMC_HS200, /* High speed 200Mhz in SDR */
532ddaf02d1SJit Loon Lim 	EMMC_HS400, /* High speed 200Mhz in DDR */
533ddaf02d1SJit Loon Lim 	EMMC_HS400es, /* High speed 200Mhz in SDR with enhanced strobe*/
534ddaf02d1SJit Loon Lim };
535ddaf02d1SJit Loon Lim 
536ddaf02d1SJit Loon Lim struct cdns_sdmmc_params {
537ddaf02d1SJit Loon Lim 	uintptr_t	reg_base;
538ddaf02d1SJit Loon Lim 	uintptr_t	reg_pinmux;
539ddaf02d1SJit Loon Lim 	uintptr_t	reg_phy;
540ddaf02d1SJit Loon Lim 	uintptr_t	desc_base;
541ddaf02d1SJit Loon Lim 	size_t		desc_size;
542ddaf02d1SJit Loon Lim 	int		clk_rate;
543ddaf02d1SJit Loon Lim 	int		bus_width;
544ddaf02d1SJit Loon Lim 	unsigned int	flags;
545ddaf02d1SJit Loon Lim 	enum sdmmc_device_mode	cdn_sdmmc_dev_mode;
546ddaf02d1SJit Loon Lim 	enum mmc_device_type	cdn_sdmmc_dev_type;
547ddaf02d1SJit Loon Lim 	uint32_t	combophy;
548ddaf02d1SJit Loon Lim };
549ddaf02d1SJit Loon Lim 
550ddaf02d1SJit Loon Lim 
551ddaf02d1SJit Loon Lim struct cdns_idmac_desc {
552ddaf02d1SJit Loon Lim 	/*8 bit attribute*/
553ddaf02d1SJit Loon Lim 	uint8_t attr;
554ddaf02d1SJit Loon Lim 	/*reserved bits in desc*/
555ddaf02d1SJit Loon Lim 	uint8_t reserved;
556ddaf02d1SJit Loon Lim 	/*page length for the descriptor*/
557ddaf02d1SJit Loon Lim 	uint16_t len;
558ddaf02d1SJit Loon Lim 	/*lower 32 bits for buffer (64 bit addressing)*/
559ddaf02d1SJit Loon Lim 	uint32_t addr_lo;
560ddaf02d1SJit Loon Lim #if CONFIG_DMA_ADDR_T_64BIT == 1
561ddaf02d1SJit Loon Lim 	/*higher 32 bits for buffer (64 bit addressing)*/
562ddaf02d1SJit Loon Lim 	uint32_t addr_hi;
563ddaf02d1SJit Loon Lim } __aligned(8);
564ddaf02d1SJit Loon Lim #else
565ddaf02d1SJit Loon Lim } __packed;
566ddaf02d1SJit Loon Lim #endif
567ddaf02d1SJit Loon Lim 
568ddaf02d1SJit Loon Lim 
569ddaf02d1SJit Loon Lim 
570ddaf02d1SJit Loon Lim /* Function Prototype */
571ddaf02d1SJit Loon Lim int cdns_sd_host_init(struct cdns_sdmmc_combo_phy *mmc_combo_phy_reg,
572ddaf02d1SJit Loon Lim struct cdns_sdmmc_sdhc *mmc_sdhc_reg);
573ddaf02d1SJit Loon Lim void cdns_set_sdmmc_var(struct cdns_sdmmc_combo_phy *combo_phy_reg,
574ddaf02d1SJit Loon Lim struct cdns_sdmmc_sdhc *sdhc_reg);
575*beba2040SSieu Mun Tang int cdns_mmc_init(struct cdns_sdmmc_params *params, struct mmc_device_info *info);
576*beba2040SSieu Mun Tang int cdns_program_phy_reg(struct cdns_sdmmc_combo_phy *combo_phy_reg,
577*beba2040SSieu Mun Tang 				struct cdns_sdmmc_sdhc *sdhc_reg);
578*beba2040SSieu Mun Tang void cdns_host_set_clk(uint32_t clk);
579ddaf02d1SJit Loon Lim #endif
580