xref: /rk3399_ARM-atf/drivers/imx/usdhc/imx_usdhc.h (revision 8b6591302a779da64778cd076f4e31c3c89845e3)
1*8b659130SJun Nie /*
2*8b659130SJun Nie  * Copyright (c) 2018, ARM Limited and Contributors. All rights reserved.
3*8b659130SJun Nie  *
4*8b659130SJun Nie  * SPDX-License-Identifier: BSD-3-Clause
5*8b659130SJun Nie  */
6*8b659130SJun Nie 
7*8b659130SJun Nie #ifndef __IMX_USDHC_H__
8*8b659130SJun Nie #define	__IMX_USDHC_H__
9*8b659130SJun Nie 
10*8b659130SJun Nie #include <mmc.h>
11*8b659130SJun Nie 
12*8b659130SJun Nie typedef struct imx_usdhc_params {
13*8b659130SJun Nie 	uintptr_t	reg_base;
14*8b659130SJun Nie 	int		clk_rate;
15*8b659130SJun Nie 	int		bus_width;
16*8b659130SJun Nie 	unsigned int	flags;
17*8b659130SJun Nie } imx_usdhc_params_t;
18*8b659130SJun Nie 
19*8b659130SJun Nie void imx_usdhc_init(imx_usdhc_params_t *params,
20*8b659130SJun Nie 		    struct mmc_device_info *mmc_dev_info);
21*8b659130SJun Nie 
22*8b659130SJun Nie /* iMX MMC registers definition */
23*8b659130SJun Nie #define DSADDR			0x000
24*8b659130SJun Nie #define BLKATT			0x004
25*8b659130SJun Nie #define CMDARG			0x008
26*8b659130SJun Nie #define CMDRSP0			0x010
27*8b659130SJun Nie #define CMDRSP1			0x014
28*8b659130SJun Nie #define CMDRSP2			0x018
29*8b659130SJun Nie #define CMDRSP3			0x01c
30*8b659130SJun Nie 
31*8b659130SJun Nie #define XFERTYPE		0x00c
32*8b659130SJun Nie #define XFERTYPE_CMD(x)		(((x) & 0x3f) << 24)
33*8b659130SJun Nie #define XFERTYPE_CMDTYP_ABORT	(3 << 22)
34*8b659130SJun Nie #define XFERTYPE_DPSEL		BIT(21)
35*8b659130SJun Nie #define XFERTYPE_CICEN		BIT(20)
36*8b659130SJun Nie #define XFERTYPE_CCCEN		BIT(19)
37*8b659130SJun Nie #define XFERTYPE_RSPTYP_136	BIT(16)
38*8b659130SJun Nie #define XFERTYPE_RSPTYP_48	BIT(17)
39*8b659130SJun Nie #define XFERTYPE_RSPTYP_48_BUSY	(BIT(16) | BIT(17))
40*8b659130SJun Nie 
41*8b659130SJun Nie #define PSTATE			0x024
42*8b659130SJun Nie #define PSTATE_DAT0		BIT(24)
43*8b659130SJun Nie #define PSTATE_DLA		BIT(2)
44*8b659130SJun Nie #define PSTATE_CDIHB		BIT(1)
45*8b659130SJun Nie #define PSTATE_CIHB		BIT(0)
46*8b659130SJun Nie 
47*8b659130SJun Nie #define PROTCTRL		0x028
48*8b659130SJun Nie #define PROTCTRL_LE		BIT(5)
49*8b659130SJun Nie #define PROTCTRL_WIDTH_4	BIT(1)
50*8b659130SJun Nie #define PROTCTRL_WIDTH_8	BIT(2)
51*8b659130SJun Nie #define PROTCTRL_WIDTH_MASK	0x6
52*8b659130SJun Nie 
53*8b659130SJun Nie #define SYSCTRL			0x02c
54*8b659130SJun Nie #define SYSCTRL_RSTD		BIT(26)
55*8b659130SJun Nie #define SYSCTRL_RSTC		BIT(25)
56*8b659130SJun Nie #define SYSCTRL_RSTA		BIT(24)
57*8b659130SJun Nie #define SYSCTRL_CLOCK_MASK	0x0000fff0
58*8b659130SJun Nie #define SYSCTRL_TIMEOUT_MASK	0x000f0000
59*8b659130SJun Nie #define SYSCTRL_TIMEOUT(x)	((0xf & (x)) << 16)
60*8b659130SJun Nie 
61*8b659130SJun Nie #define INTSTAT			0x030
62*8b659130SJun Nie #define INTSTAT_DMAE		BIT(28)
63*8b659130SJun Nie #define INTSTAT_DEBE		BIT(22)
64*8b659130SJun Nie #define INTSTAT_DCE		BIT(21)
65*8b659130SJun Nie #define INTSTAT_DTOE		BIT(20)
66*8b659130SJun Nie #define INTSTAT_CIE		BIT(19)
67*8b659130SJun Nie #define INTSTAT_CEBE		BIT(18)
68*8b659130SJun Nie #define INTSTAT_CCE		BIT(17)
69*8b659130SJun Nie #define INTSTAT_DINT		BIT(3)
70*8b659130SJun Nie #define INTSTAT_BGE		BIT(2)
71*8b659130SJun Nie #define INTSTAT_TC		BIT(1)
72*8b659130SJun Nie #define INTSTAT_CC		BIT(0)
73*8b659130SJun Nie #define CMD_ERR			(INTSTAT_CIE | INTSTAT_CEBE | INTSTAT_CCE)
74*8b659130SJun Nie #define DATA_ERR		(INTSTAT_DMAE | INTSTAT_DEBE | INTSTAT_DCE | \
75*8b659130SJun Nie 				 INTSTAT_DTOE)
76*8b659130SJun Nie #define DATA_COMPLETE		(INTSTAT_DINT | INTSTAT_TC)
77*8b659130SJun Nie 
78*8b659130SJun Nie #define INTSTATEN		0x034
79*8b659130SJun Nie #define INTSTATEN_DEBE		BIT(22)
80*8b659130SJun Nie #define INTSTATEN_DCE		BIT(21)
81*8b659130SJun Nie #define INTSTATEN_DTOE		BIT(20)
82*8b659130SJun Nie #define INTSTATEN_CIE		BIT(19)
83*8b659130SJun Nie #define INTSTATEN_CEBE		BIT(18)
84*8b659130SJun Nie #define INTSTATEN_CCE		BIT(17)
85*8b659130SJun Nie #define INTSTATEN_CTOE		BIT(16)
86*8b659130SJun Nie #define INTSTATEN_CINT		BIT(8)
87*8b659130SJun Nie #define INTSTATEN_BRR		BIT(5)
88*8b659130SJun Nie #define INTSTATEN_BWR		BIT(4)
89*8b659130SJun Nie #define INTSTATEN_DINT		BIT(3)
90*8b659130SJun Nie #define INTSTATEN_TC		BIT(1)
91*8b659130SJun Nie #define INTSTATEN_CC		BIT(0)
92*8b659130SJun Nie #define EMMC_INTSTATEN_BITS	(INTSTATEN_CC | INTSTATEN_TC | INTSTATEN_DINT | \
93*8b659130SJun Nie 				 INTSTATEN_BWR | INTSTATEN_BRR | INTSTATEN_CINT | \
94*8b659130SJun Nie 				 INTSTATEN_CTOE | INTSTATEN_CCE | INTSTATEN_CEBE | \
95*8b659130SJun Nie 				 INTSTATEN_CIE | INTSTATEN_DTOE | INTSTATEN_DCE | \
96*8b659130SJun Nie 				 INTSTATEN_DEBE)
97*8b659130SJun Nie 
98*8b659130SJun Nie #define INTSIGEN		0x038
99*8b659130SJun Nie 
100*8b659130SJun Nie #define WATERMARKLEV		0x044
101*8b659130SJun Nie #define WMKLV_RD_MASK		0xff
102*8b659130SJun Nie #define WMKLV_WR_MASK		0x00ff0000
103*8b659130SJun Nie #define WMKLV_MASK		(WMKLV_RD_MASK | WMKLV_WR_MASK)
104*8b659130SJun Nie 
105*8b659130SJun Nie #define MIXCTRL			0x048
106*8b659130SJun Nie #define MIXCTRL_MSBSEL		BIT(5)
107*8b659130SJun Nie #define MIXCTRL_DTDSEL		BIT(4)
108*8b659130SJun Nie #define MIXCTRL_DDREN		BIT(3)
109*8b659130SJun Nie #define MIXCTRL_AC12EN		BIT(2)
110*8b659130SJun Nie #define MIXCTRL_BCEN		BIT(1)
111*8b659130SJun Nie #define MIXCTRL_DMAEN		BIT(0)
112*8b659130SJun Nie #define MIXCTRL_DATMASK		0x7f
113*8b659130SJun Nie 
114*8b659130SJun Nie #define DLLCTRL			0x060
115*8b659130SJun Nie 
116*8b659130SJun Nie #define CLKTUNECTRLSTS		0x068
117*8b659130SJun Nie 
118*8b659130SJun Nie #define VENDSPEC		0x0c0
119*8b659130SJun Nie #define VENDSPEC_RSRV1		BIT(29)
120*8b659130SJun Nie #define VENDSPEC_CARD_CLKEN	BIT(14)
121*8b659130SJun Nie #define VENDSPEC_PER_CLKEN	BIT(13)
122*8b659130SJun Nie #define VENDSPEC_AHB_CLKEN	BIT(12)
123*8b659130SJun Nie #define VENDSPEC_IPG_CLKEN	BIT(11)
124*8b659130SJun Nie #define VENDSPEC_AC12_CHKBUSY	BIT(3)
125*8b659130SJun Nie #define VENDSPEC_EXTDMA		BIT(0)
126*8b659130SJun Nie #define VENDSPEC_INIT		(VENDSPEC_RSRV1	| VENDSPEC_CARD_CLKEN | \
127*8b659130SJun Nie 				 VENDSPEC_PER_CLKEN | VENDSPEC_AHB_CLKEN | \
128*8b659130SJun Nie 				 VENDSPEC_IPG_CLKEN | VENDSPEC_AC12_CHKBUSY | \
129*8b659130SJun Nie 				 VENDSPEC_EXTDMA)
130*8b659130SJun Nie 
131*8b659130SJun Nie #define MMCBOOT			0x0c4
132*8b659130SJun Nie 
133*8b659130SJun Nie #define mmio_clrsetbits32(addr, clear, set)	mmio_write_32(addr, (mmio_read_32(addr) & ~(clear)) | (set))
134*8b659130SJun Nie #define mmio_clrbits32(addr, clear)		mmio_write_32(addr, mmio_read_32(addr) & ~(clear))
135*8b659130SJun Nie #define mmio_setbits32(addr, set)		mmio_write_32(addr, mmio_read_32(addr) | (set))
136*8b659130SJun Nie 
137*8b659130SJun Nie #endif  /* __IMX_USDHC_H__ */
138