blob: 437dad038875a70eb35294c9679ef31fa5ab1fd5 [file] [log] [blame]
wdenkf39748a2004-06-09 13:37:52 +00001/*
2 * (C) Copyright 2002
3 * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
4 * Marius Groeger <mgroeger@sysgo.de>
5 *
6 * (C) Copyright 2002
Detlev Zundel792a09e2009-05-13 10:54:10 +02007 * Gary Jennejohn, DENX Software Engineering, <garyj@denx.de>
wdenkf39748a2004-06-09 13:37:52 +00008 *
9 * See file CREDITS for list of people who contributed to this
10 * project.
11 *
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License as
14 * published by the Free Software Foundation; either version 2 of
15 * the License, or (at your option) any later version.
16 *
17 * This program is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 * GNU General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License
23 * along with this program; if not, write to the Free Software
24 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
25 * MA 02111-1307 USA
26 */
27
28#include <common.h>
Ben Warren7194ab82009-10-04 22:37:03 -070029#include <netdev.h>
wdenkf39748a2004-06-09 13:37:52 +000030#if defined(CONFIG_LH7A400)
31#include <lh7a400.h>
wdenkf39748a2004-06-09 13:37:52 +000032#elif defined(CONFIG_LH7A404)
33#include <lh7a404.h>
wdenkf39748a2004-06-09 13:37:52 +000034#else
35#error "No CPU defined!"
36#endif
wdenkf832d8a2004-06-10 21:55:33 +000037#include <asm/mach-types.h>
38
39#include <lpd7a400_cpld.h>
wdenkf39748a2004-06-09 13:37:52 +000040
Wolfgang Denkd87080b2006-03-31 18:32:53 +020041DECLARE_GLOBAL_DATA_PTR;
42
wdenkf39748a2004-06-09 13:37:52 +000043/*
44 * Miscellaneous platform dependent initialisations
45 */
46
47int board_init (void)
48{
wdenkf39748a2004-06-09 13:37:52 +000049 /* set up the I/O ports */
50
wdenkf39748a2004-06-09 13:37:52 +000051 /* enable flash programming */
52 *(LPD7A400_CPLD_REGPTR(LPD7A400_CPLD_FLASH_REG)) |= FLASH_FPEN;
53
54 /* Auto wakeup, LCD disable, WLAN enable */
55 *(LPD7A400_CPLD_REGPTR(LPD7A400_CPLD_CECTL_REG)) &=
56 ~(CECTL_AWKP|CECTL_LCDV|CECTL_WLPE);
57
58 /* Status LED 2 on (leds are active low) */
59 *(LPD7A400_CPLD_REGPTR(LPD7A400_CPLD_EXTGPIO_REG)) =
60 (EXTGPIO_STATUS1|EXTGPIO_GPIO1) & ~(EXTGPIO_STATUS2);
61
wdenkf832d8a2004-06-10 21:55:33 +000062#if defined(CONFIG_LH7A400)
wdenkf39748a2004-06-09 13:37:52 +000063 /* arch number of Logic-Board - MACH_TYPE_LPD7A400 */
64 gd->bd->bi_arch_number = MACH_TYPE_LPD7A400;
wdenkf39748a2004-06-09 13:37:52 +000065#elif defined(CONFIG_LH7A404)
wdenkf832d8a2004-06-10 21:55:33 +000066 /* arch number of Logic-Board - MACH_TYPE_LPD7A400 */
67 gd->bd->bi_arch_number = MACH_TYPE_LPD7A404;
wdenkf39748a2004-06-09 13:37:52 +000068#endif
69
70 /* adress of boot parameters */
71 gd->bd->bi_boot_params = 0xc0000100;
72
73 return 0;
74}
75
76int dram_init (void)
77{
wdenkf39748a2004-06-09 13:37:52 +000078 gd->bd->bi_dram[0].start = PHYS_SDRAM_1;
79 gd->bd->bi_dram[0].size = PHYS_SDRAM_1_SIZE;
80
81 return 0;
82}
Ben Warren7194ab82009-10-04 22:37:03 -070083
84#ifdef CONFIG_CMD_NET
85int board_eth_init(bd_t *bis)
86{
87 int rc = 0;
88#ifdef CONFIG_SMC91111
89 rc = smc91111_initialize(0, CONFIG_SMC91111_BASE);
90#endif
91 return rc;
92}
93#endif