blob: c5b4b4ca9d399ab1da5c57caaa398972e8634f54 [file] [log] [blame]
Marek Vasut8e8b62a2015-08-03 01:37:28 +02001/*
2 * Copyright (C) 2015 Marek Vasut <marex@denx.de>
3 *
4 * SPDX-License-Identifier: GPL-2.0+
5 */
6#ifndef __CONFIG_DENX_MCVEVK_H__
7#define __CONFIG_DENX_MCVEVK_H__
8
9#include <asm/arch/socfpga_base_addrs.h>
10
11/* U-Boot Commands */
12#define CONFIG_SYS_NO_FLASH
13#define CONFIG_DOS_PARTITION
14#define CONFIG_FAT_WRITE
15#define CONFIG_HW_WATCHDOG
16
17#define CONFIG_CMD_ASKENV
18#define CONFIG_CMD_BOOTZ
19#define CONFIG_CMD_CACHE
20#define CONFIG_CMD_DFU
21#define CONFIG_CMD_DHCP
22#define CONFIG_CMD_EXT4
23#define CONFIG_CMD_EXT4_WRITE
24#define CONFIG_CMD_FAT
25#define CONFIG_CMD_FS_GENERIC
26#define CONFIG_CMD_GPIO
27#define CONFIG_CMD_GREPENV
28#define CONFIG_CMD_MII
29#define CONFIG_CMD_MMC
30#define CONFIG_CMD_PING
31#define CONFIG_CMD_USB
32#define CONFIG_CMD_USB_MASS_STORAGE
33
34/* Memory configurations */
35#define PHYS_SDRAM_1_SIZE 0x40000000 /* 1GiB on MCV */
36
37/* Booting Linux */
38#define CONFIG_BOOTDELAY 3
39#define CONFIG_BOOTFILE "fitImage"
40#define CONFIG_BOOTARGS "console=ttyS0," __stringify(CONFIG_BAUDRATE)
41#define CONFIG_PREBOOT "run try_bootscript"
42#define CONFIG_BOOTCOMMAND "run mmc_mmc"
43#define CONFIG_LOADADDR 0x01000000
44#define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
45
46/* USB */
47#ifdef CONFIG_CMD_USB
48#define CONFIG_USB_DWC2_REG_ADDR SOCFPGA_USB1_ADDRESS
49#endif
50#define CONFIG_G_DNL_MANUFACTURER "DENX"
51
52/* Extra Environment */
53#define CONFIG_HOSTNAME mcvevk
54
55#define CONFIG_EXTRA_ENV_SETTINGS \
56 "consdev=ttyS0\0" \
57 "baudrate=115200\0" \
58 "bootscript=boot.scr\0" \
59 "bootdev=/dev/mmcblk0p2\0" \
60 "rootdev=/dev/mmcblk0p3\0" \
61 "netdev=eth0\0" \
62 "hostname=mcvevk\0" \
63 "kernel_addr_r=0x10000000\0" \
64 "update_filename=u-boot-with-spl-dtb.sfp\0" \
65 "update_sd_offset=0x800\0" \
66 "update_sd=" /* Update the SD firmware partition */ \
67 "if mmc rescan ; then " \
68 "if tftp ${update_filename} ; then " \
69 "setexpr fw_sz ${filesize} / 0x200 ; " /* SD block size */ \
70 "setexpr fw_sz ${fw_sz} + 1 ; " \
71 "mmc write ${loadaddr} ${update_sd_offset} ${fw_sz} ; " \
72 "fi ; " \
73 "fi\0" \
74 "update_qspi_offset=0x0\0" \
75 "update_qspi=" /* Update the QSPI firmware */ \
76 "if sf probe ; then " \
77 "if tftp ${update_filename} ; then " \
78 "sf update ${loadaddr} ${update_qspi_offset} ${filesize} ; " \
79 "fi ; " \
80 "fi\0" \
81 "fpga_filename=output_file.rbf\0" \
82 "load_fpga=" /* Load FPGA bitstream */ \
83 "if tftp ${fpga_filename} ; then " \
84 "fpga load 0 $loadaddr $filesize ; " \
85 "bridge enable ; " \
86 "fi\0" \
87 "addcons=" \
88 "setenv bootargs ${bootargs} " \
89 "console=${consdev},${baudrate}\0" \
90 "addip=" \
91 "setenv bootargs ${bootargs} " \
92 "ip=${ipaddr}:${serverip}:${gatewayip}:" \
93 "${netmask}:${hostname}:${netdev}:off\0" \
94 "addmisc=" \
95 "setenv bootargs ${bootargs} ${miscargs}\0" \
96 "addargs=run addcons addmisc\0" \
97 "mmcload=" \
98 "mmc rescan ; " \
99 "load mmc 0:2 ${kernel_addr_r} ${bootfile}\0" \
100 "netload=" \
101 "tftp ${kernel_addr_r} ${hostname}/${bootfile}\0" \
102 "miscargs=nohlt panic=1\0" \
103 "mmcargs=setenv bootargs root=${rootdev} rw rootwait\0" \
104 "nfsargs=" \
105 "setenv bootargs root=/dev/nfs rw " \
106 "nfsroot=${serverip}:${rootpath},v3,tcp\0" \
107 "mmc_mmc=" \
108 "run mmcload mmcargs addargs ; " \
109 "bootm ${kernel_addr_r}\0" \
110 "mmc_nfs=" \
111 "run mmcload nfsargs addip addargs ; " \
112 "bootm ${kernel_addr_r}\0" \
113 "net_mmc=" \
114 "run netload mmcargs addargs ; " \
115 "bootm ${kernel_addr_r}\0" \
116 "net_nfs=" \
117 "run netload nfsargs addip addargs ; " \
118 "bootm ${kernel_addr_r}\0" \
119 "try_bootscript=" \
120 "mmc rescan;" \
121 "if test -e mmc 0:2 ${bootscript} ; then " \
122 "if load mmc 0:2 ${kernel_addr_r} ${bootscript};" \
123 "then ; " \
124 "echo Running bootscript... ; " \
125 "source ${kernel_addr_r} ; " \
126 "fi ; " \
127 "fi\0"
128
129/* The rest of the configuration is shared */
130#include <configs/socfpga_common.h>
131
132#endif /* __CONFIG_DENX_MCVEVK_H__ */