blob: d7c339e6f82e11efc4d2001ee695eb50fea5bc79 [file] [log] [blame]
Dinh Nguyenad51f7c2012-10-04 06:46:02 +00001/*
Pavel Machek5e2d70a2014-09-08 14:08:45 +02002 * Copyright (C) 2014 Marek Vasut <marex@denx.de>
Dinh Nguyenad51f7c2012-10-04 06:46:02 +00003 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02004 * SPDX-License-Identifier: GPL-2.0+
Dinh Nguyenad51f7c2012-10-04 06:46:02 +00005 */
Pavel Machek5e2d70a2014-09-08 14:08:45 +02006#ifndef __CONFIG_SOCFPGA_CYCLONE5_H__
7#define __CONFIG_SOCFPGA_CYCLONE5_H__
Dinh Nguyenad51f7c2012-10-04 06:46:02 +00008
Dinh Nguyeneca8b5c2015-11-23 17:27:17 -06009#include <asm/arch/base_addr_ac5.h>
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000010
Marek Vasutd4a4db12014-09-08 14:08:45 +020011/* U-Boot Commands */
12#define CONFIG_SYS_NO_FLASH
Marek Vasutd4a4db12014-09-08 14:08:45 +020013#define CONFIG_DOS_PARTITION
14#define CONFIG_FAT_WRITE
15#define CONFIG_HW_WATCHDOG
Marek Vasutbd279e32014-09-15 01:27:57 +020016
Marek Vasutd4a4db12014-09-08 14:08:45 +020017#define CONFIG_CMD_ASKENV
18#define CONFIG_CMD_BOOTZ
19#define CONFIG_CMD_CACHE
Marek Vasut01c09552014-12-30 20:04:20 +010020#define CONFIG_CMD_DFU
Marek Vasutd4a4db12014-09-08 14:08:45 +020021#define CONFIG_CMD_DHCP
22#define CONFIG_CMD_EXT4
23#define CONFIG_CMD_EXT4_WRITE
24#define CONFIG_CMD_FAT
Marek Vasut08c71a62014-09-19 13:28:47 +020025#define CONFIG_CMD_FS_GENERIC
Marek Vasutd4a4db12014-09-08 14:08:45 +020026#define CONFIG_CMD_GREPENV
27#define CONFIG_CMD_MII
28#define CONFIG_CMD_MMC
Marek Vasutd4a4db12014-09-08 14:08:45 +020029#define CONFIG_CMD_PING
Marek Vasut01c09552014-12-30 20:04:20 +010030#define CONFIG_CMD_USB
31#define CONFIG_CMD_USB_MASS_STORAGE
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000032
Pavel Machek5e2d70a2014-09-08 14:08:45 +020033/* Memory configurations */
Marek Vasutd4a4db12014-09-08 14:08:45 +020034#define PHYS_SDRAM_1_SIZE 0x40000000 /* 1GiB on SoCDK */
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000035
Marek Vasutd4a4db12014-09-08 14:08:45 +020036/* Booting Linux */
37#define CONFIG_BOOTDELAY 3
38#define CONFIG_BOOTFILE "zImage"
Anatolij Gustschinb02c7982014-11-07 01:12:03 +010039#define CONFIG_BOOTARGS "console=ttyS0," __stringify(CONFIG_BAUDRATE)
Chin Liang See4a6a2282014-09-19 05:33:19 -050040#ifdef CONFIG_SOCFPGA_VIRTUAL_TARGET
Marek Vasutd4a4db12014-09-08 14:08:45 +020041#define CONFIG_BOOTCOMMAND "run ramboot"
Chin Liang See4a6a2282014-09-19 05:33:19 -050042#else
Marek Vasutd4a4db12014-09-08 14:08:45 +020043#define CONFIG_BOOTCOMMAND "run mmcload; run mmcboot"
Chin Liang See4a6a2282014-09-19 05:33:19 -050044#endif
Marek Vasut2bff5402015-07-22 06:18:19 +020045#define CONFIG_LOADADDR 0x01000000
Marek Vasutd4a4db12014-09-08 14:08:45 +020046#define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000047
Pavel Machek5e2d70a2014-09-08 14:08:45 +020048/* Ethernet on SoC (EMAC) */
49#if defined(CONFIG_CMD_NET)
Marek Vasutd4a4db12014-09-08 14:08:45 +020050#define CONFIG_PHY_MICREL
51#define CONFIG_PHY_MICREL_KSZ9021
Chin Liang See9cd12042013-08-07 10:06:56 -050052#endif
Pavel Machekce340e92014-07-14 14:14:17 +020053
Dinh Nguyen813e7e62015-09-23 15:38:01 -050054#define CONFIG_ENV_IS_IN_MMC
Dinh Nguyen813e7e62015-09-23 15:38:01 -050055
Pavel Machek5e2d70a2014-09-08 14:08:45 +020056/* Extra Environment */
Marek Vasutd4a4db12014-09-08 14:08:45 +020057#define CONFIG_EXTRA_ENV_SETTINGS \
58 "verify=n\0" \
Marek Vasut950c10c2016-04-03 19:11:12 +020059 "loadaddr=" __stringify(CONFIG_SYS_LOAD_ADDR) "\0" \
Marek Vasutd4a4db12014-09-08 14:08:45 +020060 "ramboot=setenv bootargs " CONFIG_BOOTARGS ";" \
61 "bootm ${loadaddr} - ${fdt_addr}\0" \
62 "bootimage=zImage\0" \
63 "fdt_addr=100\0" \
64 "fdtimage=socfpga.dtb\0" \
Marek Vasutd4a4db12014-09-08 14:08:45 +020065 "bootm ${loadaddr} - ${fdt_addr}\0" \
66 "mmcroot=/dev/mmcblk0p2\0" \
67 "mmcboot=setenv bootargs " CONFIG_BOOTARGS \
68 " root=${mmcroot} rw rootwait;" \
69 "bootz ${loadaddr} - ${fdt_addr}\0" \
70 "mmcload=mmc rescan;" \
Marek Vasut08c71a62014-09-19 13:28:47 +020071 "load mmc 0:1 ${loadaddr} ${bootimage};" \
72 "load mmc 0:1 ${fdt_addr} ${fdtimage}\0" \
Chin Liang See9937c722015-12-22 15:32:35 +080073 "qspiload=sf probe && mtdparts default && run ubiload\0" \
Marek Vasutd4a4db12014-09-08 14:08:45 +020074 "qspiboot=setenv bootargs " CONFIG_BOOTARGS \
Chin Liang See180d6802015-12-22 15:32:39 +080075 " ubi.mtd=1,64 root=ubi0:rootfs rw rootfstype=ubifs;"\
76 "bootz ${loadaddr} - ${fdt_addr}\0" \
Chin Liang See3ab7a4b2015-12-22 15:32:31 +080077 "ubiload=ubi part UBI && ubifsmount ubi0 && " \
78 "ubifsload ${loadaddr} /boot/${bootimage} && " \
79 "ubifsload ${fdt_addr} /boot/${fdtimage}\0"
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000080
Pavel Machek5e2d70a2014-09-08 14:08:45 +020081/* The rest of the configuration is shared */
82#include <configs/socfpga_common.h>
Chin Liang See561c9d42014-06-10 01:11:04 -050083
Pavel Machek5e2d70a2014-09-08 14:08:45 +020084#endif /* __CONFIG_SOCFPGA_CYCLONE5_H__ */