blob: 600c80ab7666092a2a1f6af254b4385254a008f1 [file] [log] [blame]
wdenk12490652004-04-18 21:13:41 +00001/*
Michal Simek922ce202007-03-11 13:48:24 +01002 * (C) Copyright 2007 Michal Simek
wdenk12490652004-04-18 21:13:41 +00003 * (C) Copyright 2004 Atmark Techno, Inc.
4 *
Michal Simek922ce202007-03-11 13:48:24 +01005 * Michal SIMEK <monstr@monstr.eu>
wdenk12490652004-04-18 21:13:41 +00006 * Yasushi SHOJI <yashi@atmark-techno.com>
7 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02008 * SPDX-License-Identifier: GPL-2.0+
wdenk12490652004-04-18 21:13:41 +00009 */
10
11#include <common.h>
12#include <command.h>
13#include <malloc.h>
14#include <version.h>
wdenk78924a72004-04-18 21:45:42 +000015#include <watchdog.h>
Michal Simekf31cb1f2010-04-16 11:57:35 +020016#include <stdio_dev.h>
Michal Simek3b6f4382012-07-02 10:31:29 +020017#include <serial.h>
Michal Simek7f581f02010-08-02 14:42:09 +020018#include <net.h>
Michal Simek6c3110c2013-08-08 18:58:11 +053019#include <spi.h>
Michal Simek58a5dd22012-06-29 10:29:46 +020020#include <linux/compiler.h>
Michal Simek9c3474a2011-07-21 11:01:58 +020021#include <asm/processor.h>
Michal Simek251ed2c2012-07-10 10:31:31 +020022#include <asm/microblaze_intc.h>
Michal Simekf0300ea2012-06-28 14:34:32 +020023#include <fdtdec.h>
wdenk12490652004-04-18 21:13:41 +000024
Wolfgang Denk6405a152006-03-31 18:32:53 +020025DECLARE_GLOBAL_DATA_PTR;
26
Michal Simek7a503102014-01-20 21:05:47 +010027static int display_banner(void)
28{
29 printf("\n\n%s\n\n", version_string);
30 return 0;
31}
32
wdenk12490652004-04-18 21:13:41 +000033/*
wdenk12490652004-04-18 21:13:41 +000034 * All attempts to come up with a "common" initialization sequence
35 * that works for all boards and architectures failed: some of the
36 * requirements are just _too_ different. To get rid of the resulting
37 * mess of board dependend #ifdef'ed code we now make the whole
38 * initialization sequence configurable to the user.
39 *
40 * The requirements for any new initalization function is simple: it
41 * receives a pointer to the "global data" structure as it's only
42 * argument, and returns an integer return code, where 0 means
43 * "continue" and != 0 means "fatal error, hang the system".
44 */
45typedef int (init_fnc_t) (void);
46
47init_fnc_t *init_sequence[] = {
Michal Simek922ce202007-03-11 13:48:24 +010048 env_init,
Michal Simekf0300ea2012-06-28 14:34:32 +020049#ifdef CONFIG_OF_CONTROL
50 fdtdec_check_fdt,
51#endif
Michal Simek922ce202007-03-11 13:48:24 +010052 serial_init,
Michal Simek26acb3e2014-01-21 07:30:37 +010053#ifndef CONFIG_SPL_BUILD
Michal Simek4255f052011-07-21 09:52:25 +020054 console_init_f,
Michal Simek26acb3e2014-01-21 07:30:37 +010055#endif
Michal Simek7a503102014-01-20 21:05:47 +010056 display_banner,
Michal Simek26acb3e2014-01-21 07:30:37 +010057#ifndef CONFIG_SPL_BUILD
Michal Simek922ce202007-03-11 13:48:24 +010058 interrupts_init,
Michal Simekd1ff6c72010-04-16 11:37:41 +020059 timer_init,
Michal Simek26acb3e2014-01-21 07:30:37 +010060#endif
wdenk12490652004-04-18 21:13:41 +000061 NULL,
62};
63
Michal Simek9c3474a2011-07-21 11:01:58 +020064unsigned long monitor_flash_len;
65
Michal Simek9cabb362012-07-04 13:12:37 +020066void board_init_f(ulong not_used)
wdenk78924a72004-04-18 21:45:42 +000067{
wdenk20a61222004-07-10 23:48:41 +000068 bd_t *bd;
wdenk78924a72004-04-18 21:45:42 +000069 init_fnc_t **init_fnc_ptr;
Andreas Bießmann7c87cc12013-04-18 22:48:46 +000070 gd = (gd_t *)(CONFIG_SYS_SDRAM_BASE + CONFIG_SYS_GBL_DATA_OFFSET);
71 bd = (bd_t *)(CONFIG_SYS_SDRAM_BASE + CONFIG_SYS_GBL_DATA_OFFSET
Michal Simekeaf2c862010-12-21 09:32:44 +010072 - GENERATED_BD_INFO_SIZE);
Michal Simek26acb3e2014-01-21 07:30:37 +010073#if defined(CONFIG_CMD_FLASH) && !defined(CONFIG_SPL_BUILD)
Michal Simek922ce202007-03-11 13:48:24 +010074 ulong flash_size = 0;
75#endif
76 asm ("nop"); /* FIXME gd is not initialize - wait */
Andreas Bießmann7c87cc12013-04-18 22:48:46 +000077 memset((void *)gd, 0, GENERATED_GBL_DATA_SIZE);
78 memset((void *)bd, 0, GENERATED_BD_INFO_SIZE);
Michal Simekeaf2c862010-12-21 09:32:44 +010079 gd->bd = bd;
wdenk20a61222004-07-10 23:48:41 +000080 gd->baudrate = CONFIG_BAUDRATE;
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020081 bd->bi_memstart = CONFIG_SYS_SDRAM_BASE;
82 bd->bi_memsize = CONFIG_SYS_SDRAM_SIZE;
Michal Simekc2e00ea2008-11-24 11:38:22 +010083 gd->flags |= GD_FLG_RELOC; /* tell others: relocation done */
Michal Simek922ce202007-03-11 13:48:24 +010084
Michal Simek9c3474a2011-07-21 11:01:58 +020085 monitor_flash_len = __end - __text_start;
86
Michal Simekf0300ea2012-06-28 14:34:32 +020087#ifdef CONFIG_OF_EMBED
88 /* Get a pointer to the FDT */
Masahiro Yamada43c08932014-02-05 11:28:25 +090089 gd->fdt_blob = __dtb_dt_begin;
Michal Simekf0300ea2012-06-28 14:34:32 +020090#elif defined CONFIG_OF_SEPARATE
91 /* FDT is at end of image */
92 gd->fdt_blob = (void *)__end;
93#endif
Michal Simek26acb3e2014-01-21 07:30:37 +010094
95#ifndef CONFIG_SPL_BUILD
Michal Simekf0300ea2012-06-28 14:34:32 +020096 /* Allow the early environment to override the fdt address */
97 gd->fdt_blob = (void *)getenv_ulong("fdtcontroladdr", 16,
98 (uintptr_t)gd->fdt_blob);
Michal Simek26acb3e2014-01-21 07:30:37 +010099#endif
Michal Simekf0300ea2012-06-28 14:34:32 +0200100
Peter Tyser781c9b82009-08-21 23:05:21 -0500101 /*
102 * The Malloc area is immediately below the monitor copy in DRAM
103 * aka CONFIG_SYS_MONITOR_BASE - Note there is no need for reloc_off
104 * as our monitory code is run from SDRAM
105 */
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000106 mem_malloc_init(CONFIG_SYS_MALLOC_BASE, CONFIG_SYS_MALLOC_LEN);
wdenk20a61222004-07-10 23:48:41 +0000107
Michal Simek3b6f4382012-07-02 10:31:29 +0200108 serial_initialize();
Michal Simek3b6f4382012-07-02 10:31:29 +0200109
Michal Simek8173ce72013-10-16 09:06:32 +0200110#ifdef CONFIG_XILINX_TB_WATCHDOG
111 hw_watchdog_init();
112#endif
wdenk78924a72004-04-18 21:45:42 +0000113 for (init_fnc_ptr = init_sequence; *init_fnc_ptr; ++init_fnc_ptr) {
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000114 WATCHDOG_RESET();
115 if ((*init_fnc_ptr) () != 0)
116 hang();
wdenk78924a72004-04-18 21:45:42 +0000117 }
118
Michal Simek26acb3e2014-01-21 07:30:37 +0100119#ifndef CONFIG_SPL_BUILD
Michal Simekf0300ea2012-06-28 14:34:32 +0200120#ifdef CONFIG_OF_CONTROL
121 /* For now, put this check after the console is ready */
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000122 if (fdtdec_prepare_fdt())
123 panic("** No FDT - please see doc/README.fdt-control");
124 else
Michal Simekf0300ea2012-06-28 14:34:32 +0200125 printf("DTB: 0x%x\n", (u32)gd->fdt_blob);
126#endif
127
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000128 puts("SDRAM :\n");
129 printf("\t\tIcache:%s\n", icache_status() ? "ON" : "OFF");
130 printf("\t\tDcache:%s\n", dcache_status() ? "ON" : "OFF");
131 printf("\tU-Boot Start:0x%08x\n", CONFIG_SYS_TEXT_BASE);
Michal Simekf614bea2009-01-05 13:28:40 +0100132
Jon Loeliger6b233052007-07-09 18:02:11 -0500133#if defined(CONFIG_CMD_FLASH)
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000134 puts("Flash: ");
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200135 bd->bi_flashstart = CONFIG_SYS_FLASH_BASE;
Michal Simekab43dbe2012-07-10 10:21:25 +0200136 flash_size = flash_init();
137 if (bd->bi_flashstart && flash_size > 0) {
Michal Simekf614bea2009-01-05 13:28:40 +0100138# ifdef CONFIG_SYS_FLASH_CHECKSUM
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000139 print_size(flash_size, "");
Michal Simekf614bea2009-01-05 13:28:40 +0100140 /*
141 * Compute and print flash CRC if flashchecksum is set to 'y'
142 *
143 * NOTE: Maybe we should add some WATCHDOG_RESET()? XXX
144 */
Joe Hershberger864ec562012-12-11 22:16:22 -0600145 if (getenv_yesno("flashchecksum") == 1) {
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000146 printf(" CRC: %08X",
147 crc32(0, (const u8 *)bd->bi_flashstart,
148 flash_size)
Michal Simekf614bea2009-01-05 13:28:40 +0100149 );
150 }
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000151 putc('\n');
Michal Simekf614bea2009-01-05 13:28:40 +0100152# else /* !CONFIG_SYS_FLASH_CHECKSUM */
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000153 print_size(flash_size, "\n");
Michal Simekf614bea2009-01-05 13:28:40 +0100154# endif /* CONFIG_SYS_FLASH_CHECKSUM */
Michal Simekab43dbe2012-07-10 10:21:25 +0200155 bd->bi_flashsize = flash_size;
156 bd->bi_flashoffset = bd->bi_flashstart + flash_size;
Michal Simek922ce202007-03-11 13:48:24 +0100157 } else {
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000158 puts("Flash init FAILED");
Michal Simek922ce202007-03-11 13:48:24 +0100159 bd->bi_flashstart = 0;
160 bd->bi_flashsize = 0;
161 bd->bi_flashoffset = 0;
162 }
163#endif
164
Michal Simek6c3110c2013-08-08 18:58:11 +0530165#ifdef CONFIG_SPI
166 spi_init();
167#endif
168
Michal Simekf31cb1f2010-04-16 11:57:35 +0200169 /* relocate environment function pointers etc. */
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000170 env_relocate();
Michal Simekf31cb1f2010-04-16 11:57:35 +0200171
172 /* Initialize stdio devices */
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000173 stdio_init();
Michal Simekf31cb1f2010-04-16 11:57:35 +0200174
Michal Simek2dcf6142011-07-21 10:30:42 +0200175 /* Initialize the jump table for applications */
176 jumptable_init();
177
178 /* Initialize the console (after the relocation and devices init) */
179 console_init_r();
180
Michal Simek9cabb362012-07-04 13:12:37 +0200181 board_init();
182
Simon Glass383c33a2011-10-13 14:43:10 +0000183 /* Initialize from environment */
184 load_addr = getenv_ulong("loadaddr", 16, load_addr);
Michal Simekf31cb1f2010-04-16 11:57:35 +0200185
Jon Loeliger6b233052007-07-09 18:02:11 -0500186#if defined(CONFIG_CMD_NET)
Michal Simek7f581f02010-08-02 14:42:09 +0200187 printf("Net: ");
188 eth_initialize(gd->bd);
189
190 uchar enetaddr[6];
191 eth_getenv_enetaddr("ethaddr", enetaddr);
192 printf("MAC: %pM\n", enetaddr);
Michal Simek922ce202007-03-11 13:48:24 +0100193#endif
194
wdenk78924a72004-04-18 21:45:42 +0000195 /* main_loop */
196 for (;;) {
Andreas Bießmann7c87cc12013-04-18 22:48:46 +0000197 WATCHDOG_RESET();
198 main_loop();
wdenk78924a72004-04-18 21:45:42 +0000199 }
Michal Simek26acb3e2014-01-21 07:30:37 +0100200#endif /* CONFIG_SPL_BUILD */
wdenk78924a72004-04-18 21:45:42 +0000201}