blob: 5ed949791f642a5e0a901d7838c0f2595e7fecd1 [file] [log] [blame]
Suriyan Ramasami0ad6c342013-04-11 07:17:25 +00001/*
2 * Copyright (C) 2013 Suriyan Ramasami <suriyan.r@gmail.com>
3 *
4 * Based on dockstar.h originally written by
5 * Copyright (C) 2010 Eric C. Cooper <ecc@cmu.edu>
6 *
7 * Based on sheevaplug.h originally written by
8 * Prafulla Wadaskar <prafulla@marvell.com>
9 * (C) Copyright 2009
10 * Marvell Semiconductor <www.marvell.com>
11 *
Wolfgang Denk1a459662013-07-08 09:37:19 +020012 * SPDX-License-Identifier: GPL-2.0+
Suriyan Ramasami0ad6c342013-04-11 07:17:25 +000013 */
14
15#ifndef _CONFIG_GOFLEXHOME_H
16#define _CONFIG_GOFLEXHOME_H
17
18/*
19 * Version number information
20 */
21#define CONFIG_IDENT_STRING "\nSeagate GoFlex Home"
22
23/*
24 * High Level Configuration Options (easy to change)
25 */
26#define CONFIG_FEROCEON_88FR131 1 /* CPU Core subversion */
Suriyan Ramasami0ad6c342013-04-11 07:17:25 +000027#define CONFIG_KW88F6281 1 /* SOC Name */
28#define CONFIG_MACH_GOFLEXHOME /* Machine type */
29#define CONFIG_SKIP_LOWLEVEL_INIT /* disable board lowlevel_init */
30
31/*
32 * Default GPIO configuration and LED status
33 */
34#define GOFLEXHOME_OE_LOW (~(0))
35#define GOFLEXHOME_OE_HIGH (~(0))
36#define GOFLEXHOME_OE_VAL_LOW (1 << 29) /* USB_PWEN low */
37#define GOFLEXHOME_OE_VAL_HIGH (1 << 17) /* LED pin high */
38
39/* PHY related */
40#define MV88E1116_LED_FCTRL_REG 10
41#define MV88E1116_CPRSP_CR3_REG 21
42#define MV88E1116_MAC_CTRL_REG 21
43#define MV88E1116_PGADR_REG 22
44#define MV88E1116_RGMII_TXTM_CTRL (1 << 4)
45#define MV88E1116_RGMII_RXTM_CTRL (1 << 5)
46
47/*
48 * Commands configuration
49 */
50#define CONFIG_SYS_NO_FLASH /* Declare no flash (NOR/SPI) */
51#define CONFIG_CONSOLE_MUX
52#define CONFIG_SYS_CONSOLE_IS_IN_ENV
53
54#include <config_cmd_default.h>
55#define CONFIG_CMD_DHCP
56#define CONFIG_CMD_ENV
57#define CONFIG_CMD_MII
58#define CONFIG_CMD_NAND
59#define CONFIG_CMD_PING
60#define CONFIG_CMD_USB
61#define CONFIG_CMD_IDE
62#define CONFIG_CMD_DATE
63#define CONFIG_CMD_EXT4
64#define CONFIG_SYS_MVFS /* Picks up Filesystem from mv-common.h */
65
66/*
67 * mv-common.h should be defined after CMD configs since it used them
68 * to enable certain macros
69 */
70#include "mv-common.h"
71
72#undef CONFIG_SYS_PROMPT /* previously defined in mv-common.h */
73#define CONFIG_SYS_PROMPT "GoFlexHome> " /* Command Prompt */
74
75/*
76 * Environment variables configurations
77 */
78#ifdef CONFIG_CMD_NAND
79#define CONFIG_ENV_IS_IN_NAND 1
80#define CONFIG_ENV_SECT_SIZE 0x20000 /* 128K */
81#else
82#define CONFIG_ENV_IS_NOWHERE 1 /* if env in SDRAM */
83#endif
84/*
85 * max 4k env size is enough, but in case of nand
86 * it has to be rounded to sector size
87 */
88#define CONFIG_ENV_SIZE 0x20000 /* 128k */
89#define CONFIG_ENV_ADDR 0xC0000
90#define CONFIG_ENV_OFFSET 0xC0000 /* env starts here */
91
92/*
93 * Default environment variables
94 */
95#define CONFIG_BOOTCOMMAND \
96 "setenv bootargs ${console} ${mtdparts} ${bootargs_root}; " \
97 "ubi part root; " \
98 "ubifsmount ubi:root; " \
99 "ubifsload 0x800000 ${kernel}; " \
100 "bootm 0x800000"
101
102#define CONFIG_MTDPARTS \
103 "mtdparts=orion_nand:1m(uboot),6M(uImage),-(root)\0"
104
105#define CONFIG_EXTRA_ENV_SETTINGS \
106 "console=console=ttyS0,115200\0" \
107 "mtdids=nand0=orion_nand\0" \
108 "mtdparts="CONFIG_MTDPARTS \
109 "kernel=/boot/uImage\0" \
110 "bootargs_root=ubi.mtd=root root=ubi0:root rootfstype=ubifs ro\0"
111
112/*
113 * Ethernet Driver configuration
114 */
115#ifdef CONFIG_CMD_NET
116#define CONFIG_MVGBE_PORTS {1, 0} /* enable port 0 only */
117#define CONFIG_PHY_BASE_ADR 0
118#endif /* CONFIG_CMD_NET */
119
120/*
121 * * SATA Driver configuration
122 * */
123#ifdef CONFIG_MVSATA_IDE
124#define CONFIG_SYS_ATA_IDE0_OFFSET MV_SATA_PORT0_OFFSET
125#endif /*CONFIG_MVSATA_IDE*/
126
127/*
128 * * RTC driver configuration
129 * */
130#ifdef CONFIG_CMD_DATE
131#define CONFIG_RTC_MV
132#endif /* CONFIG_CMD_DATE */
133
134#endif /* _CONFIG_GOFLEXHOME_H */