1*a02d517bSMax Krummenacher/*
2*a02d517bSMax Krummenacher * Copyright (C) 2013 Boundary Devices
3*a02d517bSMax Krummenacher * Copyright (C) 2014-2016, Toradex AG
4*a02d517bSMax Krummenacher *
5*a02d517bSMax Krummenacher * SPDX-License-Identifier:	GPL-2.0+
6*a02d517bSMax Krummenacher */
7*a02d517bSMax Krummenacher
8*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDPDC, 0x0002002D
9*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDCFG0, 0x2C305503
10*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDCFG1, 0xB66D8D63
11*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDCFG2, 0x01FF00DB
12*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDRWD, 0x000026D2
13*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDOR, 0x00301023
14*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDOTC, 0x00333030
15*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDPDC, 0x0002556D
16*a02d517bSMax Krummenacher/* CS0 End: 7MSB of ((0x10000000 + 512M) -1) >> 25 */
17*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDASP, 0x00000017
18*a02d517bSMax Krummenacher/* DDR3 DATA BUS SIZE: 64BIT */
19*a02d517bSMax Krummenacher/* DATA 4, MX6_MMDC_P0_MDCTL, 0x821A0000 */
20*a02d517bSMax Krummenacher/* DDR3 DATA BUS SIZE: 32BIT */
21*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDCTL, 0x82190000
22*a02d517bSMax Krummenacher
23*a02d517bSMax Krummenacher/* Write commands to DDR */
24*a02d517bSMax Krummenacher/* Load Mode Registers */
25*a02d517bSMax Krummenacher/* TODO Use Auto Self-Refresh mode (Extended Temperature)*/
26*a02d517bSMax Krummenacher/* DATA 4, MX6_MMDC_P0_MDSCR, 0x04408032 */
27*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDSCR, 0x04008032
28*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDSCR, 0x00008033
29*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDSCR, 0x00048031
30*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDSCR, 0x13208030
31*a02d517bSMax Krummenacher/* ZQ calibration */
32*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDSCR, 0x04008040
33*a02d517bSMax Krummenacher
34*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MPZQHWCTRL, 0xA1390003
35*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P1_MPZQHWCTRL, 0xA1390003
36*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDREF, 0x00005800
37*a02d517bSMax Krummenacher
38*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MPODTCTRL, 0x00000000
39*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P1_MPODTCTRL, 0x00000000
40*a02d517bSMax Krummenacher
41*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MPDGCTRL0, 0x42360232
42*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MPDGCTRL1, 0x021F022A
43*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P1_MPDGCTRL0, 0x421E0224
44*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P1_MPDGCTRL1, 0x02110218
45*a02d517bSMax Krummenacher
46*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MPRDDLCTL, 0x41434344
47*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P1_MPRDDLCTL, 0x4345423E
48*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MPWRDLCTL, 0x39383339
49*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P1_MPWRDLCTL, 0x3E363930
50*a02d517bSMax Krummenacher
51*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MPWLDECTRL0, 0x00340039
52*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MPWLDECTRL1, 0x002C002D
53*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P1_MPWLDECTRL0, 0x00120019
54*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P1_MPWLDECTRL1, 0x0012002D
55*a02d517bSMax Krummenacher
56*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MPMUR0, 0x00000800
57*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P1_MPMUR0, 0x00000800
58*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MDSCR, 0x00000000
59*a02d517bSMax KrummenacherDATA 4, MX6_MMDC_P0_MAPSR, 0x00011006
60