blob: 87c37ea0a5fb6d722ced5fde479c6ba40f75ce7b [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/* NAND support */
Stefan Agner4ce682a2015-05-08 19:07:13 +020035#define CONFIG_SYS_NAND_ONFI_DETECTION
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053036#define CONFIG_SYS_MAX_NAND_DEVICE 1
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053037
38#define CONFIG_IPADDR 192.168.10.2
39#define CONFIG_NETMASK 255.255.255.0
40#define CONFIG_SERVERIP 192.168.10.1
41
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053042#define CONFIG_LOADADDR 0x80008000
43#define CONFIG_FDTADDR 0x84000000
44
45/* We boot from the gfxRAM area of the OCRAM. */
Stefan Agner1faaa3c2017-10-17 13:59:19 +020046#define CONFIG_BOARD_SIZE_LIMIT 520192
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053047
Stefan Agnerc0594832019-03-25 17:25:03 +010048#define MEM_LAYOUT_ENV_SETTINGS \
49 "bootm_size=0x10000000\0" \
50 "fdt_addr_r=0x82000000\0" \
Stefan Agnerc0594832019-03-25 17:25:03 +010051 "kernel_addr_r=0x81000000\0" \
52 "pxefile_addr_r=0x87100000\0" \
53 "ramdisk_addr_r=0x82100000\0" \
54 "scriptaddr=0x87000000\0"
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053055
Igor Opaniukaf80e152019-12-09 12:33:32 +020056#define UBOOT_UPDATE \
57 "update_uboot=nand erase.part u-boot && " \
58 "nand write ${loadaddr} u-boot ${filesize}\0" \
59
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053060#define NFS_BOOTCMD \
61 "nfsargs=ip=:::::eth0: root=/dev/nfs\0" \
62 "nfsboot=run setup; " \
63 "setenv bootargs ${defargs} ${nfsargs} ${mtdparts} " \
64 "${setupargs} ${vidargs}; echo Booting from NFS...;" \
65 "dhcp ${kernel_addr_r} && " \
66 "tftp ${fdt_addr_r} ${soc}-colibri-${fdt_board}.dtb && " \
Sanchayan Maitya48b4272016-12-02 14:28:27 +053067 "run fdt_fixup && bootz ${kernel_addr_r} - ${fdt_addr_r}\0" \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053068
Stefan Agnerc0594832019-03-25 17:25:03 +010069#define UBI_BOOTCMD \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053070 "ubiargs=ubi.mtd=ubi root=ubi0:rootfs rootfstype=ubifs " \
71 "ubi.fm_autoconvert=1\0" \
72 "ubiboot=run setup; " \
73 "setenv bootargs ${defargs} ${ubiargs} ${mtdparts} " \
74 "${setupargs} ${vidargs}; echo Booting from NAND...; " \
Sanchayan Maity27e4e102016-11-25 16:19:17 +053075 "ubi part ubi && " \
76 "ubi read ${kernel_addr_r} kernel && " \
77 "ubi read ${fdt_addr_r} dtb && " \
Sanchayan Maitya48b4272016-12-02 14:28:27 +053078 "run fdt_fixup && bootz ${kernel_addr_r} - ${fdt_addr_r}\0" \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053079
Stefan Agner7f411a52019-03-25 17:25:04 +010080#define CONFIG_BOOTCOMMAND "run ubiboot; " \
81 "setenv fdtfile ${soc}-colibri-${fdt_board}.dtb && run distro_bootcmd;"
Stefan Agnerc0594832019-03-25 17:25:03 +010082
83#define BOOT_TARGET_DEVICES(func) \
84 func(MMC, mmc, 0) \
85 func(USB, usb, 0) \
86 func(DHCP, dhcp, na)
87#include <config_distro_bootcmd.h>
88#undef BOOTENV_RUN_NET_USB_START
89#define BOOTENV_RUN_NET_USB_START ""
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053090
Sanchayan Maity7755e532015-04-17 18:56:42 +053091#define DFU_ALT_NAND_INFO "vf-bcb part 0,1;u-boot part 0,2;ubi part 0,4"
92
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +053093#define CONFIG_EXTRA_ENV_SETTINGS \
Stefan Agnerc0594832019-03-25 17:25:03 +010094 BOOTENV \
95 MEM_LAYOUT_ENV_SETTINGS \
96 NFS_BOOTCMD \
Stefan Agnerc0594832019-03-25 17:25:03 +010097 UBI_BOOTCMD \
Igor Opaniukaf80e152019-12-09 12:33:32 +020098 UBOOT_UPDATE \
Stefan Agnerc0594832019-03-25 17:25:03 +010099 "console=ttyLP0\0" \
Stefan Agnerb093f0f2019-03-25 17:25:07 +0100100 "defargs=user_debug=30\0" \
Stefan Agnerc0594832019-03-25 17:25:03 +0100101 "dfu_alt_info=" DFU_ALT_NAND_INFO "\0" \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530102 "fdt_board=eval-v3\0" \
Sanchayan Maitya48b4272016-12-02 14:28:27 +0530103 "fdt_fixup=;\0" \
Max Krummenacher115d21f2020-06-16 22:20:05 +0300104 "kernel_image=zImage\0" \
Stefan Agnerc0594832019-03-25 17:25:03 +0100105 "mtdparts=" CONFIG_MTDPARTS_DEFAULT "\0" \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530106 "setsdupdate=mmc rescan && set interface mmc && " \
Stefan Agnerc0594832019-03-25 17:25:03 +0100107 "fatload ${interface} 0:1 ${loadaddr} flash_blk.img && " \
108 "source ${loadaddr}\0" \
109 "setup=setenv setupargs console=tty1 console=${console}" \
110 ",${baudrate}n8 ${memargs}\0" \
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530111 "setupdate=run setsdupdate || run setusbupdate\0" \
Stefan Agnerc0594832019-03-25 17:25:03 +0100112 "setusbupdate=usb start && set interface usb && " \
113 "fatload ${interface} 0:1 ${loadaddr} flash_blk.img && " \
114 "source ${loadaddr}\0" \
Stefan Agner13011752017-04-11 11:12:14 +0530115 "splashpos=m,m\0" \
Stefan Agnerc0594832019-03-25 17:25:03 +0100116 "video-mode=dcufb:640x480-16@60,monitor=lcd\0"
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530117
118/* Miscellaneous configurable options */
Sanchayan Maity0d92de42015-06-08 12:40:41 +0530119#define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530120#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
121
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530122#define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
123#define CONFIG_SYS_HZ 1000
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530124
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530125/* Physical memory map */
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530126#define PHYS_SDRAM (0x80000000)
Marcel Ziswiler2e3b3d52019-03-25 17:25:02 +0100127#define PHYS_SDRAM_SIZE (256 * SZ_1M)
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530128
129#define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM
130#define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR
131#define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE
132
133#define CONFIG_SYS_INIT_SP_OFFSET \
134 (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
135#define CONFIG_SYS_INIT_SP_ADDR \
136 (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
137
138/* Environment organization */
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530139#ifdef CONFIG_ENV_IS_IN_NAND
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530140#define CONFIG_ENV_RANGE (4 * 64 * 2048)
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530141#endif
142
Sanchayan Maity7755e532015-04-17 18:56:42 +0530143/* USB Host Support */
Sanchayan Maity7755e532015-04-17 18:56:42 +0530144#define CONFIG_USB_MAX_CONTROLLER_COUNT 2
145#define CONFIG_EHCI_HCD_INIT_AFTER_RESET
146
Sanchayan Maity7755e532015-04-17 18:56:42 +0530147/* USB DFU */
Marcel Ziswiler2e3b3d52019-03-25 17:25:02 +0100148#define CONFIG_SYS_DFU_DATA_BUF_SIZE (SZ_1M)
Sanchayan Maity7755e532015-04-17 18:56:42 +0530149
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +0530150#endif /* __CONFIG_H */