blob: 676144a668aa2acf2cf2ebabd102afdb430fb1e3 [file] [log] [blame]
Dinh Nguyen77754402012-10-04 06:46:02 +00001/*
Pavel Machek5095ee02014-09-08 14:08:45 +02002 * Copyright (C) 2014 Marek Vasut <marex@denx.de>
Dinh Nguyen77754402012-10-04 06:46:02 +00003 *
Wolfgang Denk1a459662013-07-08 09:37:19 +02004 * SPDX-License-Identifier: GPL-2.0+
Dinh Nguyen77754402012-10-04 06:46:02 +00005 */
Pavel Machek5095ee02014-09-08 14:08:45 +02006#ifndef __CONFIG_SOCFPGA_CYCLONE5_H__
7#define __CONFIG_SOCFPGA_CYCLONE5_H__
Dinh Nguyen77754402012-10-04 06:46:02 +00008
9#include <asm/arch/socfpga_base_addrs.h>
Chin Liang See5d649d22013-09-11 11:24:48 -050010#include "../../board/altera/socfpga/pinmux_config.h"
Chin Liang Seedc4d4aa2014-06-10 01:17:42 -050011#include "../../board/altera/socfpga/iocsr_config.h"
Chin Liang Seeddfeb0a2014-03-04 22:13:53 -060012#include "../../board/altera/socfpga/pll_config.h"
Dinh Nguyen77754402012-10-04 06:46:02 +000013
Marek Vasut47f9b4e2014-09-08 14:08:45 +020014/* U-Boot Commands */
15#define CONFIG_SYS_NO_FLASH
16#include <config_cmd_default.h>
17#define CONFIG_DOS_PARTITION
18#define CONFIG_FAT_WRITE
19#define CONFIG_HW_WATCHDOG
20
21#define CONFIG_CMD_ASKENV
22#define CONFIG_CMD_BOOTZ
23#define CONFIG_CMD_CACHE
Marek Vasute5e87172014-12-30 20:04:20 +010024#define CONFIG_CMD_DFU
Marek Vasut47f9b4e2014-09-08 14:08:45 +020025#define CONFIG_CMD_DHCP
26#define CONFIG_CMD_EXT4
27#define CONFIG_CMD_EXT4_WRITE
28#define CONFIG_CMD_FAT
29#define CONFIG_CMD_FPGA
Marek Vasut2f210632014-09-19 13:28:47 +020030#define CONFIG_CMD_FS_GENERIC
Marek Vasut47f9b4e2014-09-08 14:08:45 +020031#define CONFIG_CMD_GREPENV
32#define CONFIG_CMD_MII
33#define CONFIG_CMD_MMC
34#define CONFIG_CMD_NET
35#define CONFIG_CMD_PING
36#define CONFIG_CMD_SETEXPR
Marek Vasute5e87172014-12-30 20:04:20 +010037#define CONFIG_CMD_USB
38#define CONFIG_CMD_USB_MASS_STORAGE
Marek Vasut47f9b4e2014-09-08 14:08:45 +020039
40#define CONFIG_REGEX /* Enable regular expression support */
41
Pavel Machek5095ee02014-09-08 14:08:45 +020042/* Memory configurations */
Marek Vasut47f9b4e2014-09-08 14:08:45 +020043#define PHYS_SDRAM_1_SIZE 0x40000000 /* 1GiB on SoCDK */
Dinh Nguyen77754402012-10-04 06:46:02 +000044
Marek Vasut47f9b4e2014-09-08 14:08:45 +020045/* Booting Linux */
46#define CONFIG_BOOTDELAY 3
47#define CONFIG_BOOTFILE "zImage"
Anatolij Gustschin116f5d52014-11-07 01:12:03 +010048#define CONFIG_BOOTARGS "console=ttyS0," __stringify(CONFIG_BAUDRATE)
Chin Liang See97ce2742014-09-19 05:33:19 -050049#ifdef CONFIG_SOCFPGA_VIRTUAL_TARGET
Marek Vasut47f9b4e2014-09-08 14:08:45 +020050#define CONFIG_BOOTCOMMAND "run ramboot"
Chin Liang See97ce2742014-09-19 05:33:19 -050051#else
Marek Vasut47f9b4e2014-09-08 14:08:45 +020052#define CONFIG_BOOTCOMMAND "run mmcload; run mmcboot"
53#endif
54#define CONFIG_LOADADDR 0x8000
55#define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
56
Pavel Machek5095ee02014-09-08 14:08:45 +020057/* Ethernet on SoC (EMAC) */
58#if defined(CONFIG_CMD_NET)
Marek Vasut5a1d0ad2014-10-10 01:50:23 +020059#define CONFIG_EMAC_BASE SOCFPGA_EMAC1_ADDRESS
Marek Vasut47f9b4e2014-09-08 14:08:45 +020060#define CONFIG_PHY_INTERFACE_MODE PHY_INTERFACE_MODE_RGMII
Marek Vasut47f9b4e2014-09-08 14:08:45 +020061
62/* PHY */
Marek Vasut47f9b4e2014-09-08 14:08:45 +020063#define CONFIG_PHY_MICREL
64#define CONFIG_PHY_MICREL_KSZ9021
65#define CONFIG_KSZ9021_CLK_SKEW_ENV "micrel-ksz9021-clk-skew"
66#define CONFIG_KSZ9021_CLK_SKEW_VAL 0xf0f0
67#define CONFIG_KSZ9021_DATA_SKEW_ENV "micrel-ksz9021-data-skew"
68#define CONFIG_KSZ9021_DATA_SKEW_VAL 0x0
69
Chin Liang See97ce2742014-09-19 05:33:19 -050070#endif
Dinh Nguyen77754402012-10-04 06:46:02 +000071
Marek Vasute5e87172014-12-30 20:04:20 +010072/* USB */
73#ifdef CONFIG_CMD_USB
74#define CONFIG_USB_DWC2_REG_ADDR SOCFPGA_USB1_ADDRESS
75#endif
76#define CONFIG_G_DNL_MANUFACTURER "Altera"
77
Pavel Machek5095ee02014-09-08 14:08:45 +020078/* Extra Environment */
79#define CONFIG_HOSTNAME socfpga_cyclone5
Dinh Nguyen77754402012-10-04 06:46:02 +000080
81#define CONFIG_EXTRA_ENV_SETTINGS \
82 "verify=n\0" \
Marek Vasut5368c552012-09-23 17:41:24 +020083 "loadaddr= " __stringify(CONFIG_SYS_LOAD_ADDR) "\0" \
Dinh Nguyen77754402012-10-04 06:46:02 +000084 "ramboot=setenv bootargs " CONFIG_BOOTARGS ";" \
85 "bootm ${loadaddr} - ${fdt_addr}\0" \
Chin Liang See97ce2742014-09-19 05:33:19 -050086 "bootimage=zImage\0" \
Dinh Nguyen77754402012-10-04 06:46:02 +000087 "fdt_addr=100\0" \
Chin Liang See97ce2742014-09-19 05:33:19 -050088 "fdtimage=socfpga.dtb\0" \
89 "fsloadcmd=ext2load\0" \
90 "bootm ${loadaddr} - ${fdt_addr}\0" \
91 "mmcroot=/dev/mmcblk0p2\0" \
92 "mmcboot=setenv bootargs " CONFIG_BOOTARGS \
93 " root=${mmcroot} rw rootwait;" \
94 "bootz ${loadaddr} - ${fdt_addr}\0" \
95 "mmcload=mmc rescan;" \
Marek Vasut2f210632014-09-19 13:28:47 +020096 "load mmc 0:1 ${loadaddr} ${bootimage};" \
97 "load mmc 0:1 ${fdt_addr} ${fdtimage}\0" \
Dinh Nguyen77754402012-10-04 06:46:02 +000098 "qspiroot=/dev/mtdblock0\0" \
99 "qspirootfstype=jffs2\0" \
100 "qspiboot=setenv bootargs " CONFIG_BOOTARGS \
101 " root=${qspiroot} rw rootfstype=${qspirootfstype};"\
102 "bootm ${loadaddr} - ${fdt_addr}\0"
103
Pavel Machek5095ee02014-09-08 14:08:45 +0200104/* The rest of the configuration is shared */
105#include <configs/socfpga_common.h>
Dinh Nguyen77754402012-10-04 06:46:02 +0000106
Pavel Machek5095ee02014-09-08 14:08:45 +0200107#endif /* __CONFIG_SOCFPGA_CYCLONE5_H__ */