xref: /rk3399_rockchip-uboot/arch/arm/include/asm/arch-rockchip/dram_spec_timing.h (revision 5290223f29d613f4d0585be630201da98f1a15cf)
178efceb6SYouMin Chen /* SPDX-License-Identifier:     GPL-2.0+ */
278efceb6SYouMin Chen /*
378efceb6SYouMin Chen  * Copyright (C) 2020 Rockchip Electronics Co., Ltd
478efceb6SYouMin Chen  */
578efceb6SYouMin Chen 
678efceb6SYouMin Chen #ifndef __ROCKCHIP_DRAM_SPEC_TIMING_H__
778efceb6SYouMin Chen #define __ROCKCHIP_DRAM_SPEC_TIMING_H__
878efceb6SYouMin Chen 
978efceb6SYouMin Chen enum ddr3_speed_rate {
1078efceb6SYouMin Chen 	/* 5-5-5 */
1178efceb6SYouMin Chen 	DDR3_800D = 0,
1278efceb6SYouMin Chen 	/* 6-6-6 */
1378efceb6SYouMin Chen 	DDR3_800E = 1,
1478efceb6SYouMin Chen 	/* 6-6-6 */
1578efceb6SYouMin Chen 	DDR3_1066E = 2,
1678efceb6SYouMin Chen 	/* 7-7-7 */
1778efceb6SYouMin Chen 	DDR3_1066F = 3,
1878efceb6SYouMin Chen 	/* 8-8-8 */
1978efceb6SYouMin Chen 	DDR3_1066G = 4,
2078efceb6SYouMin Chen 	/* 7-7-7 */
2178efceb6SYouMin Chen 	DDR3_1333F = 5,
2278efceb6SYouMin Chen 	/* 8-8-8 */
2378efceb6SYouMin Chen 	DDR3_1333G = 6,
2478efceb6SYouMin Chen 	/* 9-9-9 */
2578efceb6SYouMin Chen 	DDR3_1333H = 7,
2678efceb6SYouMin Chen 	/* 10-10-10 */
2778efceb6SYouMin Chen 	DDR3_1333J = 8,
2878efceb6SYouMin Chen 	/* 8-8-8 */
2978efceb6SYouMin Chen 	DDR3_1600G = 9,
3078efceb6SYouMin Chen 	/* 9-9-9 */
3178efceb6SYouMin Chen 	DDR3_1600H = 10,
3278efceb6SYouMin Chen 	/* 10-10-10 */
3378efceb6SYouMin Chen 	DDR3_1600J = 11,
3478efceb6SYouMin Chen 	/* 11-11-11 */
3578efceb6SYouMin Chen 	DDR3_1600K = 12,
3678efceb6SYouMin Chen 	/* 10-10-10 */
3778efceb6SYouMin Chen 	DDR3_1866J = 13,
3878efceb6SYouMin Chen 	/* 11-11-11 */
3978efceb6SYouMin Chen 	DDR3_1866K = 14,
4078efceb6SYouMin Chen 	/* 12-12-12 */
4178efceb6SYouMin Chen 	DDR3_1866L = 15,
4278efceb6SYouMin Chen 	/* 13-13-13 */
4378efceb6SYouMin Chen 	DDR3_1866M = 16,
4478efceb6SYouMin Chen 	/* 11-11-11 */
4578efceb6SYouMin Chen 	DDR3_2133K = 17,
4678efceb6SYouMin Chen 	/* 12-12-12 */
4778efceb6SYouMin Chen 	DDR3_2133L = 18,
4878efceb6SYouMin Chen 	/* 13-13-13 */
4978efceb6SYouMin Chen 	DDR3_2133M = 19,
5078efceb6SYouMin Chen 	/* 14-14-14 */
5178efceb6SYouMin Chen 	DDR3_2133N = 20,
5278efceb6SYouMin Chen 	DDR3_DEFAULT = 21,
5378efceb6SYouMin Chen };
5478efceb6SYouMin Chen 
5578efceb6SYouMin Chen enum ddr4_speed_rate {
5678efceb6SYouMin Chen 	/* DDR4_1600J (10-10-10) */
5778efceb6SYouMin Chen 	DDR4_1600J = 0,
5878efceb6SYouMin Chen 	/* DDR4_1600K (11-11-11) */
5978efceb6SYouMin Chen 	DDR4_1600K = 1,
6078efceb6SYouMin Chen 	/* DDR4_1600L (12-12-12) */
6178efceb6SYouMin Chen 	DDR4_1600L = 2,
6278efceb6SYouMin Chen 	/* DDR4_1800L (12-12-12) */
6378efceb6SYouMin Chen 	DDR4_1866L = 3,
6478efceb6SYouMin Chen 	/* DDR4_1800M (13-13-13) */
6578efceb6SYouMin Chen 	DDR4_1866M = 4,
6678efceb6SYouMin Chen 	/* DDR4_1800N (14-14-14) */
6778efceb6SYouMin Chen 	DDR4_1866N = 5,
6878efceb6SYouMin Chen 	/* DDR4_2133N (14-14-14) */
6978efceb6SYouMin Chen 	DDR4_2133N = 6,
7078efceb6SYouMin Chen 	/* DDR4_2133P (15-15-15) */
7178efceb6SYouMin Chen 	DDR4_2133P = 7,
7278efceb6SYouMin Chen 	/* DDR4_2133R (16-16-16) */
7378efceb6SYouMin Chen 	DDR4_2133R = 8,
7478efceb6SYouMin Chen 	/* DDR4_2400P (15-15-15) */
7578efceb6SYouMin Chen 	DDR4_2400P = 9,
7678efceb6SYouMin Chen 	/* DDR4_2400R (16-16-16) */
7778efceb6SYouMin Chen 	DDR4_2400R = 10,
7878efceb6SYouMin Chen 	/* DDR4_2400U (18-18-18) */
7978efceb6SYouMin Chen 	DDR4_2400U = 11,
8078efceb6SYouMin Chen 	/* DEFAULT */
8178efceb6SYouMin Chen 	DDR4_DEFAULT = 12,
8278efceb6SYouMin Chen };
8378efceb6SYouMin Chen 
8478efceb6SYouMin Chen /* mr0 for ddr3 */
8578efceb6SYouMin Chen #define DDR3_BL8		(0)
8678efceb6SYouMin Chen #define DDR3_BC4_8		(1)
8778efceb6SYouMin Chen #define DDR3_BC4		(2)
8878efceb6SYouMin Chen #define DDR3_CL(n)		(((((n) - 4) & 0x7) << 4)\
8978efceb6SYouMin Chen 				| ((((n) - 4) & 0x8) >> 1))
9078efceb6SYouMin Chen #define DDR3_WR(n)		(((n) & 0x7) << 9)
9178efceb6SYouMin Chen #define DDR3_DLL_RESET		(1 << 8)
9278efceb6SYouMin Chen #define DDR3_DLL_DERESET	(0 << 8)
9378efceb6SYouMin Chen 
9478efceb6SYouMin Chen /* mr1 for ddr3 */
9578efceb6SYouMin Chen #define DDR3_DLL_ENABLE		(0)
9678efceb6SYouMin Chen #define DDR3_DLL_DISABLE	(1)
9778efceb6SYouMin Chen #define DDR3_MR1_AL(n)		(((n) & 0x3) << 3)
9878efceb6SYouMin Chen 
9978efceb6SYouMin Chen #define DDR3_DS_40		(0)
10078efceb6SYouMin Chen #define DDR3_DS_34		BIT(1)
10178efceb6SYouMin Chen #define DDR3_DS_MASK		((1 << 1) | (1 << 5))
10278efceb6SYouMin Chen #define DDR3_RTT_NOM_MASK	((1 << 2) | (1 << 6) | (1 << 9))
10378efceb6SYouMin Chen #define DDR3_RTT_NOM_DIS	(0)
10478efceb6SYouMin Chen #define DDR3_RTT_NOM_60		BIT(2)
10578efceb6SYouMin Chen #define DDR3_RTT_NOM_120	BIT(6)
10678efceb6SYouMin Chen #define DDR3_RTT_NOM_40		((1 << 2) | (1 << 6))
10778efceb6SYouMin Chen #define DDR3_TDQS		BIT(11)
10878efceb6SYouMin Chen 
10978efceb6SYouMin Chen /* mr2 for ddr3 */
11078efceb6SYouMin Chen #define DDR3_MR2_CWL(n)		((((n) - 5) & 0x7) << 3)
11178efceb6SYouMin Chen #define DDR3_RTT_WR_DIS		(0)
11278efceb6SYouMin Chen #define DDR3_RTT_WR_60		(1 << 9)
11378efceb6SYouMin Chen #define DDR3_RTT_WR_120		(2 << 9)
11478efceb6SYouMin Chen 
11578efceb6SYouMin Chen /*
11678efceb6SYouMin Chen  * MR0 (Device Information)
11778efceb6SYouMin Chen  * 0:DAI complete, 1:DAI still in progress
11878efceb6SYouMin Chen  */
11978efceb6SYouMin Chen #define LPDDR2_DAI		(0x1)
12078efceb6SYouMin Chen /* 0:S2 or S4 SDRAM, 1:NVM */
12178efceb6SYouMin Chen #define LPDDR2_DI		(0x1 << 1)
12278efceb6SYouMin Chen /* 0:DNV not supported, 1:DNV supported */
12378efceb6SYouMin Chen #define LPDDR2_DNVI		(0x1 << 2)
12478efceb6SYouMin Chen #define LPDDR2_RZQI		(0x3 << 3)
12578efceb6SYouMin Chen 
12678efceb6SYouMin Chen /*
12778efceb6SYouMin Chen  * 00:RZQ self test not supported,
12878efceb6SYouMin Chen  * 01:ZQ-pin may connect to VDDCA or float
12978efceb6SYouMin Chen  * 10:ZQ-pin may short to GND.
13078efceb6SYouMin Chen  * 11:ZQ-pin self test completed, no error condition detected.
13178efceb6SYouMin Chen  */
13278efceb6SYouMin Chen 
13378efceb6SYouMin Chen /* MR1 (Device Feature) */
13478efceb6SYouMin Chen #define LPDDR2_BL4		(0x2)
13578efceb6SYouMin Chen #define LPDDR2_BL8		(0x3)
13678efceb6SYouMin Chen #define LPDDR2_BL16		(0x4)
13778efceb6SYouMin Chen #define LPDDR2_N_WR(n)		(((n) - 2) << 5)
13878efceb6SYouMin Chen 
13978efceb6SYouMin Chen /* MR2 (Device Feature 2) */
14078efceb6SYouMin Chen #define LPDDR2_RL3_WL1		(0x1)
14178efceb6SYouMin Chen #define LPDDR2_RL4_WL2		(0x2)
14278efceb6SYouMin Chen #define LPDDR2_RL5_WL2		(0x3)
14378efceb6SYouMin Chen #define LPDDR2_RL6_WL3		(0x4)
14478efceb6SYouMin Chen #define LPDDR2_RL7_WL4		(0x5)
14578efceb6SYouMin Chen #define LPDDR2_RL8_WL4		(0x6)
14678efceb6SYouMin Chen 
14778efceb6SYouMin Chen /* MR3 (IO Configuration 1) */
14878efceb6SYouMin Chen #define LPDDR2_DS_34		(0x1)
14978efceb6SYouMin Chen #define LPDDR2_DS_40		(0x2)
15078efceb6SYouMin Chen #define LPDDR2_DS_48		(0x3)
15178efceb6SYouMin Chen #define LPDDR2_DS_60		(0x4)
15278efceb6SYouMin Chen #define LPDDR2_DS_80		(0x6)
15378efceb6SYouMin Chen /* optional */
15478efceb6SYouMin Chen #define LPDDR2_DS_120		(0x7)
15578efceb6SYouMin Chen 
15678efceb6SYouMin Chen /* MR4 (Device Temperature) */
15778efceb6SYouMin Chen #define LPDDR2_TREF_MASK	(0x7)
15878efceb6SYouMin Chen #define LPDDR2_4_TREF		(0x1)
15978efceb6SYouMin Chen #define LPDDR2_2_TREF		(0x2)
16078efceb6SYouMin Chen #define LPDDR2_1_TREF		(0x3)
16178efceb6SYouMin Chen #define LPDDR2_025_TREF		(0x5)
16278efceb6SYouMin Chen #define LPDDR2_025_TREF_DERATE	(0x6)
16378efceb6SYouMin Chen 
16478efceb6SYouMin Chen #define LPDDR2_TUF		(0x1 << 7)
16578efceb6SYouMin Chen 
16678efceb6SYouMin Chen /* MR8 (Basic configuration 4) */
16778efceb6SYouMin Chen #define LPDDR2_S4		(0x0)
16878efceb6SYouMin Chen #define LPDDR2_S2		(0x1)
16978efceb6SYouMin Chen #define LPDDR2_N		(0x2)
17078efceb6SYouMin Chen /* Unit:MB */
17178efceb6SYouMin Chen #define LPDDR2_DENSITY(mr8)	(8 << (((mr8) >> 2) & 0xf))
17278efceb6SYouMin Chen #define LPDDR2_IO_WIDTH(mr8)	(32 >> (((mr8) >> 6) & 0x3))
17378efceb6SYouMin Chen 
17478efceb6SYouMin Chen /* MR10 (Calibration) */
17578efceb6SYouMin Chen #define LPDDR2_ZQINIT		(0xff)
17678efceb6SYouMin Chen #define LPDDR2_ZQCL		(0xab)
17778efceb6SYouMin Chen #define LPDDR2_ZQCS		(0x56)
17878efceb6SYouMin Chen #define LPDDR2_ZQRESET		(0xc3)
17978efceb6SYouMin Chen 
18078efceb6SYouMin Chen /* MR16 (PASR Bank Mask), S2 SDRAM Only */
18178efceb6SYouMin Chen #define LPDDR2_PASR_FULL	(0x0)
18278efceb6SYouMin Chen #define LPDDR2_PASR_1_2		(0x1)
18378efceb6SYouMin Chen #define LPDDR2_PASR_1_4		(0x2)
18478efceb6SYouMin Chen #define LPDDR2_PASR_1_8		(0x3)
18578efceb6SYouMin Chen 
18678efceb6SYouMin Chen /*
18778efceb6SYouMin Chen  * MR0 (Device Information)
18878efceb6SYouMin Chen  * 0:DAI complete,
18978efceb6SYouMin Chen  * 1:DAI still in progress
19078efceb6SYouMin Chen  */
19178efceb6SYouMin Chen #define LPDDR3_DAI		(0x1)
19278efceb6SYouMin Chen /*
19378efceb6SYouMin Chen  * 00:RZQ self test not supported,
19478efceb6SYouMin Chen  * 01:ZQ-pin may connect to VDDCA or float
19578efceb6SYouMin Chen  * 10:ZQ-pin may short to GND.
19678efceb6SYouMin Chen  * 11:ZQ-pin self test completed, no error condition detected.
19778efceb6SYouMin Chen  */
19878efceb6SYouMin Chen #define LPDDR3_RZQI		(0x3 << 3)
19978efceb6SYouMin Chen /*
20078efceb6SYouMin Chen  * 0:DRAM does not support WL(Set B),
20178efceb6SYouMin Chen  * 1:DRAM support WL(Set B)
20278efceb6SYouMin Chen  */
20378efceb6SYouMin Chen #define LPDDR3_WL_SUPOT		BIT(6)
20478efceb6SYouMin Chen /*
20578efceb6SYouMin Chen  * 0:DRAM does not support RL=3,nWR=3,WL=1;
20678efceb6SYouMin Chen  * 1:DRAM supports RL=3,nWR=3,WL=1 for frequencies <=166
20778efceb6SYouMin Chen  */
20878efceb6SYouMin Chen #define LPDDR3_RL3_SUPOT	BIT(7)
20978efceb6SYouMin Chen 
21078efceb6SYouMin Chen /* MR1 (Device Feature) */
21178efceb6SYouMin Chen #define LPDDR3_BL8		(0x3)
21278efceb6SYouMin Chen #define LPDDR3_N_WR(n)		((n) << 5)
21378efceb6SYouMin Chen 
21478efceb6SYouMin Chen /* MR2 (Device Feature 2), WL Set A,default */
21578efceb6SYouMin Chen /* <=166MHz,optional*/
21678efceb6SYouMin Chen #define LPDDR3_RL3_WL1		(0x1)
21778efceb6SYouMin Chen /* <=400MHz*/
21878efceb6SYouMin Chen #define LPDDR3_RL6_WL3		(0x4)
21978efceb6SYouMin Chen /* <=533MHz*/
22078efceb6SYouMin Chen #define LPDDR3_RL8_WL4		(0x6)
22178efceb6SYouMin Chen /* <=600MHz*/
22278efceb6SYouMin Chen #define LPDDR3_RL9_WL5		(0x7)
22378efceb6SYouMin Chen /* <=667MHz,default*/
22478efceb6SYouMin Chen #define LPDDR3_RL10_WL6		(0x8)
22578efceb6SYouMin Chen /* <=733MHz*/
22678efceb6SYouMin Chen #define LPDDR3_RL11_WL6		(0x9)
22778efceb6SYouMin Chen /* <=800MHz*/
22878efceb6SYouMin Chen #define LPDDR3_RL12_WL6		(0xa)
22978efceb6SYouMin Chen /* <=933MHz*/
23078efceb6SYouMin Chen #define LPDDR3_RL14_WL8		(0xc)
23178efceb6SYouMin Chen /* <=1066MHz*/
23278efceb6SYouMin Chen #define LPDDR3_RL16_WL8		(0xe)
23378efceb6SYouMin Chen 
23478efceb6SYouMin Chen /* WL Set B, optional */
23578efceb6SYouMin Chen /* <=667MHz,default*/
23678efceb6SYouMin Chen #define LPDDR3_RL10_WL8		(0x8)
23778efceb6SYouMin Chen /* <=733MHz*/
23878efceb6SYouMin Chen #define LPDDR3_RL11_WL9		(0x9)
23978efceb6SYouMin Chen /* <=800MHz*/
24078efceb6SYouMin Chen #define LPDDR3_RL12_WL9		(0xa)
24178efceb6SYouMin Chen /* <=933MHz*/
24278efceb6SYouMin Chen #define LPDDR3_RL14_WL11	(0xc)
24378efceb6SYouMin Chen /* <=1066MHz*/
24478efceb6SYouMin Chen #define LPDDR3_RL16_WL13	(0xe)
24578efceb6SYouMin Chen 
24678efceb6SYouMin Chen /* 1:enable nWR programming > 9(default)*/
24778efceb6SYouMin Chen #define LPDDR3_N_WRE		BIT(4)
24878efceb6SYouMin Chen /* 1:Select WL Set B*/
24978efceb6SYouMin Chen #define LPDDR3_WL_S		BIT(6)
25078efceb6SYouMin Chen /* 1:enable*/
25178efceb6SYouMin Chen #define LPDDR3_WR_LEVEL		BIT(7)
25278efceb6SYouMin Chen 
25378efceb6SYouMin Chen /* MR3 (IO Configuration 1) */
25478efceb6SYouMin Chen #define LPDDR3_DS_34		(0x1)
25578efceb6SYouMin Chen #define LPDDR3_DS_40		(0x2)
25678efceb6SYouMin Chen #define LPDDR3_DS_48		(0x3)
25778efceb6SYouMin Chen #define LPDDR3_DS_60		(0x4)
25878efceb6SYouMin Chen #define LPDDR3_DS_80		(0x6)
25978efceb6SYouMin Chen #define LPDDR3_DS_34D_40U	(0x9)
26078efceb6SYouMin Chen #define LPDDR3_DS_40D_48U	(0xa)
26178efceb6SYouMin Chen #define LPDDR3_DS_34D_48U	(0xb)
26278efceb6SYouMin Chen 
26378efceb6SYouMin Chen /* MR4 (Device Temperature) */
26478efceb6SYouMin Chen #define LPDDR3_TREF_MASK	(0x7)
26578efceb6SYouMin Chen /* SDRAM Low temperature operating limit exceeded */
26678efceb6SYouMin Chen #define LPDDR3_LT_EXED		(0x0)
26778efceb6SYouMin Chen #define LPDDR3_4_TREF		(0x1)
26878efceb6SYouMin Chen #define LPDDR3_2_TREF		(0x2)
26978efceb6SYouMin Chen #define LPDDR3_1_TREF		(0x3)
27078efceb6SYouMin Chen #define LPDDR3_05_TREF		(0x4)
27178efceb6SYouMin Chen #define LPDDR3_025_TREF		(0x5)
27278efceb6SYouMin Chen #define LPDDR3_025_TREF_DERATE	(0x6)
27378efceb6SYouMin Chen /* SDRAM High temperature operating limit exceeded */
27478efceb6SYouMin Chen #define LPDDR3_HT_EXED		(0x7)
27578efceb6SYouMin Chen 
27678efceb6SYouMin Chen /* 1:value has changed since last read of MR4 */
27778efceb6SYouMin Chen #define LPDDR3_TUF		(0x1 << 7)
27878efceb6SYouMin Chen 
27978efceb6SYouMin Chen /* MR8 (Basic configuration 4) */
28078efceb6SYouMin Chen #define LPDDR3_S8		(0x3)
28178efceb6SYouMin Chen #define LPDDR3_DENSITY(mr8)	(8 << (((mr8) >> 2) & 0xf))
28278efceb6SYouMin Chen #define LPDDR3_IO_WIDTH(mr8)	(32 >> (((mr8) >> 6) & 0x3))
28378efceb6SYouMin Chen 
28478efceb6SYouMin Chen /* MR10 (Calibration) */
28578efceb6SYouMin Chen #define LPDDR3_ZQINIT		(0xff)
28678efceb6SYouMin Chen #define LPDDR3_ZQCL		(0xab)
28778efceb6SYouMin Chen #define LPDDR3_ZQCS		(0x56)
28878efceb6SYouMin Chen #define LPDDR3_ZQRESET		(0xc3)
28978efceb6SYouMin Chen 
29078efceb6SYouMin Chen /* MR11 (ODT Control) */
29178efceb6SYouMin Chen #define LPDDR3_ODT_60		(1)
29278efceb6SYouMin Chen #define LPDDR3_ODT_120		(2)
29378efceb6SYouMin Chen #define LPDDR3_ODT_240		(3)
29478efceb6SYouMin Chen #define LPDDR3_ODT_DIS		(0)
29578efceb6SYouMin Chen 
29678efceb6SYouMin Chen /* MR2 (Device Feature 2) */
29778efceb6SYouMin Chen /* RL & nRTP for DBI-RD Disabled */
29878efceb6SYouMin Chen #define LPDDR4_RL6_NRTP8	(0x0)
29978efceb6SYouMin Chen #define LPDDR4_RL10_NRTP8	(0x1)
30078efceb6SYouMin Chen #define LPDDR4_RL14_NRTP8	(0x2)
30178efceb6SYouMin Chen #define LPDDR4_RL20_NRTP8	(0x3)
30278efceb6SYouMin Chen #define LPDDR4_RL24_NRTP10	(0x4)
30378efceb6SYouMin Chen #define LPDDR4_RL28_NRTP12	(0x5)
30478efceb6SYouMin Chen #define LPDDR4_RL32_NRTP14	(0x6)
30578efceb6SYouMin Chen #define LPDDR4_RL36_NRTP16	(0x7)
30678efceb6SYouMin Chen /* RL & nRTP for DBI-RD Disabled */
30778efceb6SYouMin Chen #define LPDDR4_RL12_NRTP8	(0x1)
30878efceb6SYouMin Chen #define LPDDR4_RL16_NRTP8	(0x2)
30978efceb6SYouMin Chen #define LPDDR4_RL22_NRTP8	(0x3)
31078efceb6SYouMin Chen #define LPDDR4_RL28_NRTP10	(0x4)
31178efceb6SYouMin Chen #define LPDDR4_RL32_NRTP12	(0x5)
31278efceb6SYouMin Chen #define LPDDR4_RL36_NRTP14	(0x6)
31378efceb6SYouMin Chen #define LPDDR4_RL40_NRTP16	(0x7)
31478efceb6SYouMin Chen /* WL Set A,default */
31578efceb6SYouMin Chen #define LPDDR4_A_WL4		(0x0 << 3)
31678efceb6SYouMin Chen #define LPDDR4_A_WL6		(0x1 << 3)
31778efceb6SYouMin Chen #define LPDDR4_A_WL8		(0x2 << 3)
31878efceb6SYouMin Chen #define LPDDR4_A_WL10		(0x3 << 3)
31978efceb6SYouMin Chen #define LPDDR4_A_WL12		(0x4 << 3)
32078efceb6SYouMin Chen #define LPDDR4_A_WL14		(0x5 << 3)
32178efceb6SYouMin Chen #define LPDDR4_A_WL16		(0x6 << 3)
32278efceb6SYouMin Chen #define LPDDR4_A_WL18		(0x7 << 3)
32378efceb6SYouMin Chen /* WL Set B, optional */
32478efceb6SYouMin Chen #define LPDDR4_B_WL4		(0x0 << 3)
32578efceb6SYouMin Chen #define LPDDR4_B_WL8		(0x1 << 3)
32678efceb6SYouMin Chen #define LPDDR4_B_WL12		(0x2 << 3)
32778efceb6SYouMin Chen #define LPDDR4_B_WL18		(0x3 << 3)
32878efceb6SYouMin Chen #define LPDDR4_B_WL22		(0x4 << 3)
32978efceb6SYouMin Chen #define LPDDR4_B_WL26		(0x5 << 3)
33078efceb6SYouMin Chen #define LPDDR4_B_WL30		(0x6 << 3)
33178efceb6SYouMin Chen #define LPDDR4_B_WL34		(0x7 << 3)
33278efceb6SYouMin Chen /* 1:Select WL Set B*/
33378efceb6SYouMin Chen #define LPDDR4_WL_B		BIT(6)
33478efceb6SYouMin Chen /* 1:enable*/
33578efceb6SYouMin Chen #define LPDDR4_WR_LEVEL		BIT(7)
33678efceb6SYouMin Chen 
33778efceb6SYouMin Chen /* MR3 */
33878efceb6SYouMin Chen #define LPDDR4_VDDQ_2_5		(0)
33978efceb6SYouMin Chen #define LPDDR4_VDDQ_3		(1)
34078efceb6SYouMin Chen #define LPDDR4_PU_CAL_MASK	(1)
34178efceb6SYouMin Chen #define LPDDR4_WRPST_0_5_TCK	(0 << 1)
34278efceb6SYouMin Chen #define LPDDR4_WRPST_1_5_TCK	(1 << 1)
34378efceb6SYouMin Chen #define LPDDR4_PPR_EN		(1 << 2)
34478efceb6SYouMin Chen /* PDDS */
34578efceb6SYouMin Chen #define LPDDR4_PDDS_MASK	(0x7 << 3)
34678efceb6SYouMin Chen #define LPDDR4_PDDS_SHIFT	(3)
34778efceb6SYouMin Chen #define LPDDR4_PDDS_240		(0x1 << 3)
34878efceb6SYouMin Chen #define LPDDR4_PDDS_120		(0x2 << 3)
34978efceb6SYouMin Chen #define LPDDR4_PDDS_80		(0x3 << 3)
35078efceb6SYouMin Chen #define LPDDR4_PDDS_60		(0x4 << 3)
35178efceb6SYouMin Chen #define LPDDR4_PDDS_48		(0x5 << 3)
35278efceb6SYouMin Chen #define LPDDR4_PDDS_40		(0x6 << 3)
35378efceb6SYouMin Chen #define LPDDR4_DBI_RD_EN	BIT(6)
35478efceb6SYouMin Chen #define LPDDR4_DBI_WR_EN	BIT(7)
35578efceb6SYouMin Chen 
35678efceb6SYouMin Chen /* MR11 (ODT Control) */
35778efceb6SYouMin Chen #define LPDDR4_DQODT_MASK	(0x7)
35878efceb6SYouMin Chen #define LPDDR4_DQODT_SHIFT	(0x0)
35978efceb6SYouMin Chen #define LPDDR4_DQODT_240	(1)
36078efceb6SYouMin Chen #define LPDDR4_DQODT_120	(2)
36178efceb6SYouMin Chen #define LPDDR4_DQODT_80		(3)
36278efceb6SYouMin Chen #define LPDDR4_DQODT_60		(4)
36378efceb6SYouMin Chen #define LPDDR4_DQODT_48		(5)
36478efceb6SYouMin Chen #define LPDDR4_DQODT_40		(6)
36578efceb6SYouMin Chen #define LPDDR4_DQODT_DIS	(0)
36678efceb6SYouMin Chen #define LPDDR4_CAODT_MASK	(0x7 << 4)
36778efceb6SYouMin Chen #define LPDDR4_CAODT_SHIFT	(4)
36878efceb6SYouMin Chen #define LPDDR4_CAODT_240	(1 << 4)
36978efceb6SYouMin Chen #define LPDDR4_CAODT_120	(2 << 4)
37078efceb6SYouMin Chen #define LPDDR4_CAODT_80		(3 << 4)
37178efceb6SYouMin Chen #define LPDDR4_CAODT_60		(4 << 4)
37278efceb6SYouMin Chen #define LPDDR4_CAODT_48		(5 << 4)
37378efceb6SYouMin Chen #define LPDDR4_CAODT_40		(6 << 4)
37478efceb6SYouMin Chen #define LPDDR4_CAODT_DIS	(0 << 4)
37578efceb6SYouMin Chen 
37678efceb6SYouMin Chen /* MR22 */
37778efceb6SYouMin Chen #define LPDDR4_ODTE_CK_SHIFT	(3)
37878efceb6SYouMin Chen #define LPDDR4_ODTE_CS_SHIFT	(4)
37978efceb6SYouMin Chen #define LPDDR4_ODTD_CA_SHIFT	(5)
38078efceb6SYouMin Chen #define LPDDR4_SOC_ODT_MASK	(0x7)
38178efceb6SYouMin Chen #define LPDDR4_SOC_ODT_SHIFT	(0)
38278efceb6SYouMin Chen #define LPDDR4_SOC_ODT_240	(1)
38378efceb6SYouMin Chen #define LPDDR4_SOC_ODT_120	(2)
38478efceb6SYouMin Chen #define LPDDR4_SOC_ODT_80	(3)
38578efceb6SYouMin Chen #define LPDDR4_SOC_ODT_60	(4)
38678efceb6SYouMin Chen #define LPDDR4_SOC_ODT_48	(5)
38778efceb6SYouMin Chen #define LPDDR4_SOC_ODT_40	(6)
38878efceb6SYouMin Chen #define LPDDR4_SOC_ODT_DIS	(0)
38978efceb6SYouMin Chen 
390*5290223fSYouMin Chen /* LPDDR4x */
391*5290223fSYouMin Chen /* MR3 */
392*5290223fSYouMin Chen #define LPDDR4X_VDDQ_0_6	(0)
393*5290223fSYouMin Chen #define LPDDR4X_VDDQ_0_5	(1)
394*5290223fSYouMin Chen 
39578efceb6SYouMin Chen /* mr0 for ddr4 */
39678efceb6SYouMin Chen #define DDR4_BL8		(0)
39778efceb6SYouMin Chen #define DDR4_BC4_8		(1)
39878efceb6SYouMin Chen #define DDR4_BC4		(2)
39978efceb6SYouMin Chen #define DDR4_WR_RTP(n)		((n) << 9)
40078efceb6SYouMin Chen #define DDR4_CL(n)		((((n) & 0xe) << 3) | ((n) & 1) << 2)
40178efceb6SYouMin Chen #define DDR4_DLL_RESET(n)	((n) << 8)
40278efceb6SYouMin Chen #define DDR4_DLL_ON		BIT(0)
40378efceb6SYouMin Chen #define DDR4_DLL_OFF		(0 << 0)
40478efceb6SYouMin Chen 
40578efceb6SYouMin Chen /* mr1 for ddr4 */
40678efceb6SYouMin Chen #define DDR4_AL			((n) << 3)
40778efceb6SYouMin Chen #define DDR4_DS_34		(0)
40878efceb6SYouMin Chen #define DDR4_DS_48		BIT(1)
40978efceb6SYouMin Chen #define DDR4_DS_MASK		(0x3 << 1)
41078efceb6SYouMin Chen #define DDR4_RTT_NOM_MASK	(0x7 << 8)
41178efceb6SYouMin Chen #define DDR4_RTT_NOM_DIS	(0)
41278efceb6SYouMin Chen #define DDR4_RTT_NOM_60		BIT(8)
41378efceb6SYouMin Chen #define DDR4_RTT_NOM_120	(2 << 8)
41478efceb6SYouMin Chen #define DDR4_RTT_NOM_40		(0x3 << 8)
41578efceb6SYouMin Chen #define DDR4_RTT_NOM_240	(0x4 << 8)
41678efceb6SYouMin Chen #define DDR4_RTT_NOM_48		(0x5 << 8)
41778efceb6SYouMin Chen #define DDR4_RTT_NOM_80		(0x6 << 8)
41878efceb6SYouMin Chen #define DDR4_RTT_NOM_34		(0x7 << 8)
41978efceb6SYouMin Chen 
42078efceb6SYouMin Chen /* mr2 for ddr4 */
42178efceb6SYouMin Chen #define DDR4_MR2_CWL(n)		((n) << 3)
42278efceb6SYouMin Chen #define DDR4_RTT_WR_DIS		(0)
42378efceb6SYouMin Chen #define DDR4_RTT_WR_120		BIT(9)
42478efceb6SYouMin Chen #define DDR4_RTT_WR_240		(2 << 9)
42578efceb6SYouMin Chen 
42678efceb6SYouMin Chen /* mr4 for ddr4 */
42778efceb6SYouMin Chen #define DDR4_READ_PREAMBLE(n)	((n) << 11)
42878efceb6SYouMin Chen #define DDR4_WRITE_PREAMBLE(n)	((n) << 12)
42978efceb6SYouMin Chen #define DDR4_READ_PREAMBLE_TRAIN(n)	((n) << 10)
43078efceb6SYouMin Chen 
43178efceb6SYouMin Chen /* mr5 for ddr4 */
43278efceb6SYouMin Chen #define DDR4_RD_DBI(n)		((n) << 12)
43378efceb6SYouMin Chen #define DDR4_WR_DBI(n)		((n) << 11)
43478efceb6SYouMin Chen #define DDR4_DM(n)		((n) << 10)
43578efceb6SYouMin Chen #define DDR4_RTT_PARK_DIS	(0 << 6)
43678efceb6SYouMin Chen #define DDR4_RTT_PARK_60	(1 << 6)
43778efceb6SYouMin Chen #define DDR4_RTT_PARK_120	(2 << 6)
43878efceb6SYouMin Chen #define DDR4_RTT_PARK_40	(3 << 6)
43978efceb6SYouMin Chen #define DDR4_RTT_PARK_240	(4 << 6)
44078efceb6SYouMin Chen #define DDR4_RTT_PARK_48	(5 << 6)
44178efceb6SYouMin Chen #define DDR4_RTT_PARK_80	(6 << 6)
44278efceb6SYouMin Chen #define DDR4_RTT_PARK_34	(7 << 6)
44378efceb6SYouMin Chen #define DIS_ODT_PD		(1 << 5)
44478efceb6SYouMin Chen #define EN_ODT_PD		(0 << 5)
44578efceb6SYouMin Chen 
44678efceb6SYouMin Chen /* mr6 for ddr4 */
44778efceb6SYouMin Chen #define DDR4_TCCD_L(n)		(((n) - 4) << 10)
44878efceb6SYouMin Chen 
44978efceb6SYouMin Chen #define PS_2_CLK(freq, ps)	(((uint64_t)(ps) / 100 * (uint64_t)(freq) +\
45078efceb6SYouMin Chen 				9999) / 10000)
45178efceb6SYouMin Chen 
45278efceb6SYouMin Chen #endif /* __ROCKCHIP_DRAM_SPEC_TIMING_H__ */
453