| /* |
| * Copyright (C) 2015-2016 Stefan Roese <sr@denx.de> |
| * |
| * SPDX-License-Identifier: GPL-2.0+ |
| * |
| * Refer doc/README.imximage for more details about how-to configure |
| * and create imximage boot image |
| * |
| * The syntax is taken as close as possible with the kwbimage |
| */ |
| |
| /* image version */ |
| |
| IMAGE_VERSION 2 |
| |
| /* |
| * Boot Device : one of |
| * sd, nand |
| */ |
| BOOT_FROM sd |
| |
| /* |
| * Device Configuration Data (DCD) |
| * |
| * Each entry must have the format: |
| * Addr-type Address Value |
| * |
| * where: |
| * Addr-type register length (1,2 or 4 bytes) |
| * Address absolute address of the register |
| * value value to be stored in the register |
| */ |
| |
| #define __ASSEMBLY__ |
| #include <config.h> |
| |
| /* Enable all clocks */ |
| DATA 4 0x020c4068 0xffffffff |
| DATA 4 0x020c406c 0xffffffff |
| DATA 4 0x020c4070 0xffffffff |
| DATA 4 0x020c4074 0xffffffff |
| DATA 4 0x020c4078 0xffffffff |
| DATA 4 0x020c407c 0xffffffff |
| DATA 4 0x020c4080 0xffffffff |
| DATA 4 0x020c4084 0xffffffff |
| |
| /* ddr io type */ |
| DATA 4 0x020e04b4 0x000C0000 /* IOMUXC_SW_PAD_CTL_GRP_DDR_TYPE */ |
| DATA 4 0x020e04ac 0x00000000 /* IOMUXC_SW_PAD_CTL_GRP_DDRPKE */ |
| |
| /* clock */ |
| DATA 4 0x020e027c 0x00000030 /* IOMUXC_SW_PAD_CTL_PAD_DRAM_SDCLK0_P */ |
| |
| /* control and address */ |
| DATA 4 0x020E0250 0x00000030 /* IOMUXC_SW_PAD_CTL_PAD_DRAM_CAS */ |
| DATA 4 0x020E024C 0x00000030 /* IOMUXC_SW_PAD_CTL_PAD_DRAM_RAS */ |
| DATA 4 0x020E0490 0x00000030 /* IOMUXC_SW_PAD_CTL_GRP_ADDDS */ |
| DATA 4 0x020E0288 0x00000030 /* IOMUXC_SW_PAD_CTL_PAD_DRAM_RESET */ |
| DATA 4 0x020E0270 0x00000000 /* IOMUXC_SW_PAD_CTL_PAD_DRAM_SDBA2 - DSE can be |
| configured using Group Control Register: |
| IOMUXC_SW_PAD_CTL_GRP_CTLDS */ |
| DATA 4 0x020E0260 0x00000030 /* IOMUXC_SW_PAD_CTL_PAD_DRAM_ODT0 */ |
| DATA 4 0x020E0264 0x00000030 /* IOMUXC_SW_PAD_CTL_PAD_DRAM_ODT1 */ |
| DATA 4 0x020E04A0 0x00000030 /* IOMUXC_SW_PAD_CTL_GRP_CTLDS */ |
| |
| /* data strobes */ |
| DATA 4 0x020e0494 0x00020000 /* IOMUXC_SW_PAD_CTL_GRP_DDRMODE_CTL */ |
| DATA 4 0x020e0280 0x00000030 /* IOMUXC_SW_PAD_CTL_PAD_DRAM_SDQS0_P */ |
| DATA 4 0x020e0284 0x00000030 /* IOMUXC_SW_PAD_CTL_PAD_DRAM_SDQS1_P */ |
| |
| /* data */ |
| DATA 4 0x020E04B0 0x00020000 /* IOMUXC_SW_PAD_CTL_GRP_DDRMODE */ |
| DATA 4 0x020E0498 0x00000030 /* IOMUXC_SW_PAD_CTL_GRP_B0DS */ |
| DATA 4 0x020E04A4 0x00000030 /* IOMUXC_SW_PAD_CTL_GRP_B1DS */ |
| DATA 4 0x020E0244 0x00000030 /* IOMUXC_SW_PAD_CTL_PAD_DRAM_DQM0 */ |
| DATA 4 0x020E0248 0x00000030 /* IOMUXC_SW_PAD_CTL_PAD_DRAM_DQM1 */ |
| |
| /* |
| * DDR Controller Registers |
| * |
| * Manufacturer: IM |
| * Device Part Number: IME1G16D3EEBG-15EI |
| * Clock Freq.: 400MHz |
| * Density per CS in Gb: 1 |
| * Chip Selects used: 1 |
| * Number of Banks: 8 |
| * Row address: 13 |
| * Column address: 10 |
| * Data bus width 16 |
| */ |
| DATA 4 0x021b001c 0x00008000 /* MMDC0_MDSCR, set the Configuration request bit |
| during MMDC set up */ |
| |
| /* |
| * Calibration setup |
| */ |
| DATA 4 0x021b0800 0xA1390003 /* DDR_PHY_P0_MPZQHWCTRL, enable both one-time & |
| periodic HW ZQ calibration. */ |
| |
| /* |
| * For target board, may need to run write leveling calibration to fine tune |
| * these settings. |
| */ |
| DATA 4 0x021b080c 0x00000000 |
| |
| /* Read DQS Gating calibration */ |
| DATA 4 0x021b083c 0x4164015C /* MPDGCTRL0 PHY0 */ |
| |
| /* Read calibration */ |
| DATA 4 0x021b0848 0x40404446 /* MPRDDLCTL PHY0 */ |
| |
| /* Write calibration */ |
| DATA 4 0x021b0850 0x40405A52 /* MPWRDLCTL PHY0 */ |
| |
| /* |
| * read data bit delay: (3 is the reccommended default value, although out of |
| * reset value is 0) |
| */ |
| DATA 4 0x021b081c 0x33333333 /* DDR_PHY_P0_MPREDQBY0DL3 */ |
| DATA 4 0x021b0820 0x33333333 /* DDR_PHY_P0_MPREDQBY1DL3 */ |
| DATA 4 0x021b082c 0xF3333333 |
| DATA 4 0x021b0830 0xF3333333 |
| |
| DATA 4 0x021b08c0 0x00921012 |
| |
| /* Clock Fine Tuning */ |
| DATA 4 0x021B0858 0x00000F00 /* [MMDC_MPSDCTRL] MMDC PHY CK Control Register */ |
| |
| /* Complete calibration by forced measurement: */ |
| DATA 4 0x021b08b8 0x00000800 /* DDR_PHY_P0_MPMUR0, frc_msr */ |
| /* |
| * Calibration setup end |
| */ |
| |
| /* MMDC init: */ |
| DATA 4 0x021b0004 0x0002002D /* MMDC0_MDPDC */ |
| DATA 4 0x021b0008 0x1B333030 /* MMDC0_MDOTC */ |
| DATA 4 0x021b000c 0x3F4352F3 /* MMDC0_MDCFG0 */ |
| DATA 4 0x021b0010 0xB66D0B63 /* MMDC0_MDCFG1 */ |
| DATA 4 0x021b0014 0x01FF00DB /* MMDC0_MDCFG2 */ |
| |
| /* |
| * MDMISC: RALAT kept to the high level of 5. |
| * MDMISC: consider reducing RALAT if your 528MHz board design allow that. |
| * Lower RALAT benefits: |
| * a. better operation at low frequency, for LPDDR2 freq < 100MHz, change RALAT |
| * to 3 |
| * b. Small performence improvment |
| */ |
| DATA 4 0x021b0018 0x00201740 /* MMDC0_MDMISC */ |
| |
| DATA 4 0x021b001c 0x00008000 /* MMDC0_MDSCR, set the Configuration request bit |
| during MMDC set up */ |
| |
| DATA 4 0x021b002c 0x000026D2 /* MMDC0_MDRWD */ |
| DATA 4 0x021b0030 0x00431023 /* MMDC0_MDOR */ |
| DATA 4 0x021b0040 0x00000047 /* Chan0 CS0_END */ |
| DATA 4 0x021b0000 0x82180000 /* MMDC0_MDCTL */ |
| |
| /* Mode register writes */ |
| DATA 4 0x021b001c 0x02008032 /* MMDC0_MDSCR, MR2 write, CS0 */ |
| DATA 4 0x021b001c 0x00008033 /* MMDC0_MDSCR, MR3 write, CS0 */ |
| DATA 4 0x021b001c 0x00048031 /* MMDC0_MDSCR, MR1 write, CS0 */ |
| DATA 4 0x021b001c 0x15208030 /* MMDC0_MDSCR, MR0 write, CS0 */ |
| DATA 4 0x021b001c 0x04008040 /* MMDC0_MDSCR, ZQ calibration command sent to |
| device on CS0 */ |
| |
| DATA 4 0x021b0020 0x00000800 /* MMDC0_MDREF */ |
| DATA 4 0x021b0818 0x00000227 /* DDR_PHY_P0_MPODTCTRL */ |
| DATA 4 0x021b0004 0x0002556D /* MMDC0_MDPDC now SDCTL power down enabled */ |
| DATA 4 0x021b0404 0x00011006 /* MMDC0_MAPSR ADOPT power down enabled, MMDC will |
| enter automatically to self-refresh while the |
| number of idle cycle reached. */ |
| DATA 4 0x021b001c 0x00000000 /* MMDC0_MDSCR, clear this register (especially |
| the configuration bit as initialization is |
| complete) */ |