diff options
Diffstat (limited to 'arch/powerpc/lib')
| -rw-r--r-- | arch/powerpc/lib/board.c | 14 | ||||
| -rw-r--r-- | arch/powerpc/lib/bootm.c | 5 | 
2 files changed, 19 insertions, 0 deletions
| diff --git a/arch/powerpc/lib/board.c b/arch/powerpc/lib/board.c index 4719f8c6967..83fb0744f54 100644 --- a/arch/powerpc/lib/board.c +++ b/arch/powerpc/lib/board.c @@ -186,6 +186,12 @@ int __board_flash_wp_on(void)  }  int board_flash_wp_on(void) __attribute__((weak, alias("__board_flash_wp_on"))); +void __cpu_secondary_init_r(void) +{ +} +void cpu_secondary_init_r(void) +__attribute__((weak, alias("__cpu_secondary_init_r"))); +  static int init_func_ram (void)  {  #ifdef	CONFIG_BOARD_TYPES @@ -798,6 +804,14 @@ void board_init_r (gd_t *id, ulong dest_addr)  	env_relocate ();  	/* +	 * after non-volatile devices & environment is setup and cpu code have +	 * another round to deal with any initialization that might require +	 * full access to the environment or loading of some image (firmware) +	 * from a non-volatile device +	 */ +	cpu_secondary_init_r(); + +	/*  	 * Fill in missing fields of bd_info.  	 * We do this here, where we have "normal" access to the  	 * environment; we used to do this still running from ROM, diff --git a/arch/powerpc/lib/bootm.c b/arch/powerpc/lib/bootm.c index 116d81bec6b..c7f3d084a3a 100644 --- a/arch/powerpc/lib/bootm.c +++ b/arch/powerpc/lib/bootm.c @@ -33,6 +33,7 @@  #include <bzlib.h>  #include <environment.h>  #include <asm/byteorder.h> +#include <asm/mp.h>  #if defined(CONFIG_OF_LIBFDT)  #include <fdt.h> @@ -166,6 +167,10 @@ void arch_lmb_reserve(struct lmb *lmb)  	sp -= 4096;  	lmb_reserve(lmb, sp, (CONFIG_SYS_SDRAM_BASE + get_effective_memsize() - sp)); +#ifdef CONFIG_MP +	cpu_mp_lmb_reserve(lmb); +#endif +  	return ;  } | 
