xref: /openbmc/u-boot/arch/powerpc/include/asm/config.h (revision 170397f1)
1 /*
2  * Copyright 2009-2011 Freescale Semiconductor, Inc.
3  *
4  * SPDX-License-Identifier:	GPL-2.0+
5  */
6 
7 #ifndef _ASM_CONFIG_H_
8 #define _ASM_CONFIG_H_
9 
10 #ifdef CONFIG_MPC85xx
11 #include <asm/config_mpc85xx.h>
12 #define CONFIG_SYS_FSL_DDR
13 #endif
14 
15 #ifdef CONFIG_MPC86xx
16 #include <asm/config_mpc86xx.h>
17 #define CONFIG_SYS_FSL_DDR
18 #endif
19 
20 #ifdef CONFIG_MPC83xx
21 #define CONFIG_SYS_FSL_DDR
22 #endif
23 
24 #ifndef HWCONFIG_BUFFER_SIZE
25   #define HWCONFIG_BUFFER_SIZE 256
26 #endif
27 
28 /* CONFIG_HARD_SPI triggers SPI bus initialization in PowerPC */
29 #if defined(CONFIG_MPC8XXX_SPI) || defined(CONFIG_FSL_ESPI)
30 # ifndef CONFIG_HARD_SPI
31 #  define CONFIG_HARD_SPI
32 # endif
33 #endif
34 
35 #define CONFIG_LMB
36 #define CONFIG_SYS_BOOT_RAMDISK_HIGH
37 #define CONFIG_SYS_BOOT_GET_CMDLINE
38 #define CONFIG_SYS_BOOT_GET_KBD
39 
40 #ifndef CONFIG_MAX_MEM_MAPPED
41 #if	defined(CONFIG_4xx)		|| \
42 	defined(CONFIG_E500)		|| \
43 	defined(CONFIG_MPC86xx)		|| \
44 	defined(CONFIG_E300)
45 #define CONFIG_MAX_MEM_MAPPED	((phys_size_t)2 << 30)
46 #else
47 #define CONFIG_MAX_MEM_MAPPED	(256 << 20)
48 #endif
49 #endif
50 
51 /* Check if boards need to enable FSL DMA engine for SDRAM init */
52 #if !defined(CONFIG_FSL_DMA) && defined(CONFIG_DDR_ECC)
53 #if (defined(CONFIG_MPC83xx) && defined(CONFIG_DDR_ECC_INIT_VIA_DMA)) || \
54 	((defined(CONFIG_MPC85xx) || defined(CONFIG_MPC86xx)) && \
55 	!defined(CONFIG_ECC_INIT_VIA_DDRCONTROLLER))
56 #define CONFIG_FSL_DMA
57 #endif
58 #endif
59 
60 /*
61  * Provide a default boot page translation virtual address that lines up with
62  * Freescale's default e500 reset page.
63  */
64 #if (defined(CONFIG_E500) && defined(CONFIG_MP))
65 #ifndef CONFIG_BPTR_VIRT_ADDR
66 #define CONFIG_BPTR_VIRT_ADDR	0xfffff000
67 #endif
68 #endif
69 
70 /*
71  * SEC (crypto unit) major compatible version determination
72  */
73 #if defined(CONFIG_MPC83xx)
74 #define CONFIG_SYS_FSL_SEC_BE
75 #define CONFIG_SYS_FSL_SEC_COMPAT	2
76 #endif
77 
78 /* Since so many PPC SOCs have a semi-common LBC, define this here */
79 #if defined(CONFIG_MPC85xx) || defined(CONFIG_MPC86xx) || \
80 	defined(CONFIG_MPC83xx)
81 #if !defined(CONFIG_FSL_IFC)
82 #define CONFIG_FSL_LBC
83 #endif
84 #endif
85 
86 /* The TSEC driver uses the PHYLIB infrastructure */
87 #ifndef CONFIG_PHYLIB
88 #if defined(CONFIG_TSEC_ENET)
89 #define CONFIG_PHYLIB
90 
91 #include <config_phylib_all_drivers.h>
92 #endif /* TSEC_ENET */
93 #endif /* !CONFIG_PHYLIB */
94 
95 /* The FMAN driver uses the PHYLIB infrastructure */
96 #if defined(CONFIG_FMAN_ENET)
97 #define CONFIG_PHYLIB
98 #endif
99 
100 /* All PPC boards must swap IDE bytes */
101 #define CONFIG_IDE_SWAP_IO
102 
103 #if defined(CONFIG_DM_SERIAL)
104 /*
105  * TODO: Convert this to a clock driver exists that can give us the UART
106  * clock here.
107  */
108 #define CONFIG_SYS_NS16550_CLK		get_serial_clock()
109 #endif
110 
111 #endif /* _ASM_CONFIG_H_ */
112