blob: be90ce9bff4ee31fe9ff01859fae43966b1d230b [file] [log] [blame]
Stefano Babic99d51c52017-07-26 18:23:05 +02001/*
2 * Copyright (C) Stefano Babic <sbabic@denx.de>
3 *
4 * SPDX-License-Identifier: GPL-2.0+
5 */
6
7
8#ifndef __PCM058_CONFIG_H
9#define __PCM058_CONFIG_H
10
11#include <config_distro_defaults.h>
12
13#ifdef CONFIG_SPL
14#define CONFIG_SPL_SPI_LOAD
15#define CONFIG_SYS_SPI_U_BOOT_OFFS (64 * 1024)
16#include "imx6_spl.h"
17#endif
18
19#include "mx6_common.h"
20
21/* Thermal */
22#define CONFIG_IMX_THERMAL
23
24/* Serial */
25#define CONFIG_MXC_UART
26#define CONFIG_MXC_UART_BASE UART4_BASE
27#define CONSOLE_DEV "ttymxc3"
28
29/* Early setup */
30#define CONFIG_DISPLAY_BOARDINFO_LATE
31
32
33/* Size of malloc() pool */
34#define CONFIG_SYS_MALLOC_LEN (8 * SZ_1M)
35
36/* Ethernet */
Stefano Babic99d51c52017-07-26 18:23:05 +020037#define CONFIG_MII
38#define IMX_FEC_BASE ENET_BASE_ADDR
39#define CONFIG_FEC_XCV_TYPE RGMII
40#define CONFIG_ETHPRIME "FEC"
41#define CONFIG_FEC_MXC_PHYADDR 3
42
Stefano Babic99d51c52017-07-26 18:23:05 +020043/* SPI Flash */
44#define CONFIG_MXC_SPI
45#define CONFIG_SF_DEFAULT_BUS 2
46#define CONFIG_SF_DEFAULT_CS 0
47#define CONFIG_SF_DEFAULT_SPEED 20000000
48#define CONFIG_SF_DEFAULT_MODE SPI_MODE_0
49
50/* I2C Configs */
51#define CONFIG_SYS_I2C
52#define CONFIG_SYS_I2C_MXC
53#define CONFIG_SYS_I2C_MXC_I2C1 /* enable I2C bus 0 */
54#define CONFIG_SYS_I2C_SPEED 100000
55
56#ifndef CONFIG_SPL_BUILD
57#define CONFIG_CMD_NAND
58/* Enable NAND support */
59#define CONFIG_CMD_NAND_TRIMFFS
60#define CONFIG_NAND_MXS
61#define CONFIG_SYS_MAX_NAND_DEVICE 1
62#define CONFIG_SYS_NAND_BASE 0x40000000
63#define CONFIG_SYS_NAND_5_ADDR_CYCLE
64#define CONFIG_SYS_NAND_ONFI_DETECTION
65#endif
66
67/* DMA stuff, needed for GPMI/MXS NAND support */
68#define CONFIG_APBH_DMA
69#define CONFIG_APBH_DMA_BURST
70#define CONFIG_APBH_DMA_BURST8
71
72/* Filesystem support */
73#define CONFIG_MTD_PARTITIONS
74#define CONFIG_MTD_DEVICE
75#define MTDIDS_DEFAULT "nand0=gpmi-nand"
76#define MTDPARTS_DEFAULT "mtdparts=gpmi-nand:-(nand);" \
77 "spi2.0:1024k(bootloader),64k(env1),64k(env2),-(rescue)"
78
79/* Various command support */
80
81/* Physical Memory Map */
82#define CONFIG_NR_DRAM_BANKS 1
83#define PHYS_SDRAM MMDC0_ARB_BASE_ADDR
84
85#define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM
86#define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR
87#define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE
88
89#define CONFIG_SYS_INIT_SP_OFFSET \
90 (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
91#define CONFIG_SYS_INIT_SP_ADDR \
92 (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
93
94/* MMC Configs */
95#define CONFIG_SYS_FSL_ESDHC_ADDR 0
96#define CONFIG_SYS_FSL_USDHC_NUM 2
97
98/* Environment organization */
99#define CONFIG_ENV_IS_IN_SPI_FLASH
100#define CONFIG_ENV_SIZE (16 * 1024)
101#define CONFIG_ENV_OFFSET (1024 * SZ_1K)
102#define CONFIG_ENV_SECT_SIZE (64 * SZ_1K)
103#define CONFIG_ENV_SPI_BUS CONFIG_SF_DEFAULT_BUS
104#define CONFIG_ENV_SPI_CS CONFIG_SF_DEFAULT_CS
105#define CONFIG_ENV_SPI_MODE CONFIG_SF_DEFAULT_MODE
106#define CONFIG_ENV_SPI_MAX_HZ CONFIG_SF_DEFAULT_SPEED
107#define CONFIG_SYS_REDUNDAND_ENVIRONMENT
108#define CONFIG_ENV_OFFSET_REDUND (CONFIG_ENV_OFFSET + \
109 CONFIG_ENV_SECT_SIZE)
110#define CONFIG_ENV_SIZE_REDUND CONFIG_ENV_SIZE
111
112#ifdef CONFIG_ENV_IS_IN_NAND
113#define CONFIG_ENV_OFFSET (0x1E0000)
114#define CONFIG_ENV_SECT_SIZE (128 * SZ_1K)
115#endif
116
117/* Default environment */
118#define CONFIG_EXTRA_ENV_SETTINGS \
119 "addcons=setenv bootargs ${bootargs} " \
120 "console=${console},${baudrate}\0" \
121 "addip=setenv bootargs ${bootargs} " \
122 "ip=${ipaddr}:${serverip}:${gatewayip}:" \
123 "${netmask}:${hostname}:${netdev}:off\0" \
124 "addmisc=setenv bootargs ${bootargs} ${miscargs}\0" \
125 "addmtd=run mtdnand;run mtdspi;" \
126 "setenv bootargs ${bootargs} ${mtdparts}\0" \
127 "mtdnand=setenv mtdparts mtdparts=gpmi-nand:" \
128 "40m(Kernels),400m(root),-(nand)\0" \
129 "mtdspi=setenv mtdparts ${mtdparts}" \
130 "';spi2.0:1024k(bootloader)," \
131 "64k(env1),64k(env2),-(rescue)'\0" \
132 "bootcmd=if test -n ${rescue};" \
133 "then run swupdate;fi;run nandboot;run swupdate\0" \
134 "bootfile=uImage\0" \
135 "bootimage=uImage\0" \
136 "console=ttymxc3\0" \
137 "fdt_addr_r=0x18000000\0" \
138 "fdt_file=pfla02.dtb\0" \
139 "fdt_high=0xffffffff\0" \
140 "initrd_high=0xffffffff\0" \
141 "kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \
142 "miscargs=panic=1 quiet\0" \
143 "mmcargs=setenv bootargs root=${mmcroot} rw rootwait\0" \
144 "mmcboot=if run mmcload;then " \
145 "run mmcargs addcons addmisc;" \
146 "bootm;fi\0" \
147 "mmcload=mmc rescan;" \
148 "load mmc 0:${mmcpart} ${kernel_addr_r} boot/fitImage\0"\
149 "mmcpart=1\0" \
150 "mmcroot=/dev/mmcblk0p1\0" \
151 "ubiroot=1\0" \
152 "nandargs=setenv bootargs ubi.mtd=1 " \
153 "root=ubi0:rootfs${ubiroot} rootfstype=ubifs\0" \
154 "nandboot=run mtdnand;ubi part nand0,0;" \
155 "ubi readvol ${kernel_addr_r} kernel${ubiroot};" \
156 "run nandargs addip addcons addmtd addmisc;" \
157 "bootm ${kernel_addr_r}\0" \
158 "net_nfs=tftp ${kernel_addr_r} ${board_name}/${bootfile};" \
159 "tftp ${fdt_addr_r} ${board_name}/${fdt_file};" \
160 "run nfsargs addip addcons addmtd addmisc;" \
161 "bootm ${kernel_addr_r} - ${fdt_addr_r}\0" \
162 "net_nfs_fit=tftp ${kernel_addr_r} ${board_name}/${fitfile};" \
163 "run nfsargs addip addcons addmtd addmisc;" \
164 "bootm ${kernel_addr_r}\0" \
165 "nfsargs=setenv bootargs root=/dev/nfs" \
166 " nfsroot=${serverip}:${nfsroot},v3 panic=1\0" \
167 "swupdate=setenv bootargs root=/dev/ram;" \
168 "run addip addcons addmtd addmisc;" \
169 "sf probe;" \
170 "sf read ${kernel_addr_r} 120000 600000;" \
171 "sf read 14000000 730000 800000;" \
172 "bootm ${kernel_addr_r} 14000000\0"
173
174#endif