1 /* 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__ */ 133