diff options
| author | Alessandro Rubini <rubini@unipv.it> | 2009-01-24 18:10:37 +0100 | 
|---|---|---|
| committer | Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> | 2009-01-24 18:10:37 +0100 | 
| commit | d5254f149da9e6cd649d887b042ce577ef3ba78d (patch) | |
| tree | 421281a124201c2460f99e30953dd8c177e9a57f /board/st/nmdk8815/nmdk8815.c | |
| parent | 7d264c1ef267cfc8d928bc8577a7cc907f2f5e47 (diff) | |
| download | olio-uboot-2014.01-d5254f149da9e6cd649d887b042ce577ef3ba78d.tar.xz olio-uboot-2014.01-d5254f149da9e6cd649d887b042ce577ef3ba78d.zip | |
Initial support for Nomadik 8815 development board
The NMDK8815 board is distributed by ST Microelectornics.
Other (proprietary) code must be run to unlock the CPU before
U-Boot runs. doc/README.nmdk8815 outlines the boot sequence.
This is the initial port, with basic infrastructure and
a working serial port.
Signed-off-by: Alessandro Rubini <rubini@unipv.it>
Acked-by: Andrea Gallo <andrea.gallo@stnwireless.com>
Signed-off-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
Diffstat (limited to 'board/st/nmdk8815/nmdk8815.c')
| -rw-r--r-- | board/st/nmdk8815/nmdk8815.c | 72 | 
1 files changed, 72 insertions, 0 deletions
| diff --git a/board/st/nmdk8815/nmdk8815.c b/board/st/nmdk8815/nmdk8815.c new file mode 100644 index 000000000..c54eac12c --- /dev/null +++ b/board/st/nmdk8815/nmdk8815.c @@ -0,0 +1,72 @@ +/* + * (C) Copyright 2005 + * STMicrolelctronics, <www.st.com> + * + * (C) Copyright 2004 + * ARM Ltd. + * Philippe Robin, <philippe.robin@arm.com> + * + * 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 + */ + +#include <common.h> +#include <asm/io.h> + +DECLARE_GLOBAL_DATA_PTR; + +#ifdef CONFIG_SHOW_BOOT_PROGRESS +void show_boot_progress(int progress) +{ +	printf("%i\n", progress); +} +#endif + +/* + * Miscellaneous platform dependent initialisations + */ +int board_init(void) +{ +	gd->bd->bi_arch_number = MACH_TYPE_NOMADIK; +	gd->bd->bi_boot_params = 0x00000100; +	writel(0xC37800F0, NOMADIK_GPIO1_BASE + 0x20); +	writel(0x00000000, NOMADIK_GPIO1_BASE + 0x24); +	writel(0x00000000, NOMADIK_GPIO1_BASE + 0x28); +	writel(readl(NOMADIK_SRC_BASE) | 0x8000, NOMADIK_SRC_BASE); + +	icache_enable(); + +	return 0; +} + +int misc_init_r(void) +{ +	setenv("verify", "n"); +	return 0; +} + +int dram_init(void) +{ +	/* set dram bank start addr and size */ +	gd->bd->bi_dram[0].start = PHYS_SDRAM_1; +	gd->bd->bi_dram[0].size = PHYS_SDRAM_1_SIZE; + +	gd->bd->bi_dram[1].start = PHYS_SDRAM_2; +	gd->bd->bi_dram[1].size = PHYS_SDRAM_2_SIZE; +	return 0; +} |