1*ca62d2e1SMarek Vasut /* 2*ca62d2e1SMarek Vasut * Copyright (C) 2015 Marek Vasut <marex@denx.de> 3*ca62d2e1SMarek Vasut * 4*ca62d2e1SMarek Vasut * SPDX-License-Identifier: GPL-2.0+ 5*ca62d2e1SMarek Vasut */ 6*ca62d2e1SMarek Vasut 7*ca62d2e1SMarek Vasut #include <common.h> 8*ca62d2e1SMarek Vasut #include <errno.h> 9*ca62d2e1SMarek Vasut #include <asm/arch/sdram.h> 10*ca62d2e1SMarek Vasut /* QTS output file. */ 11*ca62d2e1SMarek Vasut #include <qts/sdram_config.h> 12*ca62d2e1SMarek Vasut 13*ca62d2e1SMarek Vasut #include <qts/sequencer_auto_ac_init.h> 14*ca62d2e1SMarek Vasut #include <qts/sequencer_auto_inst_init.h> 15*ca62d2e1SMarek Vasut #include <qts/sequencer_auto.h> 16*ca62d2e1SMarek Vasut #include <qts/sequencer_defines.h> 17*ca62d2e1SMarek Vasut 18*ca62d2e1SMarek Vasut static const struct socfpga_sdram_config sdram_config = { 19*ca62d2e1SMarek Vasut .ctrl_cfg = 20*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_MEMTYPE << 21*ca62d2e1SMarek Vasut SDR_CTRLGRP_CTRLCFG_MEMTYPE_LSB) | 22*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_MEMBL << 23*ca62d2e1SMarek Vasut SDR_CTRLGRP_CTRLCFG_MEMBL_LSB) | 24*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_ADDRORDER << 25*ca62d2e1SMarek Vasut SDR_CTRLGRP_CTRLCFG_ADDRORDER_LSB) | 26*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_ECCEN << 27*ca62d2e1SMarek Vasut SDR_CTRLGRP_CTRLCFG_ECCEN_LSB) | 28*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_ECCCORREN << 29*ca62d2e1SMarek Vasut SDR_CTRLGRP_CTRLCFG_ECCCORREN_LSB) | 30*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_REORDEREN << 31*ca62d2e1SMarek Vasut SDR_CTRLGRP_CTRLCFG_REORDEREN_LSB) | 32*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_STARVELIMIT << 33*ca62d2e1SMarek Vasut SDR_CTRLGRP_CTRLCFG_STARVELIMIT_LSB) | 34*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_DQSTRKEN << 35*ca62d2e1SMarek Vasut SDR_CTRLGRP_CTRLCFG_DQSTRKEN_LSB) | 36*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_NODMPINS << 37*ca62d2e1SMarek Vasut SDR_CTRLGRP_CTRLCFG_NODMPINS_LSB), 38*ca62d2e1SMarek Vasut .dram_timing1 = 39*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_TCWL << 40*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING1_TCWL_LSB) | 41*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_AL << 42*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING1_TAL_LSB) | 43*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_TCL << 44*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING1_TCL_LSB) | 45*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_TRRD << 46*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING1_TRRD_LSB) | 47*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_TFAW << 48*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING1_TFAW_LSB) | 49*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_TRFC << 50*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING1_TRFC_LSB), 51*ca62d2e1SMarek Vasut .dram_timing2 = 52*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING2_IF_TREFI << 53*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING2_TREFI_LSB) | 54*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING2_IF_TRCD << 55*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING2_TRCD_LSB) | 56*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING2_IF_TRP << 57*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING2_TRP_LSB) | 58*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING2_IF_TWR << 59*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING2_TWR_LSB) | 60*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING2_IF_TWTR << 61*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING2_TWTR_LSB), 62*ca62d2e1SMarek Vasut .dram_timing3 = 63*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING3_TRTP << 64*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING3_TRTP_LSB) | 65*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING3_TRAS << 66*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING3_TRAS_LSB) | 67*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING3_TRC << 68*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING3_TRC_LSB) | 69*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING3_TMRD << 70*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING3_TMRD_LSB) | 71*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING3_TCCD << 72*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING3_TCCD_LSB), 73*ca62d2e1SMarek Vasut .dram_timing4 = 74*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING4_SELFRFSHEXIT << 75*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING4_SELFRFSHEXIT_LSB) | 76*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING4_PWRDOWNEXIT << 77*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMTIMING4_PWRDOWNEXIT_LSB), 78*ca62d2e1SMarek Vasut .lowpwr_timing = 79*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_LOWPWRTIMING_AUTOPDCYCLES << 80*ca62d2e1SMarek Vasut SDR_CTRLGRP_LOWPWRTIMING_AUTOPDCYCLES_LSB) | 81*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_LOWPWRTIMING_CLKDISABLECYCLES << 82*ca62d2e1SMarek Vasut SDR_CTRLGRP_LOWPWRTIMING_CLKDISABLECYCLES_LSB), 83*ca62d2e1SMarek Vasut .dram_odt = 84*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMODT_READ << 85*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMODT_READ_LSB) | 86*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMODT_WRITE << 87*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMODT_WRITE_LSB), 88*ca62d2e1SMarek Vasut .dram_addrw = 89*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMADDRW_COLBITS << 90*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMADDRW_COLBITS_LSB) | 91*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMADDRW_ROWBITS << 92*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMADDRW_ROWBITS_LSB) | 93*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMADDRW_BANKBITS << 94*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMADDRW_BANKBITS_LSB) | 95*ca62d2e1SMarek Vasut ((CONFIG_HPS_SDR_CTRLCFG_DRAMADDRW_CSBITS - 1) << 96*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMADDRW_CSBITS_LSB), 97*ca62d2e1SMarek Vasut .dram_if_width = 98*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMIFWIDTH_IFWIDTH << 99*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMIFWIDTH_IFWIDTH_LSB), 100*ca62d2e1SMarek Vasut .dram_dev_width = 101*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMDEVWIDTH_DEVWIDTH << 102*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMDEVWIDTH_DEVWIDTH_LSB), 103*ca62d2e1SMarek Vasut .dram_intr = 104*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_DRAMINTR_INTREN << 105*ca62d2e1SMarek Vasut SDR_CTRLGRP_DRAMINTR_INTREN_LSB), 106*ca62d2e1SMarek Vasut .lowpwr_eq = 107*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_LOWPWREQ_SELFRFSHMASK << 108*ca62d2e1SMarek Vasut SDR_CTRLGRP_LOWPWREQ_SELFRFSHMASK_LSB), 109*ca62d2e1SMarek Vasut .static_cfg = 110*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_STATICCFG_MEMBL << 111*ca62d2e1SMarek Vasut SDR_CTRLGRP_STATICCFG_MEMBL_LSB) | 112*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_STATICCFG_USEECCASDATA << 113*ca62d2e1SMarek Vasut SDR_CTRLGRP_STATICCFG_USEECCASDATA_LSB), 114*ca62d2e1SMarek Vasut .ctrl_width = 115*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CTRLWIDTH_CTRLWIDTH << 116*ca62d2e1SMarek Vasut SDR_CTRLGRP_CTRLWIDTH_CTRLWIDTH_LSB), 117*ca62d2e1SMarek Vasut .cport_width = 118*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CPORTWIDTH_CPORTWIDTH << 119*ca62d2e1SMarek Vasut SDR_CTRLGRP_CPORTWIDTH_CMDPORTWIDTH_LSB), 120*ca62d2e1SMarek Vasut .cport_wmap = 121*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CPORTWMAP_CPORTWMAP << 122*ca62d2e1SMarek Vasut SDR_CTRLGRP_CPORTWMAP_CPORTWFIFOMAP_LSB), 123*ca62d2e1SMarek Vasut .cport_rmap = 124*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CPORTRMAP_CPORTRMAP << 125*ca62d2e1SMarek Vasut SDR_CTRLGRP_CPORTRMAP_CPORTRFIFOMAP_LSB), 126*ca62d2e1SMarek Vasut .rfifo_cmap = 127*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_RFIFOCMAP_RFIFOCMAP << 128*ca62d2e1SMarek Vasut SDR_CTRLGRP_RFIFOCMAP_RFIFOCPORTMAP_LSB), 129*ca62d2e1SMarek Vasut .wfifo_cmap = 130*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_WFIFOCMAP_WFIFOCMAP << 131*ca62d2e1SMarek Vasut SDR_CTRLGRP_WFIFOCMAP_WFIFOCPORTMAP_LSB), 132*ca62d2e1SMarek Vasut .cport_rdwr = 133*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_CPORTRDWR_CPORTRDWR << 134*ca62d2e1SMarek Vasut SDR_CTRLGRP_CPORTRDWR_CPORTRDWR_LSB), 135*ca62d2e1SMarek Vasut .port_cfg = 136*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_PORTCFG_AUTOPCHEN << 137*ca62d2e1SMarek Vasut SDR_CTRLGRP_PORTCFG_AUTOPCHEN_LSB), 138*ca62d2e1SMarek Vasut .fpgaport_rst = CONFIG_HPS_SDR_CTRLCFG_FPGAPORTRST, 139*ca62d2e1SMarek Vasut .fifo_cfg = 140*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_FIFOCFG_SYNCMODE << 141*ca62d2e1SMarek Vasut SDR_CTRLGRP_FIFOCFG_SYNCMODE_LSB) | 142*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_FIFOCFG_INCSYNC << 143*ca62d2e1SMarek Vasut SDR_CTRLGRP_FIFOCFG_INCSYNC_LSB), 144*ca62d2e1SMarek Vasut .mp_priority = 145*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPPRIORITY_USERPRIORITY << 146*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPPRIORITY_USERPRIORITY_LSB), 147*ca62d2e1SMarek Vasut .mp_weight0 = 148*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPWIEIGHT_0_STATICWEIGHT_31_0 << 149*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPWEIGHT_MPWEIGHT_0_STATICWEIGHT_31_0_LSB), 150*ca62d2e1SMarek Vasut .mp_weight1 = 151*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPWIEIGHT_1_STATICWEIGHT_49_32 << 152*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPWEIGHT_MPWEIGHT_1_STATICWEIGHT_49_32_LSB) | 153*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPWIEIGHT_1_SUMOFWEIGHT_13_0 << 154*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPWEIGHT_MPWEIGHT_1_SUMOFWEIGHTS_13_0_LSB), 155*ca62d2e1SMarek Vasut .mp_weight2 = 156*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPWIEIGHT_2_SUMOFWEIGHT_45_14 << 157*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPWEIGHT_MPWEIGHT_2_SUMOFWEIGHTS_45_14_LSB), 158*ca62d2e1SMarek Vasut .mp_weight3 = 159*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPWIEIGHT_3_SUMOFWEIGHT_63_46 << 160*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPWEIGHT_MPWEIGHT_3_SUMOFWEIGHTS_63_46_LSB), 161*ca62d2e1SMarek Vasut .mp_pacing0 = 162*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPPACING_0_THRESHOLD1_31_0 << 163*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPPACING_MPPACING_0_THRESHOLD1_31_0_LSB), 164*ca62d2e1SMarek Vasut .mp_pacing1 = 165*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPPACING_1_THRESHOLD1_59_32 << 166*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPPACING_MPPACING_1_THRESHOLD1_59_32_LSB) | 167*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPPACING_1_THRESHOLD2_3_0 << 168*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPPACING_MPPACING_1_THRESHOLD2_3_0_LSB), 169*ca62d2e1SMarek Vasut .mp_pacing2 = 170*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPPACING_2_THRESHOLD2_35_4 << 171*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPPACING_MPPACING_2_THRESHOLD2_35_4_LSB), 172*ca62d2e1SMarek Vasut .mp_pacing3 = 173*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPPACING_3_THRESHOLD2_59_36 << 174*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPPACING_MPPACING_3_THRESHOLD2_59_36_LSB), 175*ca62d2e1SMarek Vasut .mp_threshold0 = 176*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPTHRESHOLDRST_0_THRESHOLDRSTCYCLES_31_0 << 177*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPTHRESHOLDRST_0_THRESHOLDRSTCYCLES_31_0_LSB), 178*ca62d2e1SMarek Vasut .mp_threshold1 = 179*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPTHRESHOLDRST_1_THRESHOLDRSTCYCLES_63_32 << 180*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPTHRESHOLDRST_1_THRESHOLDRSTCYCLES_63_32_LSB), 181*ca62d2e1SMarek Vasut .mp_threshold2 = 182*ca62d2e1SMarek Vasut (CONFIG_HPS_SDR_CTRLCFG_MPTHRESHOLDRST_2_THRESHOLDRSTCYCLES_79_64 << 183*ca62d2e1SMarek Vasut SDR_CTRLGRP_MPTHRESHOLDRST_2_THRESHOLDRSTCYCLES_79_64_LSB), 184*ca62d2e1SMarek Vasut .phy_ctrl0 = CONFIG_HPS_SDR_CTRLCFG_PHYCTRL_PHYCTRL_0, 185*ca62d2e1SMarek Vasut }; 186*ca62d2e1SMarek Vasut 187*ca62d2e1SMarek Vasut static const struct socfpga_sdram_rw_mgr_config rw_mgr_config = { 188*ca62d2e1SMarek Vasut .activate_0_and_1 = RW_MGR_ACTIVATE_0_AND_1, 189*ca62d2e1SMarek Vasut .activate_0_and_1_wait1 = RW_MGR_ACTIVATE_0_AND_1_WAIT1, 190*ca62d2e1SMarek Vasut .activate_0_and_1_wait2 = RW_MGR_ACTIVATE_0_AND_1_WAIT2, 191*ca62d2e1SMarek Vasut .activate_1 = RW_MGR_ACTIVATE_1, 192*ca62d2e1SMarek Vasut .clear_dqs_enable = RW_MGR_CLEAR_DQS_ENABLE, 193*ca62d2e1SMarek Vasut .guaranteed_read = RW_MGR_GUARANTEED_READ, 194*ca62d2e1SMarek Vasut .guaranteed_read_cont = RW_MGR_GUARANTEED_READ_CONT, 195*ca62d2e1SMarek Vasut .guaranteed_write = RW_MGR_GUARANTEED_WRITE, 196*ca62d2e1SMarek Vasut .guaranteed_write_wait0 = RW_MGR_GUARANTEED_WRITE_WAIT0, 197*ca62d2e1SMarek Vasut .guaranteed_write_wait1 = RW_MGR_GUARANTEED_WRITE_WAIT1, 198*ca62d2e1SMarek Vasut .guaranteed_write_wait2 = RW_MGR_GUARANTEED_WRITE_WAIT2, 199*ca62d2e1SMarek Vasut .guaranteed_write_wait3 = RW_MGR_GUARANTEED_WRITE_WAIT3, 200*ca62d2e1SMarek Vasut .idle = RW_MGR_IDLE, 201*ca62d2e1SMarek Vasut .idle_loop1 = RW_MGR_IDLE_LOOP1, 202*ca62d2e1SMarek Vasut .idle_loop2 = RW_MGR_IDLE_LOOP2, 203*ca62d2e1SMarek Vasut .init_reset_0_cke_0 = RW_MGR_INIT_RESET_0_CKE_0, 204*ca62d2e1SMarek Vasut .init_reset_1_cke_0 = RW_MGR_INIT_RESET_1_CKE_0, 205*ca62d2e1SMarek Vasut .lfsr_wr_rd_bank_0 = RW_MGR_LFSR_WR_RD_BANK_0, 206*ca62d2e1SMarek Vasut .lfsr_wr_rd_bank_0_data = RW_MGR_LFSR_WR_RD_BANK_0_DATA, 207*ca62d2e1SMarek Vasut .lfsr_wr_rd_bank_0_dqs = RW_MGR_LFSR_WR_RD_BANK_0_DQS, 208*ca62d2e1SMarek Vasut .lfsr_wr_rd_bank_0_nop = RW_MGR_LFSR_WR_RD_BANK_0_NOP, 209*ca62d2e1SMarek Vasut .lfsr_wr_rd_bank_0_wait = RW_MGR_LFSR_WR_RD_BANK_0_WAIT, 210*ca62d2e1SMarek Vasut .lfsr_wr_rd_bank_0_wl_1 = RW_MGR_LFSR_WR_RD_BANK_0_WL_1, 211*ca62d2e1SMarek Vasut .lfsr_wr_rd_dm_bank_0 = RW_MGR_LFSR_WR_RD_DM_BANK_0, 212*ca62d2e1SMarek Vasut .lfsr_wr_rd_dm_bank_0_data = RW_MGR_LFSR_WR_RD_DM_BANK_0_DATA, 213*ca62d2e1SMarek Vasut .lfsr_wr_rd_dm_bank_0_dqs = RW_MGR_LFSR_WR_RD_DM_BANK_0_DQS, 214*ca62d2e1SMarek Vasut .lfsr_wr_rd_dm_bank_0_nop = RW_MGR_LFSR_WR_RD_DM_BANK_0_NOP, 215*ca62d2e1SMarek Vasut .lfsr_wr_rd_dm_bank_0_wait = RW_MGR_LFSR_WR_RD_DM_BANK_0_WAIT, 216*ca62d2e1SMarek Vasut .lfsr_wr_rd_dm_bank_0_wl_1 = RW_MGR_LFSR_WR_RD_DM_BANK_0_WL_1, 217*ca62d2e1SMarek Vasut .mrs0_dll_reset = RW_MGR_MRS0_DLL_RESET, 218*ca62d2e1SMarek Vasut .mrs0_dll_reset_mirr = RW_MGR_MRS0_DLL_RESET_MIRR, 219*ca62d2e1SMarek Vasut .mrs0_user = RW_MGR_MRS0_USER, 220*ca62d2e1SMarek Vasut .mrs0_user_mirr = RW_MGR_MRS0_USER_MIRR, 221*ca62d2e1SMarek Vasut .mrs1 = RW_MGR_MRS1, 222*ca62d2e1SMarek Vasut .mrs1_mirr = RW_MGR_MRS1_MIRR, 223*ca62d2e1SMarek Vasut .mrs2 = RW_MGR_MRS2, 224*ca62d2e1SMarek Vasut .mrs2_mirr = RW_MGR_MRS2_MIRR, 225*ca62d2e1SMarek Vasut .mrs3 = RW_MGR_MRS3, 226*ca62d2e1SMarek Vasut .mrs3_mirr = RW_MGR_MRS3_MIRR, 227*ca62d2e1SMarek Vasut .precharge_all = RW_MGR_PRECHARGE_ALL, 228*ca62d2e1SMarek Vasut .read_b2b = RW_MGR_READ_B2B, 229*ca62d2e1SMarek Vasut .read_b2b_wait1 = RW_MGR_READ_B2B_WAIT1, 230*ca62d2e1SMarek Vasut .read_b2b_wait2 = RW_MGR_READ_B2B_WAIT2, 231*ca62d2e1SMarek Vasut .refresh_all = RW_MGR_REFRESH_ALL, 232*ca62d2e1SMarek Vasut .rreturn = RW_MGR_RETURN, 233*ca62d2e1SMarek Vasut .sgle_read = RW_MGR_SGLE_READ, 234*ca62d2e1SMarek Vasut .zqcl = RW_MGR_ZQCL, 235*ca62d2e1SMarek Vasut 236*ca62d2e1SMarek Vasut .true_mem_data_mask_width = RW_MGR_TRUE_MEM_DATA_MASK_WIDTH, 237*ca62d2e1SMarek Vasut .mem_address_mirroring = RW_MGR_MEM_ADDRESS_MIRRORING, 238*ca62d2e1SMarek Vasut .mem_data_mask_width = RW_MGR_MEM_DATA_MASK_WIDTH, 239*ca62d2e1SMarek Vasut .mem_data_width = RW_MGR_MEM_DATA_WIDTH, 240*ca62d2e1SMarek Vasut .mem_dq_per_read_dqs = RW_MGR_MEM_DQ_PER_READ_DQS, 241*ca62d2e1SMarek Vasut .mem_dq_per_write_dqs = RW_MGR_MEM_DQ_PER_WRITE_DQS, 242*ca62d2e1SMarek Vasut .mem_if_read_dqs_width = RW_MGR_MEM_IF_READ_DQS_WIDTH, 243*ca62d2e1SMarek Vasut .mem_if_write_dqs_width = RW_MGR_MEM_IF_WRITE_DQS_WIDTH, 244*ca62d2e1SMarek Vasut .mem_number_of_cs_per_dimm = RW_MGR_MEM_NUMBER_OF_CS_PER_DIMM, 245*ca62d2e1SMarek Vasut .mem_number_of_ranks = RW_MGR_MEM_NUMBER_OF_RANKS, 246*ca62d2e1SMarek Vasut .mem_virtual_groups_per_read_dqs = 247*ca62d2e1SMarek Vasut RW_MGR_MEM_VIRTUAL_GROUPS_PER_READ_DQS, 248*ca62d2e1SMarek Vasut .mem_virtual_groups_per_write_dqs = 249*ca62d2e1SMarek Vasut RW_MGR_MEM_VIRTUAL_GROUPS_PER_WRITE_DQS, 250*ca62d2e1SMarek Vasut }; 251*ca62d2e1SMarek Vasut 252*ca62d2e1SMarek Vasut struct socfpga_sdram_io_config io_config = { 253*ca62d2e1SMarek Vasut .delay_per_dchain_tap = IO_DELAY_PER_DCHAIN_TAP, 254*ca62d2e1SMarek Vasut .delay_per_dqs_en_dchain_tap = IO_DELAY_PER_DQS_EN_DCHAIN_TAP, 255*ca62d2e1SMarek Vasut .delay_per_opa_tap = IO_DELAY_PER_OPA_TAP, 256*ca62d2e1SMarek Vasut .dll_chain_length = IO_DLL_CHAIN_LENGTH, 257*ca62d2e1SMarek Vasut .dqdqs_out_phase_max = IO_DQDQS_OUT_PHASE_MAX, 258*ca62d2e1SMarek Vasut .dqs_en_delay_max = IO_DQS_EN_DELAY_MAX, 259*ca62d2e1SMarek Vasut .dqs_en_delay_offset = IO_DQS_EN_DELAY_OFFSET, 260*ca62d2e1SMarek Vasut .dqs_en_phase_max = IO_DQS_EN_PHASE_MAX, 261*ca62d2e1SMarek Vasut .dqs_in_delay_max = IO_DQS_IN_DELAY_MAX, 262*ca62d2e1SMarek Vasut .dqs_in_reserve = IO_DQS_IN_RESERVE, 263*ca62d2e1SMarek Vasut .dqs_out_reserve = IO_DQS_OUT_RESERVE, 264*ca62d2e1SMarek Vasut .io_in_delay_max = IO_IO_IN_DELAY_MAX, 265*ca62d2e1SMarek Vasut .io_out1_delay_max = IO_IO_OUT1_DELAY_MAX, 266*ca62d2e1SMarek Vasut .io_out2_delay_max = IO_IO_OUT2_DELAY_MAX, 267*ca62d2e1SMarek Vasut .shift_dqs_en_when_shift_dqs = IO_SHIFT_DQS_EN_WHEN_SHIFT_DQS, 268*ca62d2e1SMarek Vasut }; 269*ca62d2e1SMarek Vasut 270*ca62d2e1SMarek Vasut struct socfpga_sdram_misc_config misc_config = { 271*ca62d2e1SMarek Vasut .afi_rate_ratio = AFI_RATE_RATIO, 272*ca62d2e1SMarek Vasut .calib_lfifo_offset = CALIB_LFIFO_OFFSET, 273*ca62d2e1SMarek Vasut .calib_vfifo_offset = CALIB_VFIFO_OFFSET, 274*ca62d2e1SMarek Vasut .enable_super_quick_calibration = ENABLE_SUPER_QUICK_CALIBRATION, 275*ca62d2e1SMarek Vasut .max_latency_count_width = MAX_LATENCY_COUNT_WIDTH, 276*ca62d2e1SMarek Vasut .read_valid_fifo_size = READ_VALID_FIFO_SIZE, 277*ca62d2e1SMarek Vasut .reg_file_init_seq_signature = REG_FILE_INIT_SEQ_SIGNATURE, 278*ca62d2e1SMarek Vasut .tinit_cntr0_val = TINIT_CNTR0_VAL, 279*ca62d2e1SMarek Vasut .tinit_cntr1_val = TINIT_CNTR1_VAL, 280*ca62d2e1SMarek Vasut .tinit_cntr2_val = TINIT_CNTR2_VAL, 281*ca62d2e1SMarek Vasut .treset_cntr0_val = TRESET_CNTR0_VAL, 282*ca62d2e1SMarek Vasut .treset_cntr1_val = TRESET_CNTR1_VAL, 283*ca62d2e1SMarek Vasut .treset_cntr2_val = TRESET_CNTR2_VAL, 284*ca62d2e1SMarek Vasut }; 285*ca62d2e1SMarek Vasut 286*ca62d2e1SMarek Vasut const struct socfpga_sdram_config *socfpga_get_sdram_config(void) 287*ca62d2e1SMarek Vasut { 288*ca62d2e1SMarek Vasut return &sdram_config; 289*ca62d2e1SMarek Vasut } 290*ca62d2e1SMarek Vasut 291*ca62d2e1SMarek Vasut void socfpga_get_seq_ac_init(const u32 **init, unsigned int *nelem) 292*ca62d2e1SMarek Vasut { 293*ca62d2e1SMarek Vasut *init = ac_rom_init; 294*ca62d2e1SMarek Vasut *nelem = ARRAY_SIZE(ac_rom_init); 295*ca62d2e1SMarek Vasut } 296*ca62d2e1SMarek Vasut 297*ca62d2e1SMarek Vasut void socfpga_get_seq_inst_init(const u32 **init, unsigned int *nelem) 298*ca62d2e1SMarek Vasut { 299*ca62d2e1SMarek Vasut *init = inst_rom_init; 300*ca62d2e1SMarek Vasut *nelem = ARRAY_SIZE(inst_rom_init); 301*ca62d2e1SMarek Vasut } 302*ca62d2e1SMarek Vasut 303*ca62d2e1SMarek Vasut const struct socfpga_sdram_rw_mgr_config *socfpga_get_sdram_rwmgr_config(void) 304*ca62d2e1SMarek Vasut { 305*ca62d2e1SMarek Vasut return &rw_mgr_config; 306*ca62d2e1SMarek Vasut } 307*ca62d2e1SMarek Vasut 308*ca62d2e1SMarek Vasut const struct socfpga_sdram_io_config *socfpga_get_sdram_io_config(void) 309*ca62d2e1SMarek Vasut { 310*ca62d2e1SMarek Vasut return &io_config; 311*ca62d2e1SMarek Vasut } 312*ca62d2e1SMarek Vasut 313*ca62d2e1SMarek Vasut const struct socfpga_sdram_misc_config *socfpga_get_sdram_misc_config(void) 314*ca62d2e1SMarek Vasut { 315*ca62d2e1SMarek Vasut return &misc_config; 316*ca62d2e1SMarek Vasut } 317