blob: 1478ea844e17e43f75c5936957208a4d74e382a2 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +05302/*
Marcel Ziswiler510c2dd2019-03-25 17:25:01 +01003 * Copyright 2015-2019 Toradex, Inc.
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +05304 *
Marcel Ziswilerd92dee52016-11-16 17:49:23 +01005 * Configuration settings for the Toradex VF50/VF61 modules.
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +05306 *
7 * Based on vf610twr.h:
8 * Copyright 2013 Freescale Semiconductor, Inc.
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +05309 */
10
11#ifndef __CONFIG_H
12#define __CONFIG_H
13
14#include <asm/arch/imx-regs.h>
Marcel Ziswiler2e3b3d52019-03-25 17:25:02 +010015#include <linux/sizes.h>
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053016
Gong Qianyu52de2e52015-10-26 19:47:42 +080017#define CONFIG_SYS_FSL_CLK
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053018
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053019#define CONFIG_SKIP_LOWLEVEL_INIT
20
Stefan Agner13011752017-04-11 11:12:14 +053021#ifdef CONFIG_VIDEO_FSL_DCU_FB
Stefan Agner13011752017-04-11 11:12:14 +053022#define CONFIG_SPLASH_SCREEN_ALIGN
23#define CONFIG_VIDEO_LOGO
24#define CONFIG_VIDEO_BMP_LOGO
25#define CONFIG_SYS_FSL_DCU_LE
26
27#define CONFIG_SYS_DCU_ADDR DCU0_BASE_ADDR
28#define DCU_LAYER_MAX_NUM 64
29#endif
30
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053031/* Size of malloc() pool */
Marcel Ziswiler2e3b3d52019-03-25 17:25:02 +010032#define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + 2 * SZ_1M)
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053033
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053034/* Allow to overwrite serial and ethaddr */
35#define CONFIG_ENV_OVERWRITE
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053036
37/* NAND support */
Stefan Agner4ce682a2015-05-08 19:07:13 +020038#define CONFIG_SYS_NAND_ONFI_DETECTION
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053039#define CONFIG_SYS_MAX_NAND_DEVICE 1
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053040
41#define CONFIG_IPADDR 192.168.10.2
42#define CONFIG_NETMASK 255.255.255.0
43#define CONFIG_SERVERIP 192.168.10.1
44
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053045#define CONFIG_LOADADDR 0x80008000
46#define CONFIG_FDTADDR 0x84000000
47
48/* We boot from the gfxRAM area of the OCRAM. */
Stefan Agner1faaa3c2017-10-17 13:59:19 +020049#define CONFIG_BOARD_SIZE_LIMIT 520192
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053050
Stefan Agnerc0594832019-03-25 17:25:03 +010051#define MEM_LAYOUT_ENV_SETTINGS \
52 "bootm_size=0x10000000\0" \
53 "fdt_addr_r=0x82000000\0" \
54 "fdt_high=0xffffffff\0" \
55 "initrd_high=0xffffffff\0" \
56 "kernel_addr_r=0x81000000\0" \
57 "pxefile_addr_r=0x87100000\0" \
58 "ramdisk_addr_r=0x82100000\0" \
59 "scriptaddr=0x87000000\0"
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053060
Igor Opaniukaf80e152019-12-09 12:33:32 +020061#define UBOOT_UPDATE \
62 "update_uboot=nand erase.part u-boot && " \
63 "nand write ${loadaddr} u-boot ${filesize}\0" \
64
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053065#define NFS_BOOTCMD \
66 "nfsargs=ip=:::::eth0: root=/dev/nfs\0" \
67 "nfsboot=run setup; " \
68 "setenv bootargs ${defargs} ${nfsargs} ${mtdparts} " \
69 "${setupargs} ${vidargs}; echo Booting from NFS...;" \
70 "dhcp ${kernel_addr_r} && " \
71 "tftp ${fdt_addr_r} ${soc}-colibri-${fdt_board}.dtb && " \
Sanchayan Maitya48b4272016-12-02 14:28:27 +053072 "run fdt_fixup && bootz ${kernel_addr_r} - ${fdt_addr_r}\0" \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053073
Stefan Agnerc0594832019-03-25 17:25:03 +010074#define SD_BOOTCMD \
Igor Opaniuk81a87562019-05-29 13:00:41 +030075 "set_sdargs=setenv sdargs root=PARTUUID=${uuid} ro rootwait\0" \
76 "sdboot=run setup; run sdfinduuid; run set_sdargs; " \
77 "setenv bootargs ${defargs} ${sdargs} ${mtdparts} " \
Stefan Agnerc0594832019-03-25 17:25:03 +010078 "${setupargs} ${vidargs}; echo Booting from MMC/SD card...; " \
Igor Opaniuk81a87562019-05-29 13:00:41 +030079 "load mmc ${sddev}:${sdbootpart} ${kernel_addr_r} ${kernel_file} && " \
80 "load mmc ${sddev}:${sdbootpart} ${fdt_addr_r} " \
81 "${soc}-colibri-${fdt_board}.dtb && " \
Stefan Agnerc0594832019-03-25 17:25:03 +010082 "run fdt_fixup && bootz ${kernel_addr_r} - ${fdt_addr_r}\0" \
Igor Opaniuk81a87562019-05-29 13:00:41 +030083 "sdbootpart=1\0" \
84 "sddev=0\0" \
85 "sdfinduuid=part uuid mmc ${sddev}:${sdrootpart} uuid\0" \
86 "sdrootpart=2\0"
87
Stefan Agnerc0594832019-03-25 17:25:03 +010088
89#define UBI_BOOTCMD \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053090 "ubiargs=ubi.mtd=ubi root=ubi0:rootfs rootfstype=ubifs " \
91 "ubi.fm_autoconvert=1\0" \
92 "ubiboot=run setup; " \
93 "setenv bootargs ${defargs} ${ubiargs} ${mtdparts} " \
94 "${setupargs} ${vidargs}; echo Booting from NAND...; " \
Sanchayan Maity27e4e102016-11-25 16:19:17 +053095 "ubi part ubi && " \
96 "ubi read ${kernel_addr_r} kernel && " \
97 "ubi read ${fdt_addr_r} dtb && " \
Sanchayan Maitya48b4272016-12-02 14:28:27 +053098 "run fdt_fixup && bootz ${kernel_addr_r} - ${fdt_addr_r}\0" \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053099
Stefan Agner7f411a52019-03-25 17:25:04 +0100100#define CONFIG_BOOTCOMMAND "run ubiboot; " \
101 "setenv fdtfile ${soc}-colibri-${fdt_board}.dtb && run distro_bootcmd;"
Stefan Agnerc0594832019-03-25 17:25:03 +0100102
103#define BOOT_TARGET_DEVICES(func) \
104 func(MMC, mmc, 0) \
105 func(USB, usb, 0) \
106 func(DHCP, dhcp, na)
107#include <config_distro_bootcmd.h>
108#undef BOOTENV_RUN_NET_USB_START
109#define BOOTENV_RUN_NET_USB_START ""
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530110
Sanchayan Maity7755e532015-04-17 18:56:42 +0530111#define DFU_ALT_NAND_INFO "vf-bcb part 0,1;u-boot part 0,2;ubi part 0,4"
112
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530113#define CONFIG_EXTRA_ENV_SETTINGS \
Stefan Agnerc0594832019-03-25 17:25:03 +0100114 BOOTENV \
115 MEM_LAYOUT_ENV_SETTINGS \
116 NFS_BOOTCMD \
117 SD_BOOTCMD \
118 UBI_BOOTCMD \
Igor Opaniukaf80e152019-12-09 12:33:32 +0200119 UBOOT_UPDATE \
Stefan Agnerc0594832019-03-25 17:25:03 +0100120 "console=ttyLP0\0" \
Stefan Agnerb093f0f2019-03-25 17:25:07 +0100121 "defargs=user_debug=30\0" \
Stefan Agnerc0594832019-03-25 17:25:03 +0100122 "dfu_alt_info=" DFU_ALT_NAND_INFO "\0" \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530123 "fdt_board=eval-v3\0" \
Sanchayan Maitya48b4272016-12-02 14:28:27 +0530124 "fdt_fixup=;\0" \
Stefan Agnerc0594832019-03-25 17:25:03 +0100125 "kernel_file=zImage\0" \
126 "mtdparts=" CONFIG_MTDPARTS_DEFAULT "\0" \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530127 "setsdupdate=mmc rescan && set interface mmc && " \
Stefan Agnerc0594832019-03-25 17:25:03 +0100128 "fatload ${interface} 0:1 ${loadaddr} flash_blk.img && " \
129 "source ${loadaddr}\0" \
130 "setup=setenv setupargs console=tty1 console=${console}" \
131 ",${baudrate}n8 ${memargs}\0" \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530132 "setupdate=run setsdupdate || run setusbupdate\0" \
Stefan Agnerc0594832019-03-25 17:25:03 +0100133 "setusbupdate=usb start && set interface usb && " \
134 "fatload ${interface} 0:1 ${loadaddr} flash_blk.img && " \
135 "source ${loadaddr}\0" \
Stefan Agner13011752017-04-11 11:12:14 +0530136 "splashpos=m,m\0" \
Stefan Agnerc0594832019-03-25 17:25:03 +0100137 "video-mode=dcufb:640x480-16@60,monitor=lcd\0"
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530138
139/* Miscellaneous configurable options */
Sanchayan Maity0d92de42015-06-08 12:40:41 +0530140#define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530141#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
142
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530143#define CONFIG_SYS_MEMTEST_START 0x80010000
144#define CONFIG_SYS_MEMTEST_END 0x87C00000
145
146#define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
147#define CONFIG_SYS_HZ 1000
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530148
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530149/* Physical memory map */
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530150#define PHYS_SDRAM (0x80000000)
Marcel Ziswiler2e3b3d52019-03-25 17:25:02 +0100151#define PHYS_SDRAM_SIZE (256 * SZ_1M)
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530152
153#define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM
154#define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR
155#define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE
156
157#define CONFIG_SYS_INIT_SP_OFFSET \
158 (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
159#define CONFIG_SYS_INIT_SP_ADDR \
160 (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
161
162/* Environment organization */
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530163#ifdef CONFIG_ENV_IS_IN_NAND
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530164#define CONFIG_ENV_RANGE (4 * 64 * 2048)
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530165#endif
166
Sanchayan Maity7755e532015-04-17 18:56:42 +0530167/* USB Host Support */
Sanchayan Maity7755e532015-04-17 18:56:42 +0530168#define CONFIG_USB_MAX_CONTROLLER_COUNT 2
169#define CONFIG_EHCI_HCD_INIT_AFTER_RESET
170
Sanchayan Maity7755e532015-04-17 18:56:42 +0530171/* USB DFU */
Marcel Ziswiler2e3b3d52019-03-25 17:25:02 +0100172#define CONFIG_SYS_DFU_DATA_BUF_SIZE (SZ_1M)
Sanchayan Maity7755e532015-04-17 18:56:42 +0530173
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530174#endif /* __CONFIG_H */