blob: 7a2d243ef88f3855b40debc1cec2f9cae3102a0b [file] [log] [blame]
wdenk3c2b3d42005-04-05 23:32:21 +00001/*
2 * (C) Copyright 2005 2N TELEKOMUNIKACE, Ladislav Michl
3 *
4 * See file CREDITS for list of people who contributed to this
5 * project.
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * version 2 as published by the Free Software Foundation.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
19 * MA 02111-1307 USA
20 */
21
22#include <common.h>
23
24int board_init(void)
25{
26 DECLARE_GLOBAL_DATA_PTR;
wdenk3c2b3d42005-04-05 23:32:21 +000027
28 *((volatile unsigned char *) VOICEBLUE_LED_REG) = 0xaa;
29
30 /* arch number of VoiceBlue board */
31 /* TODO: use define from asm/mach-types.h */
32 gd->bd->bi_arch_number = 218;
33
34 /* adress of boot parameters */
35 gd->bd->bi_boot_params = 0x10000100;
36
37 return 0;
38}
39
40int dram_init(void)
41{
42 DECLARE_GLOBAL_DATA_PTR;
43
44 *((volatile unsigned short *) VOICEBLUE_LED_REG) = 0xff;
45
46 /* Take the Ethernet controller out of reset and wait
47 * for the EEPROM load to complete. */
48 *((volatile unsigned short *) GPIO_DATA_OUTPUT_REG) |= 0x80;
49 udelay(10); /* doesn't work before interrupt_init call */
50 *((volatile unsigned short *) GPIO_DATA_OUTPUT_REG) &= ~0x80;
51 udelay(500);
52
53 gd->bd->bi_dram[0].start = PHYS_SDRAM_1;
54 gd->bd->bi_dram[0].size = PHYS_SDRAM_1_SIZE;
55
56 return 0;
57}
58
wdenk3c2b3d42005-04-05 23:32:21 +000059int misc_init_r(void)
60{
61 *((volatile unsigned short *) VOICEBLUE_LED_REG) = 0x55;
62
wdenk3c2b3d42005-04-05 23:32:21 +000063 return 0;
64}
65
66int board_late_init(void)
67{
68 *((volatile unsigned char *) VOICEBLUE_LED_REG) = 0x00;
69
70 return 0;
71}