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 /* 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 */ 51 52 /* USB */ 53 #ifdef CONFIG_CMD_USB 54 #define CONFIG_USB_DWC2_REG_ADDR SOCFPGA_USB1_ADDRESS 55 #endif 56 #define CONFIG_G_DNL_MANUFACTURER "DENX" 57 58 /* Extra Environment */ 59 #define CONFIG_HOSTNAME mcvevk 60 61 #define CONFIG_EXTRA_ENV_SETTINGS \ 62 "consdev=ttyS0\0" \ 63 "baudrate=115200\0" \ 64 "bootscript=boot.scr\0" \ 65 "bootdev=/dev/mmcblk0p2\0" \ 66 "rootdev=/dev/mmcblk0p3\0" \ 67 "netdev=eth0\0" \ 68 "hostname=mcvevk\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} ; " \ 78 "fi ; " \ 79 "fi\0" \ 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} ; " \ 85 "fi ; " \ 86 "fi\0" \ 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 ; " \ 91 "bridge enable ; " \ 92 "fi\0" \ 93 "addcons=" \ 94 "setenv bootargs ${bootargs} " \ 95 "console=${consdev},${baudrate}\0" \ 96 "addip=" \ 97 "setenv bootargs ${bootargs} " \ 98 "ip=${ipaddr}:${serverip}:${gatewayip}:" \ 99 "${netmask}:${hostname}:${netdev}:off\0" \ 100 "addmisc=" \ 101 "setenv bootargs ${bootargs} ${miscargs}\0" \ 102 "addargs=run addcons addmisc\0" \ 103 "mmcload=" \ 104 "mmc rescan ; " \ 105 "load mmc 0:2 ${kernel_addr_r} ${bootfile}\0" \ 106 "netload=" \ 107 "tftp ${kernel_addr_r} ${hostname}/${bootfile}\0" \ 108 "miscargs=nohlt panic=1\0" \ 109 "mmcargs=setenv bootargs root=${rootdev} rw rootwait\0" \ 110 "nfsargs=" \ 111 "setenv bootargs root=/dev/nfs rw " \ 112 "nfsroot=${serverip}:${rootpath},v3,tcp\0" \ 113 "mmc_mmc=" \ 114 "run mmcload mmcargs addargs ; " \ 115 "bootm ${kernel_addr_r}\0" \ 116 "mmc_nfs=" \ 117 "run mmcload nfsargs addip addargs ; " \ 118 "bootm ${kernel_addr_r}\0" \ 119 "net_mmc=" \ 120 "run netload mmcargs addargs ; " \ 121 "bootm ${kernel_addr_r}\0" \ 122 "net_nfs=" \ 123 "run netload nfsargs addip addargs ; " \ 124 "bootm ${kernel_addr_r}\0" \ 125 "try_bootscript=" \ 126 "mmc rescan;" \ 127 "if test -e mmc 0:2 ${bootscript} ; then " \ 128 "if load mmc 0:2 ${kernel_addr_r} ${bootscript};" \ 129 "then ; " \ 130 "echo Running bootscript... ; " \ 131 "source ${kernel_addr_r} ; " \ 132 "fi ; " \ 133 "fi\0" 134 135 /* The rest of the configuration is shared */ 136 #include <configs/socfpga_common.h> 137 138 #endif /* __CONFIG_DENX_MCVEVK_H__ */ 139