|
|
|
@ -87,6 +87,38 @@ static const struct emif_regs ddr2_emif_reg_data = { |
|
|
|
|
.emif_ddr_phy_ctlr_1 = DDR2_EMIF_READ_LATENCY, |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
static const struct ddr_data ddr3_data = { |
|
|
|
|
.datardsratio0 = DDR3_RD_DQS, |
|
|
|
|
.datawdsratio0 = DDR3_WR_DQS, |
|
|
|
|
.datafwsratio0 = DDR3_PHY_FIFO_WE, |
|
|
|
|
.datawrsratio0 = DDR3_PHY_WR_DATA, |
|
|
|
|
.datadldiff0 = PHY_DLL_LOCK_DIFF, |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
static const struct cmd_control ddr3_cmd_ctrl_data = { |
|
|
|
|
.cmd0csratio = DDR3_RATIO, |
|
|
|
|
.cmd0dldiff = DDR3_DLL_LOCK_DIFF, |
|
|
|
|
.cmd0iclkout = DDR3_INVERT_CLKOUT, |
|
|
|
|
|
|
|
|
|
.cmd1csratio = DDR3_RATIO, |
|
|
|
|
.cmd1dldiff = DDR3_DLL_LOCK_DIFF, |
|
|
|
|
.cmd1iclkout = DDR3_INVERT_CLKOUT, |
|
|
|
|
|
|
|
|
|
.cmd2csratio = DDR3_RATIO, |
|
|
|
|
.cmd2dldiff = DDR3_DLL_LOCK_DIFF, |
|
|
|
|
.cmd2iclkout = DDR3_INVERT_CLKOUT, |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
static struct emif_regs ddr3_emif_reg_data = { |
|
|
|
|
.sdram_config = DDR3_EMIF_SDCFG, |
|
|
|
|
.ref_ctrl = DDR3_EMIF_SDREF, |
|
|
|
|
.sdram_tim1 = DDR3_EMIF_TIM1, |
|
|
|
|
.sdram_tim2 = DDR3_EMIF_TIM2, |
|
|
|
|
.sdram_tim3 = DDR3_EMIF_TIM3, |
|
|
|
|
.zq_config = DDR3_ZQ_CFG, |
|
|
|
|
.emif_ddr_phy_ctlr_1 = DDR3_EMIF_READ_LATENCY, |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
static void config_vtp(void) |
|
|
|
|
{ |
|
|
|
|
writel(readl(&vtpreg->vtp0ctrlreg) | VTP_CTRL_ENABLE, |
|
|
|
@ -115,6 +147,15 @@ void config_ddr(short ddr_type) |
|
|
|
|
ddr_data = &ddr2_data; |
|
|
|
|
ioctrl_val = DDR2_IOCTRL_VALUE; |
|
|
|
|
emif_regs = &ddr2_emif_reg_data; |
|
|
|
|
} else if (ddr_type == EMIF_REG_SDRAM_TYPE_DDR3) { |
|
|
|
|
ddr_pll = 303; |
|
|
|
|
cmd_ctrl_data = &ddr3_cmd_ctrl_data; |
|
|
|
|
ddr_data = &ddr3_data; |
|
|
|
|
ioctrl_val = DDR3_IOCTRL_VALUE; |
|
|
|
|
emif_regs = &ddr3_emif_reg_data; |
|
|
|
|
} else { |
|
|
|
|
puts("Unknown memory type"); |
|
|
|
|
hang(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
enable_emif_clocks(); |
|
|
|
|