Merge branch 'master' into next
[platform/kernel/u-boot.git] / include / configs / km / km-mpc83xx.h
1 /*
2  * Internal Definitions
3  */
4 #include <linux/stringify.h>
5 #define BOOTFLASH_START 0xF0000000
6
7 /*
8  * DDR Setup
9  */
10 #define CONFIG_SYS_SDRAM_BASE           0x00000000 /* DDR is system memory */
11 #define CONFIG_SYS_SDRAM_BASE2  (CONFIG_SYS_SDRAM_BASE + 0x10000000) /* +256M */
12
13 #define CONFIG_SYS_DDR_SDRAM_CLK_CNTL   (DDR_SDRAM_CLK_CNTL_SS_EN | \
14                                         DDR_SDRAM_CLK_CNTL_CLK_ADJUST_05)
15
16 #define CFG_83XX_DDR_USES_CS0
17
18 /*
19  * Manually set up DDR parameters
20  */
21 #define CONFIG_SYS_DDR_SIZE             2048 /* MB */
22
23 /*
24  * The reserved memory
25  */
26 #define CONFIG_SYS_FLASH_BASE           0xF0000000
27
28 #if (CONFIG_SYS_MONITOR_BASE < CONFIG_SYS_FLASH_BASE)
29 #define CONFIG_SYS_RAMBOOT
30 #endif
31
32 /* Reserve 768 kB for Mon */
33 #define CONFIG_SYS_MONITOR_LEN          (768 * 1024)
34
35 /*
36  * Initial RAM Base Address Setup
37  */
38 #define CONFIG_SYS_INIT_RAM_LOCK
39 #define CONFIG_SYS_INIT_RAM_ADDR        0xE6000000 /* Initial RAM address */
40 #define CONFIG_SYS_INIT_RAM_SIZE        0x1000 /* End of used area in RAM */
41 /*
42  * Init Local Bus Memory Controller:
43  *
44  * Bank Bus     Machine PortSz  Size  Device
45  * ---- ---     ------- ------  -----  ------
46  *  0   Local   GPCM    16 bit  256MB FLASH
47  *  1   Local   GPCM     8 bit  128MB GPIO/PIGGY
48  *
49  */
50
51 /*
52  * FLASH on the Local Bus
53  */
54 #define CONFIG_SYS_FLASH_SIZE           256 /* max FLASH size is 256M */
55
56 #define CONFIG_SYS_MAX_FLASH_SECT       512 /* max num of sects on one chip */
57 #define CONFIG_SYS_FLASH_BANKS_LIST { CONFIG_SYS_FLASH_BASE }
58
59 /* I2C */
60 #define CONFIG_SYS_NUM_I2C_BUSES        4
61 #define CONFIG_SYS_I2C_MAX_HOPS         1
62 #define CONFIG_SYS_I2C_BUSES    {{0, {I2C_NULL_HOP} }, \
63                 {0, {{I2C_MUX_PCA9547, 0x70, 2} } }, \
64                 {0, {{I2C_MUX_PCA9547, 0x70, 1} } }, \
65                 {1, {I2C_NULL_HOP} } }
66
67 #if defined(CONFIG_CMD_NAND)
68 #define CONFIG_NAND_KMETER1
69 #define CONFIG_SYS_MAX_NAND_DEVICE      1
70 #define CONFIG_SYS_NAND_BASE            CONFIG_SYS_KMBEC_FPGA_BASE
71 #endif
72
73 /*
74  * For booting Linux, the board info and command line data
75  * have to be in the first 8 MB of memory, since this is
76  * the maximum mapped by the Linux kernel during initialization.
77  */
78 #define CONFIG_SYS_BOOTMAPSZ            (8 << 20)
79
80 /*
81  * Environment
82  */
83
84 #ifndef CONFIG_SYS_RAMBOOT
85 /* Address and size of Redundant Environment Sector     */
86 #endif /* CFG_SYS_RAMBOOT */
87
88 /*
89  * Environment Configuration
90  */
91 #ifndef CONFIG_KM_DEF_ENV               /* if not set by keymile-common.h */
92 #define CONFIG_KM_DEF_ENV "km-common=empty\0"
93 #endif
94
95 #ifndef CONFIG_KM_DEF_ARCH
96 #define CONFIG_KM_DEF_ARCH      "arch=ppc_82xx\0"
97 #endif
98
99 #define CONFIG_EXTRA_ENV_SETTINGS \
100         CONFIG_KM_DEF_ENV                                                \
101         CONFIG_KM_DEF_ARCH                                               \
102         "newenv="                                                        \
103                 "prot off " __stringify(CONFIG_ENV_ADDR) " +0x40000 && " \
104                 "era " __stringify(CONFIG_ENV_ADDR) " +0x40000\0"        \
105         "unlock=yes\0"                                                   \
106         ""
107
108 /*
109  * QE UEC ethernet configuration
110  */
111 #define CONFIG_UEC_ETH