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