blob: 33d04fdc4a994a530775455836954b37d357a066 [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
9#include <asm/arch/socfpga_base_addrs.h>
Chin Liang See70fa4e72013-09-11 11:24:48 -050010#include "../../board/altera/socfpga/pinmux_config.h"
Chin Liang See63550242014-06-10 01:17:42 -050011#include "../../board/altera/socfpga/iocsr_config.h"
Chin Liang Seecb350602014-03-04 22:13:53 -060012#include "../../board/altera/socfpga/pll_config.h"
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000013
Marek Vasutd4a4db12014-09-08 14:08:45 +020014/* U-Boot Commands */
15#define CONFIG_SYS_NO_FLASH
Marek Vasutd4a4db12014-09-08 14:08:45 +020016#define CONFIG_DOS_PARTITION
17#define CONFIG_FAT_WRITE
18#define CONFIG_HW_WATCHDOG
Marek Vasutbd279e32014-09-15 01:27:57 +020019
Marek Vasutd4a4db12014-09-08 14:08:45 +020020#define CONFIG_CMD_ASKENV
21#define CONFIG_CMD_BOOTZ
22#define CONFIG_CMD_CACHE
Marek Vasut01c09552014-12-30 20:04:20 +010023#define CONFIG_CMD_DFU
Marek Vasutd4a4db12014-09-08 14:08:45 +020024#define CONFIG_CMD_DHCP
25#define CONFIG_CMD_EXT4
26#define CONFIG_CMD_EXT4_WRITE
27#define CONFIG_CMD_FAT
Marek Vasut08c71a62014-09-19 13:28:47 +020028#define CONFIG_CMD_FS_GENERIC
Marek Vasutd4a4db12014-09-08 14:08:45 +020029#define CONFIG_CMD_GREPENV
30#define CONFIG_CMD_MII
31#define CONFIG_CMD_MMC
Marek Vasutd4a4db12014-09-08 14:08:45 +020032#define CONFIG_CMD_PING
Marek Vasut01c09552014-12-30 20:04:20 +010033#define CONFIG_CMD_USB
34#define CONFIG_CMD_USB_MASS_STORAGE
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000035
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000036
Pavel Machek5e2d70a2014-09-08 14:08:45 +020037/* Memory configurations */
Marek Vasutd4a4db12014-09-08 14:08:45 +020038#define PHYS_SDRAM_1_SIZE 0x40000000 /* 1GiB on SoCDK */
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000039
Marek Vasutd4a4db12014-09-08 14:08:45 +020040/* Booting Linux */
41#define CONFIG_BOOTDELAY 3
42#define CONFIG_BOOTFILE "zImage"
Anatolij Gustschinb02c7982014-11-07 01:12:03 +010043#define CONFIG_BOOTARGS "console=ttyS0," __stringify(CONFIG_BAUDRATE)
Chin Liang See4a6a2282014-09-19 05:33:19 -050044#ifdef CONFIG_SOCFPGA_VIRTUAL_TARGET
Marek Vasutd4a4db12014-09-08 14:08:45 +020045#define CONFIG_BOOTCOMMAND "run ramboot"
Chin Liang See4a6a2282014-09-19 05:33:19 -050046#else
Marek Vasutd4a4db12014-09-08 14:08:45 +020047#define CONFIG_BOOTCOMMAND "run mmcload; run mmcboot"
Chin Liang See4a6a2282014-09-19 05:33:19 -050048#endif
Marek Vasutd4a4db12014-09-08 14:08:45 +020049#define CONFIG_LOADADDR 0x8000
50#define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000051
Pavel Machek5e2d70a2014-09-08 14:08:45 +020052/* Ethernet on SoC (EMAC) */
53#if defined(CONFIG_CMD_NET)
Marek Vasut3835fbe2014-10-10 01:50:23 +020054#define CONFIG_EMAC_BASE SOCFPGA_EMAC1_ADDRESS
Marek Vasutd4a4db12014-09-08 14:08:45 +020055#define CONFIG_PHY_INTERFACE_MODE PHY_INTERFACE_MODE_RGMII
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000056
Marek Vasutd4a4db12014-09-08 14:08:45 +020057/* PHY */
Marek Vasutd4a4db12014-09-08 14:08:45 +020058#define CONFIG_PHY_MICREL
59#define CONFIG_PHY_MICREL_KSZ9021
60#define CONFIG_KSZ9021_CLK_SKEW_ENV "micrel-ksz9021-clk-skew"
61#define CONFIG_KSZ9021_CLK_SKEW_VAL 0xf0f0
62#define CONFIG_KSZ9021_DATA_SKEW_ENV "micrel-ksz9021-data-skew"
63#define CONFIG_KSZ9021_DATA_SKEW_VAL 0x0
64
Chin Liang See9cd12042013-08-07 10:06:56 -050065#endif
Pavel Machekce340e92014-07-14 14:14:17 +020066
Marek Vasut01c09552014-12-30 20:04:20 +010067/* USB */
68#ifdef CONFIG_CMD_USB
69#define CONFIG_USB_DWC2_REG_ADDR SOCFPGA_USB1_ADDRESS
70#endif
71#define CONFIG_G_DNL_MANUFACTURER "Altera"
72
Pavel Machek5e2d70a2014-09-08 14:08:45 +020073/* Extra Environment */
74#define CONFIG_HOSTNAME socfpga_cyclone5
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000075
Marek Vasutd4a4db12014-09-08 14:08:45 +020076#define CONFIG_EXTRA_ENV_SETTINGS \
77 "verify=n\0" \
78 "loadaddr= " __stringify(CONFIG_SYS_LOAD_ADDR) "\0" \
79 "ramboot=setenv bootargs " CONFIG_BOOTARGS ";" \
80 "bootm ${loadaddr} - ${fdt_addr}\0" \
81 "bootimage=zImage\0" \
82 "fdt_addr=100\0" \
83 "fdtimage=socfpga.dtb\0" \
84 "fsloadcmd=ext2load\0" \
85 "bootm ${loadaddr} - ${fdt_addr}\0" \
86 "mmcroot=/dev/mmcblk0p2\0" \
87 "mmcboot=setenv bootargs " CONFIG_BOOTARGS \
88 " root=${mmcroot} rw rootwait;" \
89 "bootz ${loadaddr} - ${fdt_addr}\0" \
90 "mmcload=mmc rescan;" \
Marek Vasut08c71a62014-09-19 13:28:47 +020091 "load mmc 0:1 ${loadaddr} ${bootimage};" \
92 "load mmc 0:1 ${fdt_addr} ${fdtimage}\0" \
Marek Vasutd4a4db12014-09-08 14:08:45 +020093 "qspiroot=/dev/mtdblock0\0" \
94 "qspirootfstype=jffs2\0" \
95 "qspiboot=setenv bootargs " CONFIG_BOOTARGS \
96 " root=${qspiroot} rw rootfstype=${qspirootfstype};"\
97 "bootm ${loadaddr} - ${fdt_addr}\0"
Dinh Nguyenad51f7c2012-10-04 06:46:02 +000098
Pavel Machek5e2d70a2014-09-08 14:08:45 +020099/* The rest of the configuration is shared */
100#include <configs/socfpga_common.h>
Chin Liang See561c9d42014-06-10 01:11:04 -0500101
Pavel Machek5e2d70a2014-09-08 14:08:45 +0200102#endif /* __CONFIG_SOCFPGA_CYCLONE5_H__ */