]>
Commit | Line | Data |
---|---|---|
7c202ac2 WD |
1 | /* |
2 | * (C) Copyright 2002 | |
3 | * Sysgo Real-Time Solutions, GmbH <www.elinos.com> | |
4 | * Alex Zuepke <[email protected]> | |
5 | * | |
6 | * See file CREDITS for list of people who contributed to this | |
7 | * project. | |
8 | * | |
9 | * This program is free software; you can redistribute it and/or | |
10 | * modify it under the terms of the GNU General Public License as | |
11 | * published by the Free Software Foundation; either version 2 of | |
12 | * the License, or (at your option) any later version. | |
13 | * | |
14 | * This program is distributed in the hope that it will be useful, | |
15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
17 | * GNU General Public License for more details. | |
18 | * | |
19 | * You should have received a copy of the GNU General Public License | |
20 | * along with this program; if not, write to the Free Software | |
21 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, | |
22 | * MA 02111-1307 USA | |
23 | */ | |
24 | ||
25 | #include <common.h> | |
26 | ||
d87080b7 | 27 | DECLARE_GLOBAL_DATA_PTR; |
7c202ac2 WD |
28 | |
29 | /* | |
30 | * Miscelaneous platform dependent initialisations | |
31 | */ | |
32 | ||
33 | int board_init (void) | |
34 | { | |
7c202ac2 WD |
35 | /* memory and cpu-speed are setup before relocation */ |
36 | /* but if we use InfernoLoader, we must do some inits here */ | |
37 | ||
38 | #ifdef CONFIG_INFERNO | |
39 | { | |
8bde7f77 WD |
40 | unsigned long temp; |
41 | __asm__ __volatile__(/* disable MMU, enable icache */ | |
42 | "mrc p15, 0, %0, c1, c0\n" | |
43 | "bic %0, %0, #0x00002000\n" | |
44 | "bic %0, %0, #0x0000000f\n" | |
45 | "orr %0, %0, #0x00001000\n" | |
46 | "orr %0, %0, #0x00000002\n" | |
47 | "mcr p15, 0, %0, c1, c0\n" | |
48 | /* flush caches */ | |
49 | "mov %0, #0\n" | |
50 | "mcr p15, 0, %0, c7, c7, 0\n" | |
51 | "mcr p15, 0, %0, c8, c7, 0\n" | |
52 | : "=r" (temp) | |
53 | : | |
54 | : "memory"); | |
55 | /* setup PCMCIA timing */ | |
56 | temp = 0xa0000018; | |
57 | *(unsigned long *)temp = 0x00060006; | |
7c202ac2 WD |
58 | |
59 | } | |
5f535fe1 | 60 | #endif /* CONFIG_INFERNO */ |
7c202ac2 WD |
61 | |
62 | /* arch number for shannon */ | |
731215eb | 63 | gd->bd->bi_arch_number = MACH_TYPE_SHANNON; |
7c202ac2 WD |
64 | |
65 | /* adress of boot parameters */ | |
66 | gd->bd->bi_boot_params = 0xc0000100; | |
67 | ||
68 | return 0; | |
69 | } | |
70 | ||
71 | int dram_init (void) | |
72 | { | |
73 | #if defined(PHYS_SDRAM_1) || defined(PHYS_SDRAM_2) || \ | |
74 | defined(PHYS_SDRAM_3) || defined(PHYS_SDRAM_4) | |
7c202ac2 WD |
75 | bd_t *bd = gd->bd; |
76 | #endif | |
77 | ||
78 | #ifdef PHYS_SDRAM_1 | |
79 | bd->bi_dram[0].start = PHYS_SDRAM_1; | |
80 | bd->bi_dram[0].size = PHYS_SDRAM_1_SIZE; | |
81 | #endif | |
82 | ||
83 | #ifdef PHYS_SDRAM_2 | |
84 | bd->bi_dram[1].start = PHYS_SDRAM_2; | |
85 | bd->bi_dram[1].size = PHYS_SDRAM_2_SIZE; | |
86 | #endif | |
87 | ||
88 | #ifdef PHYS_SDRAM_3 | |
89 | bd->bi_dram[2].start = PHYS_SDRAM_3; | |
90 | bd->bi_dram[2].size = PHYS_SDRAM_3_SIZE; | |
91 | #endif | |
92 | ||
93 | #ifdef PHYS_SDRAM_4 | |
94 | bd->bi_dram[3].start = PHYS_SDRAM_4; | |
95 | bd->bi_dram[3].size = PHYS_SDRAM_4_SIZE; | |
96 | #endif | |
97 | ||
98 | return (0); | |
99 | } |