blob: f19c66822d209bad38c6c8b829f2f621ec9ff2b5 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Chandan Nath62d7fe7c2011-10-14 02:58:24 +00002/*
3 * emif4.c
4 *
5 * AM33XX emif4 configuration file
6 *
Nishanth Menona94a4072023-11-01 15:56:03 -05007 * Copyright (C) 2011, Texas Instruments, Incorporated - https://www.ti.com/
Chandan Nath62d7fe7c2011-10-14 02:58:24 +00008 */
9
Chandan Nath62d7fe7c2011-10-14 02:58:24 +000010#include <asm/arch/cpu.h>
11#include <asm/arch/ddr_defs.h>
12#include <asm/arch/hardware.h>
13#include <asm/arch/clock.h>
Tom Rinib971dfa2012-07-03 09:20:06 -070014#include <asm/arch/sys_proto.h>
Chandan Nath62d7fe7c2011-10-14 02:58:24 +000015#include <asm/io.h>
Tom Rinifda35eb2012-07-03 08:51:34 -070016#include <asm/emif.h>
Chandan Nath62d7fe7c2011-10-14 02:58:24 +000017
Matt Porter3ba65f92013-03-15 10:07:03 +000018static struct vtp_reg *vtpreg[2] = {
19 (struct vtp_reg *)VTP0_CTRL_ADDR,
20 (struct vtp_reg *)VTP1_CTRL_ADDR};
21#ifdef CONFIG_AM33XX
Tom Rini942d3f02012-07-30 14:13:16 -070022static struct ddr_ctrl *ddrctrl = (struct ddr_ctrl *)DDR_CTRL_ADDR;
Matt Porter3ba65f92013-03-15 10:07:03 +000023#endif
Lokesh Vutlad3daba12013-12-10 15:02:22 +053024#ifdef CONFIG_AM43XX
25static struct ddr_ctrl *ddrctrl = (struct ddr_ctrl *)DDR_CTRL_ADDR;
26static struct cm_device_inst *cm_device =
27 (struct cm_device_inst *)CM_DEVICE_INST;
28#endif
Tom Rini942d3f02012-07-30 14:13:16 -070029
Matt Porter3ba65f92013-03-15 10:07:03 +000030static void config_vtp(int nr)
Chandan Nath62d7fe7c2011-10-14 02:58:24 +000031{
Matt Porter3ba65f92013-03-15 10:07:03 +000032 writel(readl(&vtpreg[nr]->vtp0ctrlreg) | VTP_CTRL_ENABLE,
33 &vtpreg[nr]->vtp0ctrlreg);
34 writel(readl(&vtpreg[nr]->vtp0ctrlreg) & (~VTP_CTRL_START_EN),
35 &vtpreg[nr]->vtp0ctrlreg);
36 writel(readl(&vtpreg[nr]->vtp0ctrlreg) | VTP_CTRL_START_EN,
37 &vtpreg[nr]->vtp0ctrlreg);
Chandan Nath62d7fe7c2011-10-14 02:58:24 +000038
39 /* Poll for READY */
Matt Porter3ba65f92013-03-15 10:07:03 +000040 while ((readl(&vtpreg[nr]->vtp0ctrlreg) & VTP_CTRL_READY) !=
Chandan Nath62d7fe7c2011-10-14 02:58:24 +000041 VTP_CTRL_READY)
42 ;
43}
44
Lokesh Vutla94d77fb2013-07-30 10:48:52 +053045void __weak ddr_pll_config(unsigned int ddrpll_m)
46{
47}
48
Lokesh Vutla965de8b2013-12-10 15:02:21 +053049void config_ddr(unsigned int pll, const struct ctrl_ioregs *ioregs,
Peter Korsgaardc00f69d2012-10-18 01:21:12 +000050 const struct ddr_data *data, const struct cmd_control *ctrl,
Matt Porter3ba65f92013-03-15 10:07:03 +000051 const struct emif_regs *regs, int nr)
Chandan Nath62d7fe7c2011-10-14 02:58:24 +000052{
Peter Korsgaardc00f69d2012-10-18 01:21:12 +000053 ddr_pll_config(pll);
Matt Porter3ba65f92013-03-15 10:07:03 +000054 config_vtp(nr);
55 config_cmd_ctrl(ctrl, nr);
Tom Rini318f27c2012-07-30 14:13:56 -070056
Matt Porter3ba65f92013-03-15 10:07:03 +000057 config_ddr_data(data, nr);
58#ifdef CONFIG_AM33XX
Lokesh Vutla965de8b2013-12-10 15:02:21 +053059 config_io_ctrl(ioregs);
Tom Rini318f27c2012-07-30 14:13:56 -070060
61 /* Set CKE to be controlled by EMIF/DDR PHY */
62 writel(DDR_CKE_CTRL_NORMAL, &ddrctrl->ddrckectrl);
James Doublesinfc46bae2014-12-22 16:26:11 -060063
Matt Porter3ba65f92013-03-15 10:07:03 +000064#endif
Lokesh Vutlad3daba12013-12-10 15:02:22 +053065#ifdef CONFIG_AM43XX
66 writel(readl(&cm_device->cm_dll_ctrl) & ~0x1, &cm_device->cm_dll_ctrl);
Jeroen Hofstee878cae62014-06-18 21:22:35 +020067 while ((readl(&cm_device->cm_dll_ctrl) & CM_DLL_READYST) == 0)
Lokesh Vutlad3daba12013-12-10 15:02:22 +053068 ;
Lokesh Vutlad3daba12013-12-10 15:02:22 +053069
70 config_io_ctrl(ioregs);
71
72 /* Set CKE to be controlled by EMIF/DDR PHY */
73 writel(DDR_CKE_CTRL_NORMAL, &ddrctrl->ddrckectrl);
James Doublesinfc46bae2014-12-22 16:26:11 -060074
Tom Rini7c352cd2015-06-05 15:51:11 +053075 if (emif_sdram_type(regs->sdram_config) == EMIF_SDRAM_TYPE_DDR3)
Dave Gerlache18945a2018-03-17 13:24:30 +053076#ifndef CONFIG_SPL_RTC_DDR_SUPPORT
Tom Rini7c352cd2015-06-05 15:51:11 +053077 /* Allow EMIF to control DDR_RESET */
78 writel(0x00000000, &ddrctrl->ddrioctrl);
Dave Gerlache18945a2018-03-17 13:24:30 +053079#else
80 /* Override EMIF DDR_RESET control */
81 writel(0x80000000, &ddrctrl->ddrioctrl);
82#endif /* CONFIG_SPL_RTC_DDR_SUPPORT */
Lokesh Vutlad3daba12013-12-10 15:02:22 +053083#endif
84
Tom Rini318f27c2012-07-30 14:13:56 -070085 /* Program EMIF instance */
Matt Porter3ba65f92013-03-15 10:07:03 +000086 config_ddr_phy(regs, nr);
87 set_sdram_timings(regs, nr);
Lokesh Vutlad3daba12013-12-10 15:02:22 +053088 if (get_emif_rev(EMIF1_BASE) == EMIF_4D5)
89 config_sdram_emif4d5(regs, nr);
90 else
91 config_sdram(regs, nr);
Chandan Nath62d7fe7c2011-10-14 02:58:24 +000092}