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