2 * Copyright (C) 2015 Marek Vasut <marex@denx.de>
4 * SPDX-License-Identifier: GPL-2.0+
6 #ifndef __CONFIG_DENX_MCVEVK_H__
7 #define __CONFIG_DENX_MCVEVK_H__
9 #include <asm/arch/socfpga_base_addrs.h>
12 #define CONFIG_SYS_NO_FLASH
13 #define CONFIG_DOS_PARTITION
14 #define CONFIG_FAT_WRITE
15 #define CONFIG_HW_WATCHDOG
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
34 /* Memory configurations */
35 #define PHYS_SDRAM_1_SIZE 0x40000000 /* 1GiB on MCV */
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
46 /* Environment is in MMC */
47 #define CONFIG_ENV_OVERWRITE
48 #define CONFIG_ENV_IS_IN_MMC
49 #define CONFIG_SYS_MMC_ENV_DEV 0 /* device 0 */
50 #define CONFIG_ENV_OFFSET 512 /* just after the MBR */
54 #define CONFIG_USB_DWC2_REG_ADDR SOCFPGA_USB1_ADDRESS
56 #define CONFIG_G_DNL_MANUFACTURER "DENX"
58 /* Extra Environment */
59 #define CONFIG_HOSTNAME mcvevk
61 #define CONFIG_EXTRA_ENV_SETTINGS \
64 "bootscript=boot.scr\0" \
65 "bootdev=/dev/mmcblk0p2\0" \
66 "rootdev=/dev/mmcblk0p3\0" \
69 "kernel_addr_r=0x10000000\0" \
70 "update_filename=u-boot-with-spl-dtb.sfp\0" \
71 "update_sd_offset=0x800\0" \
72 "update_sd=" /* Update the SD firmware partition */ \
73 "if mmc rescan ; then " \
74 "if tftp ${update_filename} ; then " \
75 "setexpr fw_sz ${filesize} / 0x200 ; " /* SD block size */ \
76 "setexpr fw_sz ${fw_sz} + 1 ; " \
77 "mmc write ${loadaddr} ${update_sd_offset} ${fw_sz} ; " \
80 "update_qspi_offset=0x0\0" \
81 "update_qspi=" /* Update the QSPI firmware */ \
82 "if sf probe ; then " \
83 "if tftp ${update_filename} ; then " \
84 "sf update ${loadaddr} ${update_qspi_offset} ${filesize} ; " \
87 "fpga_filename=output_file.rbf\0" \
88 "load_fpga=" /* Load FPGA bitstream */ \
89 "if tftp ${fpga_filename} ; then " \
90 "fpga load 0 $loadaddr $filesize ; " \
94 "setenv bootargs ${bootargs} " \
95 "console=${consdev},${baudrate}\0" \
97 "setenv bootargs ${bootargs} " \
98 "ip=${ipaddr}:${serverip}:${gatewayip}:" \
99 "${netmask}:${hostname}:${netdev}:off\0" \
101 "setenv bootargs ${bootargs} ${miscargs}\0" \
102 "addargs=run addcons addmisc\0" \
105 "load mmc 0:2 ${kernel_addr_r} ${bootfile}\0" \
107 "tftp ${kernel_addr_r} ${hostname}/${bootfile}\0" \
108 "miscargs=nohlt panic=1\0" \
109 "mmcargs=setenv bootargs root=${rootdev} rw rootwait\0" \
111 "setenv bootargs root=/dev/nfs rw " \
112 "nfsroot=${serverip}:${rootpath},v3,tcp\0" \
114 "run mmcload mmcargs addargs ; " \
115 "bootm ${kernel_addr_r}\0" \
117 "run mmcload nfsargs addip addargs ; " \
118 "bootm ${kernel_addr_r}\0" \
120 "run netload mmcargs addargs ; " \
121 "bootm ${kernel_addr_r}\0" \
123 "run netload nfsargs addip addargs ; " \
124 "bootm ${kernel_addr_r}\0" \
127 "if test -e mmc 0:2 ${bootscript} ; then " \
128 "if load mmc 0:2 ${kernel_addr_r} ${bootscript};" \
130 "echo Running bootscript... ; " \
131 "source ${kernel_addr_r} ; " \
135 /* The rest of the configuration is shared */
136 #include <configs/socfpga_common.h>
138 #endif /* __CONFIG_DENX_MCVEVK_H__ */