diff options
Diffstat (limited to 'arch/sandbox')
| -rw-r--r-- | arch/sandbox/config.mk | 5 | ||||
| -rw-r--r-- | arch/sandbox/cpu/cpu.c | 5 | ||||
| -rw-r--r-- | arch/sandbox/cpu/start.c | 9 | ||||
| -rw-r--r-- | arch/sandbox/include/asm/io.h | 8 | ||||
| -rw-r--r-- | arch/sandbox/include/asm/state.h | 1 | ||||
| -rw-r--r-- | arch/sandbox/include/asm/u-boot.h | 22 | ||||
| -rw-r--r-- | arch/sandbox/lib/Makefile | 1 | ||||
| -rw-r--r-- | arch/sandbox/lib/board.c | 285 | 
8 files changed, 28 insertions, 308 deletions
| diff --git a/arch/sandbox/config.mk b/arch/sandbox/config.mk index 4fd0d4e58..988b52c3b 100644 --- a/arch/sandbox/config.mk +++ b/arch/sandbox/config.mk @@ -18,5 +18,8 @@  # MA 02111-1307 USA  PLATFORM_CPPFLAGS += -DCONFIG_SANDBOX -D__SANDBOX__ -U_FORTIFY_SOURCE -PLATFORM_CPPFLAGS += -DCONFIG_ARCH_MAP_SYSMEM +PLATFORM_CPPFLAGS += -DCONFIG_ARCH_MAP_SYSMEM -DCONFIG_SYS_GENERIC_BOARD  PLATFORM_LIBS += -lrt + +# Support generic board on sandbox +__HAVE_ARCH_GENERIC_BOARD := y diff --git a/arch/sandbox/cpu/cpu.c b/arch/sandbox/cpu/cpu.c index b2788d5d5..dd8d495e3 100644 --- a/arch/sandbox/cpu/cpu.c +++ b/arch/sandbox/cpu/cpu.c @@ -57,6 +57,11 @@ void *map_physmem(phys_addr_t paddr, unsigned long len, unsigned long flags)  	return (void *)(gd->arch.ram_buf + paddr);  } +phys_addr_t map_to_sysmem(void *ptr) +{ +	return (u8 *)ptr - gd->arch.ram_buf; +} +  void flush_dcache_range(unsigned long start, unsigned long stop)  {  } diff --git a/arch/sandbox/cpu/start.c b/arch/sandbox/cpu/start.c index 5287fd5ee..ae6e16cab 100644 --- a/arch/sandbox/cpu/start.c +++ b/arch/sandbox/cpu/start.c @@ -90,7 +90,7 @@ int sandbox_main_loop_init(void)  	/* Execute command if required */  	if (state->cmd) { -		run_command(state->cmd, 0); +		run_command_list(state->cmd, -1, 0);  		os_exit(state->exit_type);  	} @@ -104,6 +104,13 @@ static int sb_cmdline_cb_command(struct sandbox_state *state, const char *arg)  }  SB_CMDLINE_OPT_SHORT(command, 'c', 1, "Execute U-Boot command"); +static int sb_cmdline_cb_fdt(struct sandbox_state *state, const char *arg) +{ +	state->fdt_fname = arg; +	return 0; +} +SB_CMDLINE_OPT_SHORT(fdt, 'd', 1, "Specify U-Boot's control FDT"); +  int main(int argc, char *argv[])  {  	struct sandbox_state *state; diff --git a/arch/sandbox/include/asm/io.h b/arch/sandbox/include/asm/io.h index d8c02364d..0c022f1db 100644 --- a/arch/sandbox/include/asm/io.h +++ b/arch/sandbox/include/asm/io.h @@ -20,6 +20,9 @@   * MA 02111-1307 USA   */ +#ifndef __SANDBOX_ASM_IO_H +#define __SANDBOX_ASM_IO_H +  /*   * Given a physical address and a length, return a virtual address   * that can be used to access the memory range with the caching @@ -49,3 +52,8 @@ static inline void *map_sysmem(phys_addr_t paddr, unsigned long len)  static inline void unmap_sysmem(const void *vaddr)  {  } + +/* Map from a pointer to our RAM buffer */ +phys_addr_t map_to_sysmem(void *ptr); + +#endif diff --git a/arch/sandbox/include/asm/state.h b/arch/sandbox/include/asm/state.h index 2b62b46ea..9552708a7 100644 --- a/arch/sandbox/include/asm/state.h +++ b/arch/sandbox/include/asm/state.h @@ -34,6 +34,7 @@ enum exit_type_id {  /* The complete state of the test system */  struct sandbox_state {  	const char *cmd;		/* Command to execute */ +	const char *fdt_fname;		/* Filename of FDT binary */  	enum exit_type_id exit_type;	/* How we exited U-Boot */  	const char *parse_err;		/* Error to report from parsing */  	int argc;			/* Program arguments */ diff --git a/arch/sandbox/include/asm/u-boot.h b/arch/sandbox/include/asm/u-boot.h index de8120a72..5bea1f2fc 100644 --- a/arch/sandbox/include/asm/u-boot.h +++ b/arch/sandbox/include/asm/u-boot.h @@ -36,26 +36,8 @@  #ifndef _U_BOOT_H_  #define _U_BOOT_H_	1 -typedef struct bd_info { -	unsigned long	bi_memstart;	/* start of DRAM memory */ -	phys_size_t	bi_memsize;	/* size	 of DRAM memory in bytes */ -	unsigned long	bi_flashstart;	/* start of FLASH memory */ -	unsigned long	bi_flashsize;	/* size	 of FLASH memory */ -	unsigned long	bi_flashoffset; /* reserved area for startup monitor */ -	unsigned long	bi_sramstart;	/* start of SRAM memory */ -	unsigned long	bi_sramsize;	/* size	 of SRAM memory */ -	unsigned long	bi_bootflags;	/* boot / reboot flag (for LynxOS) */ -	unsigned short	bi_ethspeed;	/* Ethernet speed in Mbps */ -	unsigned long	bi_intfreq;	/* Internal Freq, in MHz */ -	unsigned long	bi_busfreq;	/* Bus Freq, in MHz */ -	unsigned int	bi_baudrate;	/* Console Baudrate */ -	unsigned long   bi_boot_params;	/* where this board expects params */ -	struct				/* RAM configuration */ -	{ -		ulong start; -		ulong size; -	} bi_dram[CONFIG_NR_DRAM_BANKS]; -} bd_t; +/* Use the generic board which requires a unified bd_info */ +#include <asm-generic/u-boot.h>  /* For image.h:image_check_target_arch() */  #define IH_ARCH_DEFAULT IH_ARCH_SANDBOX diff --git a/arch/sandbox/lib/Makefile b/arch/sandbox/lib/Makefile index fbe579b4c..3aad574ba 100644 --- a/arch/sandbox/lib/Makefile +++ b/arch/sandbox/lib/Makefile @@ -27,7 +27,6 @@ include $(TOPDIR)/config.mk  LIB	= $(obj)lib$(ARCH).o -COBJS-y	+= board.o  COBJS-y	+= interrupts.o  SRCS	:= $(COBJS-y:.o=.c) diff --git a/arch/sandbox/lib/board.c b/arch/sandbox/lib/board.c deleted file mode 100644 index 3752fab50..000000000 --- a/arch/sandbox/lib/board.c +++ /dev/null @@ -1,285 +0,0 @@ -/* - * Copyright (c) 2011 The Chromium OS Authors. - * - * (C) Copyright 2002-2006 - * Wolfgang Denk, DENX Software Engineering, wd@denx.de. - * - * (C) Copyright 2002 - * Sysgo Real-Time Solutions, GmbH <www.elinos.com> - * Marius Groeger <mgroeger@sysgo.de> - * - * See file CREDITS for list of people who contributed to this - * project. - * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU General Public License as - * published by the Free Software Foundation; either version 2 of - * the License, or (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, - * MA 02111-1307 USA - */ - -/* - * This file was taken from ARM and changed to remove things we don't - * need. This is most of it, so have tried to avoid being over-zealous! - * For example, we want to have an emulation of the 'DRAM' used by - * U-Boot. - * - * has been talk upstream of unifying the architectures w.r.t board.c, - * so the less change here the better. - */ - -#include <common.h> -#include <command.h> -#include <malloc.h> -#include <stdio_dev.h> -#include <timestamp.h> -#include <version.h> -#include <serial.h> - -#include <os.h> - -DECLARE_GLOBAL_DATA_PTR; - -static gd_t gd_mem; - -/************************************************************************ - * Init Utilities							* - ************************************************************************ - * Some of this code should be moved into the core functions, - * or dropped completely, - * but let's get it working (again) first... - */ - -static int display_banner(void) -{ -	display_options(); - -	return 0; -} - -/** - * Configure and report on the DRAM configuration, which in our case is - * fairly simple. - */ -static int display_dram_config(void) -{ -	ulong size = 0; -	int i; - -	debug("RAM Configuration:\n"); - -	for (i = 0; i < CONFIG_NR_DRAM_BANKS; i++) { -#ifdef DEBUG -		printf("Bank #%d: %08lx ", i, gd->bd->bi_dram[i].start); -		print_size(gd->bd->bi_dram[i].size, "\n"); -#endif -		size += gd->bd->bi_dram[i].size; -	} -	puts("DRAM:  "); -	print_size(size, "\n"); -	return 0; -} - -/* - * Breathe some life into the board... - * - * Initialize a serial port as console, and carry out some hardware - * tests. - * - * The first part of initialization is running from Flash memory; - * its main purpose is to initialize the RAM so that we - * can relocate the monitor code to RAM. - */ - -/* - * All attempts to come up with a "common" initialization sequence - * that works for all boards and architectures failed: some of the - * requirements are just _too_ different. To get rid of the resulting - * mess of board dependent #ifdef'ed code we now make the whole - * initialization sequence configurable to the user. - * - * The requirements for any new initalization function is simple: it - * receives a pointer to the "global data" structure as it's only - * argument, and returns an integer return code, where 0 means - * "continue" and != 0 means "fatal error, hang the system". - */ -typedef int (init_fnc_t) (void); - -void __dram_init_banksize(void) -{ -	gd->bd->bi_dram[0].start = 0; -	gd->bd->bi_dram[0].size =  gd->ram_size; -} - -void dram_init_banksize(void) -	__attribute__((weak, alias("__dram_init_banksize"))); - -init_fnc_t *init_sequence[] = { -#if defined(CONFIG_ARCH_CPU_INIT) -	arch_cpu_init,		/* basic arch cpu dependent setup */ -#endif -#if defined(CONFIG_BOARD_EARLY_INIT_F) -	board_early_init_f, -#endif -	timer_init,		/* initialize timer */ -	env_init,		/* initialize environment */ -	serial_init,		/* serial communications setup */ -	console_init_f,		/* stage 1 init of console */ -	sandbox_early_getopt_check,	/* process command line flags (err/help) */ -	display_banner,		/* say that we are here */ -#if defined(CONFIG_DISPLAY_CPUINFO) -	print_cpuinfo,		/* display cpu info (and speed) */ -#endif -#if defined(CONFIG_DISPLAY_BOARDINFO) -	checkboard,		/* display board info */ -#endif -	dram_init,		/* configure available RAM banks */ -	NULL, -}; - -void board_init_f(ulong bootflag) -{ -	init_fnc_t **init_fnc_ptr; -	uchar *mem; -	unsigned long addr_sp, addr, size; - -	gd = &gd_mem; -	assert(gd); - -	memset((void *)gd, 0, sizeof(gd_t)); - -#if defined(CONFIG_OF_EMBED) -	/* Get a pointer to the FDT */ -	gd->fdt_blob = _binary_dt_dtb_start; -#elif defined(CONFIG_OF_SEPARATE) -	/* FDT is at end of image */ -	gd->fdt_blob = (void *)(_end_ofs + _TEXT_BASE); -#endif - -	for (init_fnc_ptr = init_sequence; *init_fnc_ptr; ++init_fnc_ptr) { -		if ((*init_fnc_ptr)() != 0) -			hang(); -	} - -	size = CONFIG_SYS_SDRAM_SIZE; -	mem = os_malloc(CONFIG_SYS_SDRAM_SIZE); - -	assert(mem); -	gd->arch.ram_buf = mem; -	addr = (ulong)(mem + size); - -	/* -	 * reserve memory for malloc() arena -	 */ -	addr_sp = addr - TOTAL_MALLOC_LEN; -	debug("Reserving %dk for malloc() at: %08lx\n", -			TOTAL_MALLOC_LEN >> 10, addr_sp); -	/* -	 * (permanently) allocate a Board Info struct -	 * and a permanent copy of the "global" data -	 */ -	addr_sp -= sizeof(bd_t); -	gd->bd = (bd_t *) addr_sp; -	debug("Reserving %zu Bytes for Board Info at: %08lx\n", -			sizeof(bd_t), addr_sp); - -	/* Ram ist board specific, so move it to board code ... */ -	dram_init_banksize(); -	display_dram_config();	/* and display it */ - -	/* We don't relocate, so just run the post-relocation code */ -	board_init_r(NULL, 0); - -	/* NOTREACHED - no way out of command loop except booting */ -} - -/************************************************************************ - * - * This is the next part if the initialization sequence: we are now - * running from RAM and have a "normal" C environment, i. e. global - * data can be written, BSS has been cleared, the stack size in not - * that critical any more, etc. - * - ************************************************************************ - */ - -void board_init_r(gd_t *id, ulong dest_addr) -{ - -	if (id) -		gd = id; - -	gd->flags |= GD_FLG_RELOC;	/* tell others: relocation done */ - -	serial_initialize(); - -#ifdef CONFIG_POST -	post_output_backlog(); -#endif - -	/* The Malloc area is at the top of simulated DRAM */ -	mem_malloc_init((ulong)gd->arch.ram_buf + gd->ram_size - -			TOTAL_MALLOC_LEN, TOTAL_MALLOC_LEN); - -	/* initialize environment */ -	env_relocate(); - -	stdio_init();	/* get the devices list going. */ - -	jumptable_init(); - -	console_init_r();	/* fully init console as a device */ - -#if defined(CONFIG_DISPLAY_BOARDINFO_LATE) -	checkboard(); -#endif - -#if defined(CONFIG_ARCH_MISC_INIT) -	/* miscellaneous arch dependent initialisations */ -	arch_misc_init(); -#endif -#if defined(CONFIG_MISC_INIT_R) -	/* miscellaneous platform dependent initialisations */ -	misc_init_r(); -#endif - -	 /* set up exceptions */ -	interrupt_init(); -	/* enable exceptions */ -	enable_interrupts(); - -#ifdef CONFIG_BOARD_LATE_INIT -	board_late_init(); -#endif - -#ifdef CONFIG_POST -	post_run(NULL, POST_RAM | post_bootmode_get(0)); -#endif - -	sandbox_main_loop_init(); - -	/* -	 * For now, run the main loop. Later we might let this be done -	 * in the main program. -	 */ -	while (1) -		main_loop(); - -	/* NOTREACHED - no way out of command loop except booting */ -} - -void hang(void) -{ -	puts("### ERROR ### Please RESET the board ###\n"); -	for (;;) -		; -} |