xref: /OK3568_Linux_fs/u-boot/arch/arm/mach-rmobile/include/mach/sh_sdhi.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * drivers/mmc/sh-sdhi.h
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * SD/MMC driver for Renesas rmobile ARM SoCs
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  * Copyright (C) 2013-2017 Renesas Electronics Corporation
7*4882a593Smuzhiyun  * Copyright (C) 2008-2009 Renesas Solutions Corp.
8*4882a593Smuzhiyun  *
9*4882a593Smuzhiyun  * SPDX-License-Identifier:	GPL-2.0
10*4882a593Smuzhiyun  */
11*4882a593Smuzhiyun 
12*4882a593Smuzhiyun #ifndef _SH_SDHI_H
13*4882a593Smuzhiyun #define _SH_SDHI_H
14*4882a593Smuzhiyun 
15*4882a593Smuzhiyun #define SDHI_CMD			(0x0000 >> 1)
16*4882a593Smuzhiyun #define SDHI_PORTSEL			(0x0004 >> 1)
17*4882a593Smuzhiyun #define SDHI_ARG0			(0x0008 >> 1)
18*4882a593Smuzhiyun #define SDHI_ARG1			(0x000C >> 1)
19*4882a593Smuzhiyun #define SDHI_STOP			(0x0010 >> 1)
20*4882a593Smuzhiyun #define SDHI_SECCNT			(0x0014 >> 1)
21*4882a593Smuzhiyun #define SDHI_RSP00			(0x0018 >> 1)
22*4882a593Smuzhiyun #define SDHI_RSP01			(0x001C >> 1)
23*4882a593Smuzhiyun #define SDHI_RSP02			(0x0020 >> 1)
24*4882a593Smuzhiyun #define SDHI_RSP03			(0x0024 >> 1)
25*4882a593Smuzhiyun #define SDHI_RSP04			(0x0028 >> 1)
26*4882a593Smuzhiyun #define SDHI_RSP05			(0x002C >> 1)
27*4882a593Smuzhiyun #define SDHI_RSP06			(0x0030 >> 1)
28*4882a593Smuzhiyun #define SDHI_RSP07			(0x0034 >> 1)
29*4882a593Smuzhiyun #define SDHI_INFO1			(0x0038 >> 1)
30*4882a593Smuzhiyun #define SDHI_INFO2			(0x003C >> 1)
31*4882a593Smuzhiyun #define SDHI_INFO1_MASK			(0x0040 >> 1)
32*4882a593Smuzhiyun #define SDHI_INFO2_MASK			(0x0044 >> 1)
33*4882a593Smuzhiyun #define SDHI_CLK_CTRL			(0x0048 >> 1)
34*4882a593Smuzhiyun #define SDHI_SIZE			(0x004C >> 1)
35*4882a593Smuzhiyun #define SDHI_OPTION			(0x0050 >> 1)
36*4882a593Smuzhiyun #define SDHI_ERR_STS1			(0x0058 >> 1)
37*4882a593Smuzhiyun #define SDHI_ERR_STS2			(0x005C >> 1)
38*4882a593Smuzhiyun #define SDHI_BUF0			(0x0060 >> 1)
39*4882a593Smuzhiyun #define SDHI_SDIO_MODE			(0x0068 >> 1)
40*4882a593Smuzhiyun #define SDHI_SDIO_INFO1			(0x006C >> 1)
41*4882a593Smuzhiyun #define SDHI_SDIO_INFO1_MASK		(0x0070 >> 1)
42*4882a593Smuzhiyun #define SDHI_CC_EXT_MODE		(0x01B0 >> 1)
43*4882a593Smuzhiyun #define SDHI_SOFT_RST			(0x01C0 >> 1)
44*4882a593Smuzhiyun #define SDHI_VERSION			(0x01C4 >> 1)
45*4882a593Smuzhiyun #define SDHI_HOST_MODE			(0x01C8 >> 1)
46*4882a593Smuzhiyun #define SDHI_SDIF_MODE			(0x01CC >> 1)
47*4882a593Smuzhiyun #define SDHI_EXT_SWAP			(0x01E0 >> 1)
48*4882a593Smuzhiyun #define SDHI_SD_DMACR			(0x0324 >> 1)
49*4882a593Smuzhiyun 
50*4882a593Smuzhiyun /* SDHI CMD VALUE */
51*4882a593Smuzhiyun #define CMD_MASK			0x0000ffff
52*4882a593Smuzhiyun 
53*4882a593Smuzhiyun /* SDHI_PORTSEL */
54*4882a593Smuzhiyun #define USE_1PORT			(1 << 8) /* 1 port */
55*4882a593Smuzhiyun 
56*4882a593Smuzhiyun /* SDHI_ARG */
57*4882a593Smuzhiyun #define ARG0_MASK			0x0000ffff
58*4882a593Smuzhiyun #define ARG1_MASK			0x0000ffff
59*4882a593Smuzhiyun 
60*4882a593Smuzhiyun /* SDHI_STOP */
61*4882a593Smuzhiyun #define STOP_SEC_ENABLE			(1 << 8)
62*4882a593Smuzhiyun 
63*4882a593Smuzhiyun /* SDHI_INFO1 */
64*4882a593Smuzhiyun #define INFO1_RESP_END			(1 << 0)
65*4882a593Smuzhiyun #define INFO1_ACCESS_END		(1 << 2)
66*4882a593Smuzhiyun #define INFO1_CARD_RE			(1 << 3)
67*4882a593Smuzhiyun #define INFO1_CARD_IN			(1 << 4)
68*4882a593Smuzhiyun #define INFO1_ISD0CD			(1 << 5)
69*4882a593Smuzhiyun #define INFO1_WRITE_PRO			(1 << 7)
70*4882a593Smuzhiyun #define INFO1_DATA3_CARD_RE		(1 << 8)
71*4882a593Smuzhiyun #define INFO1_DATA3_CARD_IN		(1 << 9)
72*4882a593Smuzhiyun #define INFO1_DATA3			(1 << 10)
73*4882a593Smuzhiyun 
74*4882a593Smuzhiyun /* SDHI_INFO2 */
75*4882a593Smuzhiyun #define INFO2_CMD_ERROR			(1 << 0)
76*4882a593Smuzhiyun #define INFO2_CRC_ERROR			(1 << 1)
77*4882a593Smuzhiyun #define INFO2_END_ERROR			(1 << 2)
78*4882a593Smuzhiyun #define INFO2_TIMEOUT			(1 << 3)
79*4882a593Smuzhiyun #define INFO2_BUF_ILL_WRITE		(1 << 4)
80*4882a593Smuzhiyun #define INFO2_BUF_ILL_READ		(1 << 5)
81*4882a593Smuzhiyun #define INFO2_RESP_TIMEOUT		(1 << 6)
82*4882a593Smuzhiyun #define INFO2_SDDAT0			(1 << 7)
83*4882a593Smuzhiyun #define INFO2_BRE_ENABLE		(1 << 8)
84*4882a593Smuzhiyun #define INFO2_BWE_ENABLE		(1 << 9)
85*4882a593Smuzhiyun #define INFO2_CBUSY			(1 << 14)
86*4882a593Smuzhiyun #define INFO2_ILA			(1 << 15)
87*4882a593Smuzhiyun #define INFO2_ALL_ERR			(0x807f)
88*4882a593Smuzhiyun 
89*4882a593Smuzhiyun /* SDHI_INFO1_MASK */
90*4882a593Smuzhiyun #define INFO1M_RESP_END			(1 << 0)
91*4882a593Smuzhiyun #define INFO1M_ACCESS_END		(1 << 2)
92*4882a593Smuzhiyun #define INFO1M_CARD_RE			(1 << 3)
93*4882a593Smuzhiyun #define INFO1M_CARD_IN			(1 << 4)
94*4882a593Smuzhiyun #define INFO1M_DATA3_CARD_RE		(1 << 8)
95*4882a593Smuzhiyun #define INFO1M_DATA3_CARD_IN		(1 << 9)
96*4882a593Smuzhiyun #define INFO1M_ALL			(0xffff)
97*4882a593Smuzhiyun #define INFO1M_SET			(INFO1M_RESP_END |	\
98*4882a593Smuzhiyun 					INFO1M_ACCESS_END |	\
99*4882a593Smuzhiyun 					INFO1M_DATA3_CARD_RE |	\
100*4882a593Smuzhiyun 					INFO1M_DATA3_CARD_IN)
101*4882a593Smuzhiyun 
102*4882a593Smuzhiyun /* SDHI_INFO2_MASK */
103*4882a593Smuzhiyun #define INFO2M_CMD_ERROR		(1 << 0)
104*4882a593Smuzhiyun #define INFO2M_CRC_ERROR		(1 << 1)
105*4882a593Smuzhiyun #define INFO2M_END_ERROR		(1 << 2)
106*4882a593Smuzhiyun #define INFO2M_TIMEOUT			(1 << 3)
107*4882a593Smuzhiyun #define INFO2M_BUF_ILL_WRITE		(1 << 4)
108*4882a593Smuzhiyun #define INFO2M_BUF_ILL_READ		(1 << 5)
109*4882a593Smuzhiyun #define INFO2M_RESP_TIMEOUT		(1 << 6)
110*4882a593Smuzhiyun #define INFO2M_BRE_ENABLE		(1 << 8)
111*4882a593Smuzhiyun #define INFO2M_BWE_ENABLE		(1 << 9)
112*4882a593Smuzhiyun #define INFO2M_ILA			(1 << 15)
113*4882a593Smuzhiyun #define INFO2M_ALL			(0xffff)
114*4882a593Smuzhiyun #define INFO2M_ALL_ERR			(0x807f)
115*4882a593Smuzhiyun 
116*4882a593Smuzhiyun /* SDHI_CLK_CTRL */
117*4882a593Smuzhiyun #define CLK_ENABLE			(1 << 8)
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun /* SDHI_OPTION */
120*4882a593Smuzhiyun #define OPT_BUS_WIDTH_M			(5 << 13)	/* 101b (15-13bit) */
121*4882a593Smuzhiyun #define OPT_BUS_WIDTH_1			(4 << 13)	/* bus width = 1 bit */
122*4882a593Smuzhiyun #define OPT_BUS_WIDTH_4			(0 << 13)	/* bus width = 4 bit */
123*4882a593Smuzhiyun #define OPT_BUS_WIDTH_8			(1 << 13)	/* bus width = 8 bit */
124*4882a593Smuzhiyun 
125*4882a593Smuzhiyun /* SDHI_ERR_STS1 */
126*4882a593Smuzhiyun #define ERR_STS1_CRC_ERROR		((1 << 11) | (1 << 10) | (1 << 9) | \
127*4882a593Smuzhiyun 					(1 << 8) | (1 << 5))
128*4882a593Smuzhiyun #define ERR_STS1_CMD_ERROR		((1 << 4) | (1 << 3) | (1 << 2) | \
129*4882a593Smuzhiyun 					(1 << 1) | (1 << 0))
130*4882a593Smuzhiyun 
131*4882a593Smuzhiyun /* SDHI_ERR_STS2 */
132*4882a593Smuzhiyun #define ERR_STS2_RES_TIMEOUT		(1 << 0)
133*4882a593Smuzhiyun #define ERR_STS2_RES_STOP_TIMEOUT	((1 << 0) | (1 << 1))
134*4882a593Smuzhiyun #define ERR_STS2_SYS_ERROR		((1 << 6) | (1 << 5) | (1 << 4) | \
135*4882a593Smuzhiyun 					(1 << 3) | (1 << 2) | (1 << 1) | \
136*4882a593Smuzhiyun 					(1 << 0))
137*4882a593Smuzhiyun 
138*4882a593Smuzhiyun /* SDHI_SDIO_MODE */
139*4882a593Smuzhiyun #define SDIO_MODE_ON			(1 << 0)
140*4882a593Smuzhiyun #define SDIO_MODE_OFF			(0 << 0)
141*4882a593Smuzhiyun 
142*4882a593Smuzhiyun /* SDHI_SDIO_INFO1 */
143*4882a593Smuzhiyun #define SDIO_INFO1_IOIRQ		(1 << 0)
144*4882a593Smuzhiyun #define SDIO_INFO1_EXPUB52		(1 << 14)
145*4882a593Smuzhiyun #define SDIO_INFO1_EXWT			(1 << 15)
146*4882a593Smuzhiyun 
147*4882a593Smuzhiyun /* SDHI_SDIO_INFO1_MASK */
148*4882a593Smuzhiyun #define SDIO_INFO1M_CLEAR		((1 << 1) | (1 << 2))
149*4882a593Smuzhiyun #define SDIO_INFO1M_ON			((1 << 15) | (1 << 14) | (1 << 2) | \
150*4882a593Smuzhiyun 					 (1 << 1) | (1 << 0))
151*4882a593Smuzhiyun 
152*4882a593Smuzhiyun /* SDHI_EXT_SWAP */
153*4882a593Smuzhiyun #define SET_SWAP			((1 << 6) | (1 << 7))	/* SWAP */
154*4882a593Smuzhiyun 
155*4882a593Smuzhiyun /* SDHI_SOFT_RST */
156*4882a593Smuzhiyun #define SOFT_RST_ON			(0 << 0)
157*4882a593Smuzhiyun #define SOFT_RST_OFF			(1 << 0)
158*4882a593Smuzhiyun 
159*4882a593Smuzhiyun #define	CLKDEV_SD_DATA			25000000	/* 25 MHz */
160*4882a593Smuzhiyun #define CLKDEV_HS_DATA			50000000	/* 50 MHz */
161*4882a593Smuzhiyun #define CLKDEV_MMC_DATA			20000000	/* 20MHz */
162*4882a593Smuzhiyun #define	CLKDEV_INIT			400000		/* 100 - 400 KHz */
163*4882a593Smuzhiyun 
164*4882a593Smuzhiyun /* For quirk */
165*4882a593Smuzhiyun #define SH_SDHI_QUIRK_16BIT_BUF		BIT(0)
166*4882a593Smuzhiyun #define SH_SDHI_QUIRK_64BIT_BUF		BIT(1)
167*4882a593Smuzhiyun 
168*4882a593Smuzhiyun int sh_sdhi_init(unsigned long addr, int ch, unsigned long quirks);
169*4882a593Smuzhiyun 
170*4882a593Smuzhiyun #endif /* _SH_SDHI_H */
171