blob: a1c3d05f8e50e2f7d4f2a62097f8e46379f0aaaa [file] [log] [blame]
Vitaly Andrianovef509b92014-04-04 13:16:53 -04001/*
2 * Keystone2: DDR3 initialization
3 *
4 * (C) Copyright 2012-2014
5 * Texas Instruments Incorporated, <www.ti.com>
6 *
7 * SPDX-License-Identifier: GPL-2.0+
8 */
9
10#include <common.h>
Hao Zhangb1babef2014-07-09 23:44:49 +030011#include "ddr3_cfg.h"
Khoronzhuk, Ivan0b868582014-07-09 19:48:40 +030012#include <asm/arch/ddr3.h>
Vitaly Andrianovef509b92014-04-04 13:16:53 -040013#include <asm/arch/hardware.h>
Vitaly Andrianovef509b92014-04-04 13:16:53 -040014
Vitaly Andrianov89f44bb2014-10-22 17:47:58 +030015static int ddr3_size;
16
Vitaly Andrianovef509b92014-04-04 13:16:53 -040017struct pll_init_data ddr3a_333 = DDR3_PLL_333(A);
Vitaly Andrianovef509b92014-04-04 13:16:53 -040018struct pll_init_data ddr3a_400 = DDR3_PLL_400(A);
Vitaly Andrianovef509b92014-04-04 13:16:53 -040019
Khoronzhuk, Ivan0b868582014-07-09 19:48:40 +030020void ddr3_init(void)
Vitaly Andrianovef509b92014-04-04 13:16:53 -040021{
22 char dimm_name[32];
23
Hao Zhangb1babef2014-07-09 23:44:49 +030024 ddr3_get_dimm_params(dimm_name);
Vitaly Andrianovef509b92014-04-04 13:16:53 -040025
26 printf("Detected SO-DIMM [%s]\n", dimm_name);
27
28 if (!strcmp(dimm_name, "18KSF1G72HZ-1G6E2 ")) {
29 init_pll(&ddr3a_400);
30 if (cpu_revision() > 0) {
Hao Zhang101eec52014-07-09 19:48:41 +030031 if (cpu_revision() > 1) {
32 /* PG 2.0 */
33 /* Reset DDR3A PHY after PLL enabled */
34 ddr3_reset_ddrphy();
Hao Zhangb1babef2014-07-09 23:44:49 +030035 ddr3phy_1600_8g.zq0cr1 |= 0x10000;
36 ddr3phy_1600_8g.zq1cr1 |= 0x10000;
37 ddr3phy_1600_8g.zq2cr1 |= 0x10000;
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030038 ddr3_init_ddrphy(KS2_DDR3A_DDRPHYC,
Hao Zhangb1babef2014-07-09 23:44:49 +030039 &ddr3phy_1600_8g);
Hao Zhang101eec52014-07-09 19:48:41 +030040 } else {
41 /* PG 1.1 */
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030042 ddr3_init_ddrphy(KS2_DDR3A_DDRPHYC,
Hao Zhangb1babef2014-07-09 23:44:49 +030043 &ddr3phy_1600_8g);
Hao Zhang101eec52014-07-09 19:48:41 +030044 }
45
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030046 ddr3_init_ddremif(KS2_DDR3A_EMIF_CTRL_BASE,
Hao Zhangb1babef2014-07-09 23:44:49 +030047 &ddr3_1600_8g);
Vitaly Andrianovef509b92014-04-04 13:16:53 -040048 printf("DRAM: Capacity 8 GiB (includes reported below)\n");
Vitaly Andrianov89f44bb2014-10-22 17:47:58 +030049 ddr3_size = 8;
Vitaly Andrianovef509b92014-04-04 13:16:53 -040050 } else {
Hao Zhangb1babef2014-07-09 23:44:49 +030051 ddr3_init_ddrphy(KS2_DDR3A_DDRPHYC, &ddr3phy_1600_8g);
52 ddr3_1600_8g.sdcfg |= 0x1000;
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030053 ddr3_init_ddremif(KS2_DDR3A_EMIF_CTRL_BASE,
Hao Zhangb1babef2014-07-09 23:44:49 +030054 &ddr3_1600_8g);
Vitaly Andrianovef509b92014-04-04 13:16:53 -040055 printf("DRAM: Capacity 4 GiB (includes reported below)\n");
Vitaly Andrianov89f44bb2014-10-22 17:47:58 +030056 ddr3_size = 4;
Vitaly Andrianovef509b92014-04-04 13:16:53 -040057 }
58 } else if (!strcmp(dimm_name, "SQR-SD3T-2G1333SED")) {
59 init_pll(&ddr3a_333);
60 if (cpu_revision() > 0) {
Hao Zhang101eec52014-07-09 19:48:41 +030061 if (cpu_revision() > 1) {
62 /* PG 2.0 */
63 /* Reset DDR3A PHY after PLL enabled */
64 ddr3_reset_ddrphy();
Hao Zhangb1babef2014-07-09 23:44:49 +030065 ddr3phy_1333_2g.zq0cr1 |= 0x10000;
66 ddr3phy_1333_2g.zq1cr1 |= 0x10000;
67 ddr3phy_1333_2g.zq2cr1 |= 0x10000;
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030068 ddr3_init_ddrphy(KS2_DDR3A_DDRPHYC,
Hao Zhangb1babef2014-07-09 23:44:49 +030069 &ddr3phy_1333_2g);
Hao Zhang101eec52014-07-09 19:48:41 +030070 } else {
71 /* PG 1.1 */
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030072 ddr3_init_ddrphy(KS2_DDR3A_DDRPHYC,
Hao Zhangb1babef2014-07-09 23:44:49 +030073 &ddr3phy_1333_2g);
Hao Zhang101eec52014-07-09 19:48:41 +030074 }
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030075 ddr3_init_ddremif(KS2_DDR3A_EMIF_CTRL_BASE,
Hao Zhangb1babef2014-07-09 23:44:49 +030076 &ddr3_1333_2g);
Vitaly Andrianov89f44bb2014-10-22 17:47:58 +030077 ddr3_size = 2;
78 printf("DRAM: 2 GiB");
Vitaly Andrianovef509b92014-04-04 13:16:53 -040079 } else {
Hao Zhangb1babef2014-07-09 23:44:49 +030080 ddr3_init_ddrphy(KS2_DDR3A_DDRPHYC, &ddr3phy_1333_2g);
81 ddr3_1333_2g.sdcfg |= 0x1000;
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030082 ddr3_init_ddremif(KS2_DDR3A_EMIF_CTRL_BASE,
Hao Zhangb1babef2014-07-09 23:44:49 +030083 &ddr3_1333_2g);
Vitaly Andrianov89f44bb2014-10-22 17:47:58 +030084 ddr3_size = 1;
85 printf("DRAM: 1 GiB");
Vitaly Andrianovef509b92014-04-04 13:16:53 -040086 }
87 } else {
88 printf("Unknown SO-DIMM. Cannot configure DDR3\n");
89 while (1)
90 ;
91 }
Murali Karicheri6c343822014-09-10 15:54:59 +030092
93 /* Apply the workaround for PG 1.0 and 1.1 Silicons */
94 if (cpu_revision() <= 1)
95 ddr3_err_reset_workaround();
Vitaly Andrianovef509b92014-04-04 13:16:53 -040096}
Vitaly Andrianov89f44bb2014-10-22 17:47:58 +030097
98/**
99 * ddr3_get_size - return ddr3 size in GiB
100 */
101int ddr3_get_size(void)
102{
103 return ddr3_size;
104}