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