xref: /rk3399_ARM-atf/drivers/imx/usdhc/imx_usdhc.h (revision b61379fb692205f5066e5d3b7fbbb3bdc438cae8)
18b659130SJun Nie /*
28b659130SJun Nie  * Copyright (c) 2018, ARM Limited and Contributors. All rights reserved.
326fd0688SGhennadi Procopciuc  * Copyright 2025 NXP
48b659130SJun Nie  *
58b659130SJun Nie  * SPDX-License-Identifier: BSD-3-Clause
68b659130SJun Nie  */
78b659130SJun Nie 
8c3cf06f1SAntonio Nino Diaz #ifndef IMX_USDHC_H
9c3cf06f1SAntonio Nino Diaz #define IMX_USDHC_H
108b659130SJun Nie 
1109d40e0eSAntonio Nino Diaz #include <drivers/mmc.h>
128b659130SJun Nie 
138b659130SJun Nie typedef struct imx_usdhc_params {
148b659130SJun Nie 	uintptr_t	reg_base;
153d165079SGhennadi Procopciuc 	unsigned int	clk_rate;
163d165079SGhennadi Procopciuc 	unsigned int	bus_width;
178b659130SJun Nie 	unsigned int	flags;
188b659130SJun Nie } imx_usdhc_params_t;
198b659130SJun Nie 
208b659130SJun Nie void imx_usdhc_init(imx_usdhc_params_t *params,
218b659130SJun Nie 		    struct mmc_device_info *mmc_dev_info);
228b659130SJun Nie 
238b659130SJun Nie /* iMX MMC registers definition */
2426fd0688SGhennadi Procopciuc #define DSADDR			0x000U
2526fd0688SGhennadi Procopciuc #define BLKATT			0x004U
26*b61379fbSGhennadi Procopciuc #define BLKATT_BLKCNT(x)	(((x) << 16U) & GENMASK_32(31U, 16U))
27*b61379fbSGhennadi Procopciuc #define BLKATT_BLKSIZE(x)	((x) & GENMASK_32(12U, 0U))
2826fd0688SGhennadi Procopciuc #define CMDARG			0x008U
2926fd0688SGhennadi Procopciuc #define CMDRSP0			0x010U
3026fd0688SGhennadi Procopciuc #define CMDRSP1			0x014U
3126fd0688SGhennadi Procopciuc #define CMDRSP2			0x018U
3226fd0688SGhennadi Procopciuc #define CMDRSP3			0x01cU
338b659130SJun Nie 
3426fd0688SGhennadi Procopciuc #define XFERTYPE		0x00cU
3526fd0688SGhennadi Procopciuc #define XFERTYPE_CMD(x)		(((x) & 0x3fU) << 24U)
36a59d43fcSGhennadi Procopciuc #define XFERTYPE_GET_CMD(x)	(((x) & GENMASK_32(29U, 24U)) >> 24U)
3726fd0688SGhennadi Procopciuc #define XFERTYPE_CMDTYP_ABORT	(3U << 22U)
3826fd0688SGhennadi Procopciuc #define XFERTYPE_DPSEL		BIT_32(21U)
3926fd0688SGhennadi Procopciuc #define XFERTYPE_CICEN		BIT_32(20U)
4026fd0688SGhennadi Procopciuc #define XFERTYPE_CCCEN		BIT_32(19U)
4126fd0688SGhennadi Procopciuc #define XFERTYPE_RSPTYP_136	BIT_32(16U)
4226fd0688SGhennadi Procopciuc #define XFERTYPE_RSPTYP_48	BIT_32(17U)
4326fd0688SGhennadi Procopciuc #define XFERTYPE_RSPTYP_48_BUSY	(BIT_32(16U) | BIT_32(17U))
448b659130SJun Nie 
4526fd0688SGhennadi Procopciuc #define PSTATE			0x024U
4626fd0688SGhennadi Procopciuc #define PSTATE_DAT0		BIT_32(24U)
4726fd0688SGhennadi Procopciuc #define PSTATE_DLA		BIT_32(2U)
4826fd0688SGhennadi Procopciuc #define PSTATE_CDIHB		BIT_32(1U)
4926fd0688SGhennadi Procopciuc #define PSTATE_CIHB		BIT_32(0U)
508b659130SJun Nie 
5126fd0688SGhennadi Procopciuc #define PROTCTRL		0x028U
5226fd0688SGhennadi Procopciuc #define PROTCTRL_LE		BIT_32(5U)
5326fd0688SGhennadi Procopciuc #define PROTCTRL_WIDTH_4	BIT_32(1U)
5426fd0688SGhennadi Procopciuc #define PROTCTRL_WIDTH_8	BIT_32(2U)
5526fd0688SGhennadi Procopciuc #define PROTCTRL_WIDTH_MASK	0x6U
568b659130SJun Nie 
5726fd0688SGhennadi Procopciuc #define SYSCTRL			0x02cU
5826fd0688SGhennadi Procopciuc #define SYSCTRL_RSTD		BIT_32(26U)
5926fd0688SGhennadi Procopciuc #define SYSCTRL_RSTC		BIT_32(25U)
6026fd0688SGhennadi Procopciuc #define SYSCTRL_RSTA		BIT_32(24U)
6126fd0688SGhennadi Procopciuc #define SYSCTRL_CLOCK_MASK	GENMASK_32(15U, 4U)
6226fd0688SGhennadi Procopciuc #define SYSCTRL_TIMEOUT_MASK	GENMASK_32(19U, 16U)
6326fd0688SGhennadi Procopciuc #define SYSCTRL_TIMEOUT(x)	((0xfU & (x)) << 16U)
648b659130SJun Nie 
6526fd0688SGhennadi Procopciuc #define INTSTAT			0x030U
6626fd0688SGhennadi Procopciuc #define INTSTAT_DMAE		BIT_32(28U)
6726fd0688SGhennadi Procopciuc #define INTSTAT_DEBE		BIT_32(22U)
6826fd0688SGhennadi Procopciuc #define INTSTAT_DCE		BIT_32(21U)
6926fd0688SGhennadi Procopciuc #define INTSTAT_DTOE		BIT_32(20U)
7026fd0688SGhennadi Procopciuc #define INTSTAT_CIE		BIT_32(19U)
7126fd0688SGhennadi Procopciuc #define INTSTAT_CEBE		BIT_32(18U)
7226fd0688SGhennadi Procopciuc #define INTSTAT_CCE		BIT_32(17U)
7326fd0688SGhennadi Procopciuc #define INTSTAT_DINT		BIT_32(3U)
7426fd0688SGhennadi Procopciuc #define INTSTAT_BGE		BIT_32(2U)
7526fd0688SGhennadi Procopciuc #define INTSTAT_TC		BIT_32(1U)
7626fd0688SGhennadi Procopciuc #define INTSTAT_CC		BIT_32(0U)
778b659130SJun Nie #define CMD_ERR			(INTSTAT_CIE | INTSTAT_CEBE | INTSTAT_CCE)
788b659130SJun Nie #define DATA_ERR		(INTSTAT_DMAE | INTSTAT_DEBE | INTSTAT_DCE | \
798b659130SJun Nie 				 INTSTAT_DTOE)
808b659130SJun Nie #define DATA_COMPLETE		(INTSTAT_DINT | INTSTAT_TC)
818b659130SJun Nie 
8226fd0688SGhennadi Procopciuc #define INTSTATEN		0x034U
8326fd0688SGhennadi Procopciuc #define INTSTATEN_DEBE		BIT_32(22U)
8426fd0688SGhennadi Procopciuc #define INTSTATEN_DCE		BIT_32(21U)
8526fd0688SGhennadi Procopciuc #define INTSTATEN_DTOE		BIT_32(20U)
8626fd0688SGhennadi Procopciuc #define INTSTATEN_CIE		BIT_32(19U)
8726fd0688SGhennadi Procopciuc #define INTSTATEN_CEBE		BIT_32(18U)
8826fd0688SGhennadi Procopciuc #define INTSTATEN_CCE		BIT_32(17U)
8926fd0688SGhennadi Procopciuc #define INTSTATEN_CTOE		BIT_32(16U)
9026fd0688SGhennadi Procopciuc #define INTSTATEN_CINT		BIT_32(8U)
9126fd0688SGhennadi Procopciuc #define INTSTATEN_BRR		BIT_32(5U)
9226fd0688SGhennadi Procopciuc #define INTSTATEN_BWR		BIT_32(4U)
9326fd0688SGhennadi Procopciuc #define INTSTATEN_DINT		BIT_32(3U)
9426fd0688SGhennadi Procopciuc #define INTSTATEN_TC		BIT_32(1U)
9526fd0688SGhennadi Procopciuc #define INTSTATEN_CC		BIT_32(0U)
968b659130SJun Nie #define EMMC_INTSTATEN_BITS	(INTSTATEN_CC | INTSTATEN_TC | INTSTATEN_DINT | \
978b659130SJun Nie 				 INTSTATEN_BWR | INTSTATEN_BRR | INTSTATEN_CINT | \
988b659130SJun Nie 				 INTSTATEN_CTOE | INTSTATEN_CCE | INTSTATEN_CEBE | \
998b659130SJun Nie 				 INTSTATEN_CIE | INTSTATEN_DTOE | INTSTATEN_DCE | \
1008b659130SJun Nie 				 INTSTATEN_DEBE)
1018b659130SJun Nie 
10226fd0688SGhennadi Procopciuc #define INTSIGEN		0x038U
1038b659130SJun Nie 
10426fd0688SGhennadi Procopciuc #define WATERMARKLEV		0x044U
10526fd0688SGhennadi Procopciuc #define WMKLV_RD_MASK		GENMASK_32(7U, 0U)
10626fd0688SGhennadi Procopciuc #define WMKLV_WR_MASK		GENMASK_32(23U, 16U)
1078b659130SJun Nie #define WMKLV_MASK		(WMKLV_RD_MASK | WMKLV_WR_MASK)
1088b659130SJun Nie 
10926fd0688SGhennadi Procopciuc #define MIXCTRL			0x048U
11026fd0688SGhennadi Procopciuc #define MIXCTRL_MSBSEL		BIT_32(5U)
11126fd0688SGhennadi Procopciuc #define MIXCTRL_DTDSEL		BIT_32(4U)
11226fd0688SGhennadi Procopciuc #define MIXCTRL_DDREN		BIT_32(3U)
11326fd0688SGhennadi Procopciuc #define MIXCTRL_AC12EN		BIT_32(2U)
11426fd0688SGhennadi Procopciuc #define MIXCTRL_BCEN		BIT_32(1U)
11526fd0688SGhennadi Procopciuc #define MIXCTRL_DMAEN		BIT_32(0U)
11626fd0688SGhennadi Procopciuc #define MIXCTRL_DATMASK		0x7fU
1178b659130SJun Nie 
11826fd0688SGhennadi Procopciuc #define DLLCTRL			0x060U
1198b659130SJun Nie 
12026fd0688SGhennadi Procopciuc #define CLKTUNECTRLSTS		0x068U
1218b659130SJun Nie 
12226fd0688SGhennadi Procopciuc #define VENDSPEC		0x0c0U
12326fd0688SGhennadi Procopciuc #define VENDSPEC_RSRV1		BIT_32(29U)
12426fd0688SGhennadi Procopciuc #define VENDSPEC_CARD_CLKEN	BIT_32(14U)
12526fd0688SGhennadi Procopciuc #define VENDSPEC_PER_CLKEN	BIT_32(13U)
12626fd0688SGhennadi Procopciuc #define VENDSPEC_AHB_CLKEN	BIT_32(12U)
12726fd0688SGhennadi Procopciuc #define VENDSPEC_IPG_CLKEN	BIT_32(11U)
12826fd0688SGhennadi Procopciuc #define VENDSPEC_AC12_CHKBUSY	BIT_32(3U)
12926fd0688SGhennadi Procopciuc #define VENDSPEC_EXTDMA		BIT_32(0U)
1308b659130SJun Nie #define VENDSPEC_INIT		(VENDSPEC_RSRV1	| VENDSPEC_CARD_CLKEN | \
1318b659130SJun Nie 				 VENDSPEC_PER_CLKEN | VENDSPEC_AHB_CLKEN | \
1328b659130SJun Nie 				 VENDSPEC_IPG_CLKEN | VENDSPEC_AC12_CHKBUSY | \
1338b659130SJun Nie 				 VENDSPEC_EXTDMA)
1348b659130SJun Nie 
13526fd0688SGhennadi Procopciuc #define MMCBOOT			0x0c4U
1368b659130SJun Nie 
1378b659130SJun Nie #define mmio_clrsetbits32(addr, clear, set)	mmio_write_32(addr, (mmio_read_32(addr) & ~(clear)) | (set))
1388b659130SJun Nie #define mmio_clrbits32(addr, clear)		mmio_write_32(addr, mmio_read_32(addr) & ~(clear))
1398b659130SJun Nie #define mmio_setbits32(addr, set)		mmio_write_32(addr, mmio_read_32(addr) | (set))
1408b659130SJun Nie 
141c3cf06f1SAntonio Nino Diaz #endif /* IMX_USDHC_H */
142