xref: /OK3568_Linux_fs/u-boot/drivers/mmc/sh_mmcif.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * MMCIF driver.
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * Copyright (C)  2011 Renesas Solutions Corp.
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  * SPDX-License-Identifier:	GPL-2.0
7*4882a593Smuzhiyun  */
8*4882a593Smuzhiyun 
9*4882a593Smuzhiyun #ifndef _SH_MMCIF_H_
10*4882a593Smuzhiyun #define _SH_MMCIF_H_
11*4882a593Smuzhiyun 
12*4882a593Smuzhiyun struct sh_mmcif_regs {
13*4882a593Smuzhiyun 	unsigned long ce_cmd_set;
14*4882a593Smuzhiyun 	unsigned long reserved;
15*4882a593Smuzhiyun 	unsigned long ce_arg;
16*4882a593Smuzhiyun 	unsigned long ce_arg_cmd12;
17*4882a593Smuzhiyun 	unsigned long ce_cmd_ctrl;
18*4882a593Smuzhiyun 	unsigned long ce_block_set;
19*4882a593Smuzhiyun 	unsigned long ce_clk_ctrl;
20*4882a593Smuzhiyun 	unsigned long ce_buf_acc;
21*4882a593Smuzhiyun 	unsigned long ce_resp3;
22*4882a593Smuzhiyun 	unsigned long ce_resp2;
23*4882a593Smuzhiyun 	unsigned long ce_resp1;
24*4882a593Smuzhiyun 	unsigned long ce_resp0;
25*4882a593Smuzhiyun 	unsigned long ce_resp_cmd12;
26*4882a593Smuzhiyun 	unsigned long ce_data;
27*4882a593Smuzhiyun 	unsigned long reserved2[2];
28*4882a593Smuzhiyun 	unsigned long ce_int;
29*4882a593Smuzhiyun 	unsigned long ce_int_mask;
30*4882a593Smuzhiyun 	unsigned long ce_host_sts1;
31*4882a593Smuzhiyun 	unsigned long ce_host_sts2;
32*4882a593Smuzhiyun 	unsigned long reserved3[11];
33*4882a593Smuzhiyun 	unsigned long ce_version;
34*4882a593Smuzhiyun };
35*4882a593Smuzhiyun 
36*4882a593Smuzhiyun /* CE_CMD_SET */
37*4882a593Smuzhiyun #define CMD_MASK		0x3f000000
38*4882a593Smuzhiyun #define CMD_SET_RTYP_NO		((0 << 23) | (0 << 22))
39*4882a593Smuzhiyun /* R1/R1b/R3/R4/R5 */
40*4882a593Smuzhiyun #define CMD_SET_RTYP_6B		((0 << 23) | (1 << 22))
41*4882a593Smuzhiyun /* R2 */
42*4882a593Smuzhiyun #define CMD_SET_RTYP_17B	((1 << 23) | (0 << 22))
43*4882a593Smuzhiyun /* R1b */
44*4882a593Smuzhiyun #define CMD_SET_RBSY		(1 << 21)
45*4882a593Smuzhiyun #define CMD_SET_CCSEN		(1 << 20)
46*4882a593Smuzhiyun /* 1: on data, 0: no data */
47*4882a593Smuzhiyun #define CMD_SET_WDAT		(1 << 19)
48*4882a593Smuzhiyun /* 1: write to card, 0: read from card */
49*4882a593Smuzhiyun #define CMD_SET_DWEN		(1 << 18)
50*4882a593Smuzhiyun /* 1: multi block trans, 0: single */
51*4882a593Smuzhiyun #define CMD_SET_CMLTE		(1 << 17)
52*4882a593Smuzhiyun /* 1: CMD12 auto issue */
53*4882a593Smuzhiyun #define CMD_SET_CMD12EN		(1 << 16)
54*4882a593Smuzhiyun /* index check */
55*4882a593Smuzhiyun #define CMD_SET_RIDXC_INDEX	((0 << 15) | (0 << 14))
56*4882a593Smuzhiyun /* check bits check */
57*4882a593Smuzhiyun #define CMD_SET_RIDXC_BITS	((0 << 15) | (1 << 14))
58*4882a593Smuzhiyun /* no check */
59*4882a593Smuzhiyun #define CMD_SET_RIDXC_NO	((1 << 15) | (0 << 14))
60*4882a593Smuzhiyun /* 1: CRC7 check*/
61*4882a593Smuzhiyun #define CMD_SET_CRC7C		((0 << 13) | (0 << 12))
62*4882a593Smuzhiyun /* 1: check bits check*/
63*4882a593Smuzhiyun #define CMD_SET_CRC7C_BITS	((0 << 13) | (1 << 12))
64*4882a593Smuzhiyun /* 1: internal CRC7 check*/
65*4882a593Smuzhiyun #define CMD_SET_CRC7C_INTERNAL	((1 << 13) | (0 << 12))
66*4882a593Smuzhiyun /* 1: CRC16 check*/
67*4882a593Smuzhiyun #define CMD_SET_CRC16C		(1 << 10)
68*4882a593Smuzhiyun /* 1: not receive CRC status */
69*4882a593Smuzhiyun #define CMD_SET_CRCSTE		(1 << 8)
70*4882a593Smuzhiyun /* 1: tran mission bit "Low" */
71*4882a593Smuzhiyun #define CMD_SET_TBIT		(1 << 7)
72*4882a593Smuzhiyun /* 1: open/drain */
73*4882a593Smuzhiyun #define CMD_SET_OPDM		(1 << 6)
74*4882a593Smuzhiyun #define CMD_SET_CCSH		(1 << 5)
75*4882a593Smuzhiyun /* 1bit */
76*4882a593Smuzhiyun #define CMD_SET_DATW_1		((0 << 1) | (0 << 0))
77*4882a593Smuzhiyun /* 4bit */
78*4882a593Smuzhiyun #define CMD_SET_DATW_4		((0 << 1) | (1 << 0))
79*4882a593Smuzhiyun /* 8bit */
80*4882a593Smuzhiyun #define CMD_SET_DATW_8		((1 << 1) | (0 << 0))
81*4882a593Smuzhiyun 
82*4882a593Smuzhiyun /* CE_CMD_CTRL */
83*4882a593Smuzhiyun #define CMD_CTRL_BREAK		(1 << 0)
84*4882a593Smuzhiyun 
85*4882a593Smuzhiyun /* CE_BLOCK_SET */
86*4882a593Smuzhiyun #define BLOCK_SIZE_MASK		0x0000ffff
87*4882a593Smuzhiyun 
88*4882a593Smuzhiyun /* CE_CLK_CTRL */
89*4882a593Smuzhiyun #define CLK_ENABLE		(1 << 24)
90*4882a593Smuzhiyun #define CLK_CLEAR		((1 << 19) | (1 << 18) | (1 << 17) | (1 << 16))
91*4882a593Smuzhiyun #define CLK_PCLK		((1 << 19) | (1 << 18) | (1 << 17) | (1 << 16))
92*4882a593Smuzhiyun /* respons timeout */
93*4882a593Smuzhiyun #define SRSPTO_256		((1 << 13) | (0 << 12))
94*4882a593Smuzhiyun /* respons busy timeout */
95*4882a593Smuzhiyun #define SRBSYTO_29		((1 << 11) | (1 << 10) | (1 << 9) | (1 << 8))
96*4882a593Smuzhiyun /* read/write timeout */
97*4882a593Smuzhiyun #define SRWDTO_29		((1 << 7) | (1 << 6) | (1 << 5) | (1 << 4))
98*4882a593Smuzhiyun /* ccs timeout */
99*4882a593Smuzhiyun #define SCCSTO_29		((1 << 3) | (1 << 2) | (1 << 1) | (1 << 0))
100*4882a593Smuzhiyun 
101*4882a593Smuzhiyun /* CE_BUF_ACC */
102*4882a593Smuzhiyun #define BUF_ACC_DMAWEN		(1 << 25)
103*4882a593Smuzhiyun #define BUF_ACC_DMAREN		(1 << 24)
104*4882a593Smuzhiyun #define BUF_ACC_BUSW_32		(0 << 17)
105*4882a593Smuzhiyun #define BUF_ACC_BUSW_16		(1 << 17)
106*4882a593Smuzhiyun #define BUF_ACC_ATYP		(1 << 16)
107*4882a593Smuzhiyun 
108*4882a593Smuzhiyun /* CE_INT */
109*4882a593Smuzhiyun #define INT_CCSDE		(1 << 29)
110*4882a593Smuzhiyun #define INT_CMD12DRE		(1 << 26)
111*4882a593Smuzhiyun #define INT_CMD12RBE		(1 << 25)
112*4882a593Smuzhiyun #define INT_CMD12CRE		(1 << 24)
113*4882a593Smuzhiyun #define INT_DTRANE		(1 << 23)
114*4882a593Smuzhiyun #define INT_BUFRE		(1 << 22)
115*4882a593Smuzhiyun #define INT_BUFWEN		(1 << 21)
116*4882a593Smuzhiyun #define INT_BUFREN		(1 << 20)
117*4882a593Smuzhiyun #define INT_CCSRCV		(1 << 19)
118*4882a593Smuzhiyun #define INT_RBSYE		(1 << 17)
119*4882a593Smuzhiyun #define INT_CRSPE		(1 << 16)
120*4882a593Smuzhiyun #define INT_CMDVIO		(1 << 15)
121*4882a593Smuzhiyun #define INT_BUFVIO		(1 << 14)
122*4882a593Smuzhiyun #define INT_WDATERR		(1 << 11)
123*4882a593Smuzhiyun #define INT_RDATERR		(1 << 10)
124*4882a593Smuzhiyun #define INT_RIDXERR		(1 << 9)
125*4882a593Smuzhiyun #define INT_RSPERR		(1 << 8)
126*4882a593Smuzhiyun #define INT_CCSTO		(1 << 5)
127*4882a593Smuzhiyun #define INT_CRCSTO		(1 << 4)
128*4882a593Smuzhiyun #define INT_WDATTO		(1 << 3)
129*4882a593Smuzhiyun #define INT_RDATTO		(1 << 2)
130*4882a593Smuzhiyun #define INT_RBSYTO		(1 << 1)
131*4882a593Smuzhiyun #define INT_RSPTO		(1 << 0)
132*4882a593Smuzhiyun #define INT_ERR_STS		(INT_CMDVIO | INT_BUFVIO | INT_WDATERR |  \
133*4882a593Smuzhiyun 				 INT_RDATERR | INT_RIDXERR | INT_RSPERR | \
134*4882a593Smuzhiyun 				 INT_CCSTO | INT_CRCSTO | INT_WDATTO |	  \
135*4882a593Smuzhiyun 				 INT_RDATTO | INT_RBSYTO | INT_RSPTO)
136*4882a593Smuzhiyun #define INT_START_MAGIC		0xD80430C0
137*4882a593Smuzhiyun 
138*4882a593Smuzhiyun /* CE_INT_MASK */
139*4882a593Smuzhiyun #define MASK_ALL		0x00000000
140*4882a593Smuzhiyun #define MASK_MCCSDE		(1 << 29)
141*4882a593Smuzhiyun #define MASK_MCMD12DRE		(1 << 26)
142*4882a593Smuzhiyun #define MASK_MCMD12RBE		(1 << 25)
143*4882a593Smuzhiyun #define MASK_MCMD12CRE		(1 << 24)
144*4882a593Smuzhiyun #define MASK_MDTRANE		(1 << 23)
145*4882a593Smuzhiyun #define MASK_MBUFRE		(1 << 22)
146*4882a593Smuzhiyun #define MASK_MBUFWEN		(1 << 21)
147*4882a593Smuzhiyun #define MASK_MBUFREN		(1 << 20)
148*4882a593Smuzhiyun #define MASK_MCCSRCV		(1 << 19)
149*4882a593Smuzhiyun #define MASK_MRBSYE		(1 << 17)
150*4882a593Smuzhiyun #define MASK_MCRSPE		(1 << 16)
151*4882a593Smuzhiyun #define MASK_MCMDVIO		(1 << 15)
152*4882a593Smuzhiyun #define MASK_MBUFVIO		(1 << 14)
153*4882a593Smuzhiyun #define MASK_MWDATERR		(1 << 11)
154*4882a593Smuzhiyun #define MASK_MRDATERR		(1 << 10)
155*4882a593Smuzhiyun #define MASK_MRIDXERR		(1 << 9)
156*4882a593Smuzhiyun #define MASK_MRSPERR		(1 << 8)
157*4882a593Smuzhiyun #define MASK_MCCSTO		(1 << 5)
158*4882a593Smuzhiyun #define MASK_MCRCSTO		(1 << 4)
159*4882a593Smuzhiyun #define MASK_MWDATTO		(1 << 3)
160*4882a593Smuzhiyun #define MASK_MRDATTO		(1 << 2)
161*4882a593Smuzhiyun #define MASK_MRBSYTO		(1 << 1)
162*4882a593Smuzhiyun #define MASK_MRSPTO		(1 << 0)
163*4882a593Smuzhiyun 
164*4882a593Smuzhiyun /* CE_HOST_STS1 */
165*4882a593Smuzhiyun #define STS1_CMDSEQ		(1 << 31)
166*4882a593Smuzhiyun 
167*4882a593Smuzhiyun /* CE_HOST_STS2 */
168*4882a593Smuzhiyun #define STS2_CRCSTE		(1 << 31)
169*4882a593Smuzhiyun #define STS2_CRC16E		(1 << 30)
170*4882a593Smuzhiyun #define STS2_AC12CRCE		(1 << 29)
171*4882a593Smuzhiyun #define STS2_RSPCRC7E		(1 << 28)
172*4882a593Smuzhiyun #define STS2_CRCSTEBE		(1 << 27)
173*4882a593Smuzhiyun #define STS2_RDATEBE		(1 << 26)
174*4882a593Smuzhiyun #define STS2_AC12REBE		(1 << 25)
175*4882a593Smuzhiyun #define STS2_RSPEBE		(1 << 24)
176*4882a593Smuzhiyun #define STS2_AC12IDXE		(1 << 23)
177*4882a593Smuzhiyun #define STS2_RSPIDXE		(1 << 22)
178*4882a593Smuzhiyun #define STS2_CCSTO		(1 << 15)
179*4882a593Smuzhiyun #define STS2_RDATTO		(1 << 14)
180*4882a593Smuzhiyun #define STS2_DATBSYTO		(1 << 13)
181*4882a593Smuzhiyun #define STS2_CRCSTTO		(1 << 12)
182*4882a593Smuzhiyun #define STS2_AC12BSYTO		(1 << 11)
183*4882a593Smuzhiyun #define STS2_RSPBSYTO		(1 << 10)
184*4882a593Smuzhiyun #define STS2_AC12RSPTO		(1 << 9)
185*4882a593Smuzhiyun #define STS2_RSPTO		(1 << 8)
186*4882a593Smuzhiyun 
187*4882a593Smuzhiyun #define STS2_CRC_ERR		(STS2_CRCSTE | STS2_CRC16E |		\
188*4882a593Smuzhiyun 				 STS2_AC12CRCE | STS2_RSPCRC7E | STS2_CRCSTEBE)
189*4882a593Smuzhiyun #define STS2_TIMEOUT_ERR	(STS2_CCSTO | STS2_RDATTO |		\
190*4882a593Smuzhiyun 				 STS2_DATBSYTO | STS2_CRCSTTO |		\
191*4882a593Smuzhiyun 				 STS2_AC12BSYTO | STS2_RSPBSYTO |	\
192*4882a593Smuzhiyun 				 STS2_AC12RSPTO | STS2_RSPTO)
193*4882a593Smuzhiyun 
194*4882a593Smuzhiyun /* CE_VERSION */
195*4882a593Smuzhiyun #define SOFT_RST_ON		(1 << 31)
196*4882a593Smuzhiyun #define SOFT_RST_OFF		(0 << 31)
197*4882a593Smuzhiyun 
198*4882a593Smuzhiyun #define CLKDEV_EMMC_DATA	52000000	/* 52MHz */
199*4882a593Smuzhiyun #ifdef CONFIG_ARCH_RMOBILE
200*4882a593Smuzhiyun #define MMC_CLK_DIV_MIN(clk)	(clk / (1 << 9))
201*4882a593Smuzhiyun #define MMC_CLK_DIV_MAX(clk)	(clk / (1 << 1))
202*4882a593Smuzhiyun #else
203*4882a593Smuzhiyun #define MMC_CLK_DIV_MIN(clk)	(clk / (1 << 8))
204*4882a593Smuzhiyun #define MMC_CLK_DIV_MAX(clk)	CLKDEV_EMMC_DATA
205*4882a593Smuzhiyun #endif
206*4882a593Smuzhiyun 
207*4882a593Smuzhiyun #define MMC_BUS_WIDTH_1		0
208*4882a593Smuzhiyun #define MMC_BUS_WIDTH_4		2
209*4882a593Smuzhiyun #define MMC_BUS_WIDTH_8		3
210*4882a593Smuzhiyun 
211*4882a593Smuzhiyun struct sh_mmcif_host {
212*4882a593Smuzhiyun 	struct mmc_data		*data;
213*4882a593Smuzhiyun 	struct sh_mmcif_regs	*regs;
214*4882a593Smuzhiyun 	unsigned int		clk;
215*4882a593Smuzhiyun 	int			bus_width;
216*4882a593Smuzhiyun 	u16			wait_int;
217*4882a593Smuzhiyun 	u16			sd_error;
218*4882a593Smuzhiyun 	u8			last_cmd;
219*4882a593Smuzhiyun };
220*4882a593Smuzhiyun 
sh_mmcif_read(unsigned long * reg)221*4882a593Smuzhiyun static inline u32 sh_mmcif_read(unsigned long *reg)
222*4882a593Smuzhiyun {
223*4882a593Smuzhiyun 	return readl(reg);
224*4882a593Smuzhiyun }
225*4882a593Smuzhiyun 
sh_mmcif_write(u32 val,unsigned long * reg)226*4882a593Smuzhiyun static inline void sh_mmcif_write(u32 val, unsigned long *reg)
227*4882a593Smuzhiyun {
228*4882a593Smuzhiyun 	writel(val, reg);
229*4882a593Smuzhiyun }
230*4882a593Smuzhiyun 
sh_mmcif_bitset(u32 val,unsigned long * reg)231*4882a593Smuzhiyun static inline void sh_mmcif_bitset(u32 val, unsigned long *reg)
232*4882a593Smuzhiyun {
233*4882a593Smuzhiyun 	sh_mmcif_write(val | sh_mmcif_read(reg), reg);
234*4882a593Smuzhiyun }
235*4882a593Smuzhiyun 
sh_mmcif_bitclr(u32 val,unsigned long * reg)236*4882a593Smuzhiyun static inline void sh_mmcif_bitclr(u32 val, unsigned long *reg)
237*4882a593Smuzhiyun {
238*4882a593Smuzhiyun 	sh_mmcif_write(~val & sh_mmcif_read(reg), reg);
239*4882a593Smuzhiyun }
240*4882a593Smuzhiyun 
241*4882a593Smuzhiyun #endif /* _SH_MMCIF_H_ */
242