summaryrefslogtreecommitdiff
path: root/lib_microblaze
diff options
context:
space:
mode:
authorwdenk <wdenk>2004-07-10 23:48:41 +0000
committerwdenk <wdenk>2004-07-10 23:48:41 +0000
commit857cad37a41c431582a74be56f858ee0476cd0d9 (patch)
treead20b07944687e5996418e91111a6cef5b2e319e /lib_microblaze
parentfabd46acff08edd9f945340338caa07bb0534e64 (diff)
downloadu-boot-imx-857cad37a41c431582a74be56f858ee0476cd0d9.zip
u-boot-imx-857cad37a41c431582a74be56f858ee0476cd0d9.tar.gz
u-boot-imx-857cad37a41c431582a74be56f858ee0476cd0d9.tar.bz2
Patches by Yasushi Shoji, 29 Jun 2004:
- add empty include/asm-microblaze/processor.h - add to CREDITS and MAINTAINERS - add gd initialization - add MicroBlaze and SUZAKU board to MAKEALL script - add reset support for SUZAKU - add flush_cache() for MicroBlaze - add CFG_FLASH_SIZE to include/configs/suzaku.h since we have fixed size flash memory on SUZAKU
Diffstat (limited to 'lib_microblaze')
-rw-r--r--lib_microblaze/Makefile2
-rw-r--r--lib_microblaze/board.c13
-rw-r--r--lib_microblaze/cache.c31
3 files changed, 45 insertions, 1 deletions
diff --git a/lib_microblaze/Makefile b/lib_microblaze/Makefile
index b683da8..ec01722 100644
--- a/lib_microblaze/Makefile
+++ b/lib_microblaze/Makefile
@@ -27,7 +27,7 @@ LIB = lib$(ARCH).a
AOBJS =
-COBJS = board.o microblaze_linux.o time.o
+COBJS = board.o microblaze_linux.o time.o cache.o
OBJS = $(AOBJS) $(COBJS)
diff --git a/lib_microblaze/board.c b/lib_microblaze/board.c
index b720e82..bc987a3 100644
--- a/lib_microblaze/board.c
+++ b/lib_microblaze/board.c
@@ -72,8 +72,21 @@ init_fnc_t *init_sequence[] = {
void board_init(void)
{
+ DECLARE_GLOBAL_DATA_PTR;
+
+ bd_t *bd;
init_fnc_t **init_fnc_ptr;
+ /* Pointer is writable since we allocated a register for it. */
+ gd = (gd_t *)CFG_GBL_DATA_OFFSET;
+ memset((void *)gd, 0, CFG_GBL_DATA_SIZE);
+
+ gd->bd = (bd_t *)(gd+1); /* At end of global data */
+ gd->baudrate = CONFIG_BAUDRATE;
+
+ bd = gd->bd;
+ bd->bi_baudrate = CONFIG_BAUDRATE;
+
for (init_fnc_ptr = init_sequence; *init_fnc_ptr; ++init_fnc_ptr) {
WATCHDOG_RESET ();
if ((*init_fnc_ptr) () != 0) {
diff --git a/lib_microblaze/cache.c b/lib_microblaze/cache.c
new file mode 100644
index 0000000..a2f7493
--- /dev/null
+++ b/lib_microblaze/cache.c
@@ -0,0 +1,31 @@
+/*
+ * (C) Copyright 2004 Atmark Techno, Inc.
+ *
+ * Yasushi SHOJI <yashi@atmark-techno.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>
+
+void flush_cache (ulong addr, ulong size)
+{
+ /* MicroBlaze have write thruough cache. nothing to do. */
+ return;
+}