]>
Commit | Line | Data |
---|---|---|
8bde7f77 WD |
1 | /* |
2 | * (C) Copyright 2003 | |
3 | * Wolfgang Denk, DENX Software Engineering, wd@denx.de. | |
4 | * | |
5 | * See file CREDITS for list of people who contributed to this | |
6 | * project. | |
7 | * | |
8 | * This program is free software; you can redistribute it and/or | |
9 | * modify it under the terms of the GNU General Public License as | |
10 | * published by the Free Software Foundation; either version 2 of | |
11 | * the License, or (at your option) any later version. | |
12 | * | |
13 | * This program is distributed in the hope that it will be useful, | |
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
16 | * GNU General Public License for more details. | |
17 | * | |
18 | * You should have received a copy of the GNU General Public License | |
19 | * along with this program; if not, write to the Free Software | |
20 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, | |
21 | * MA 02111-1307 USA | |
22 | */ | |
23 | ||
24 | /* | |
25 | * Boot support | |
26 | */ | |
27 | #include <common.h> | |
28 | #include <command.h> | |
9d2b18a0 | 29 | #include <net.h> /* for print_IPaddr */ |
8bde7f77 | 30 | |
d87080b7 | 31 | DECLARE_GLOBAL_DATA_PTR; |
8bde7f77 | 32 | |
8bde7f77 WD |
33 | static void print_num(const char *, ulong); |
34 | ||
35 | #ifndef CONFIG_ARM /* PowerPC and other */ | |
36 | ||
37 | #ifdef CONFIG_PPC | |
38 | static void print_str(const char *, const char *); | |
39 | ||
40 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
41 | { | |
8bde7f77 WD |
42 | int i; |
43 | bd_t *bd = gd->bd; | |
44 | char buf[32]; | |
45 | ||
46 | #ifdef DEBUG | |
47 | print_num ("bd address", (ulong)bd ); | |
48 | #endif | |
49 | print_num ("memstart", bd->bi_memstart ); | |
50 | print_num ("memsize", bd->bi_memsize ); | |
51 | print_num ("flashstart", bd->bi_flashstart ); | |
52 | print_num ("flashsize", bd->bi_flashsize ); | |
53 | print_num ("flashoffset", bd->bi_flashoffset ); | |
54 | print_num ("sramstart", bd->bi_sramstart ); | |
55 | print_num ("sramsize", bd->bi_sramsize ); | |
97d80fc3 WD |
56 | #if defined(CONFIG_5xx) || defined(CONFIG_8xx) || \ |
57 | defined(CONFIG_8260) || defined(CONFIG_E500) | |
8bde7f77 WD |
58 | print_num ("immr_base", bd->bi_immr_base ); |
59 | #endif | |
60 | print_num ("bootflags", bd->bi_bootflags ); | |
97d80fc3 | 61 | #if defined(CONFIG_405GP) || defined(CONFIG_405CR) || \ |
c157d8e2 | 62 | defined(CONFIG_405EP) || defined(CONFIG_XILINX_ML300) || \ |
6c5879f3 | 63 | defined(CONFIG_440EP) || defined(CONFIG_440GR) || \ |
887e2ec9 SR |
64 | defined(CONFIG_440EPX) || defined(CONFIG_440GRX) || \ |
65 | defined(CONFIG_440SP) || defined(CONFIG_440SPE) | |
8bde7f77 | 66 | print_str ("procfreq", strmhz(buf, bd->bi_procfreq)); |
983fda83 | 67 | print_str ("plb_busfreq", strmhz(buf, bd->bi_plb_busfreq)); |
c157d8e2 | 68 | #if defined(CONFIG_405GP) || defined(CONFIG_405EP) || defined(CONFIG_XILINX_ML300) || \ |
887e2ec9 SR |
69 | defined(CONFIG_440EP) || defined(CONFIG_440GR) || defined(CONFIG_440SPE) || \ |
70 | defined(CONFIG_440EPX) || defined(CONFIG_440GRX) | |
983fda83 | 71 | print_str ("pci_busfreq", strmhz(buf, bd->bi_pci_busfreq)); |
8bde7f77 | 72 | #endif |
846b0dd2 | 73 | #else /* ! CONFIG_405GP, CONFIG_405CR, CONFIG_405EP, CONFIG_XILINX_ML300, CONFIG_440EP CONFIG_440GR */ |
9c4c5ae3 | 74 | #if defined(CONFIG_CPM2) |
8bde7f77 WD |
75 | print_str ("vco", strmhz(buf, bd->bi_vco)); |
76 | print_str ("sccfreq", strmhz(buf, bd->bi_sccfreq)); | |
77 | print_str ("brgfreq", strmhz(buf, bd->bi_brgfreq)); | |
78 | #endif | |
79 | print_str ("intfreq", strmhz(buf, bd->bi_intfreq)); | |
9c4c5ae3 | 80 | #if defined(CONFIG_CPM2) |
8bde7f77 WD |
81 | print_str ("cpmfreq", strmhz(buf, bd->bi_cpmfreq)); |
82 | #endif | |
83 | print_str ("busfreq", strmhz(buf, bd->bi_busfreq)); | |
846b0dd2 | 84 | #endif /* CONFIG_405GP, CONFIG_405CR, CONFIG_405EP, CONFIG_XILINX_ML300, CONFIG_440EP CONFIG_440GR */ |
983fda83 WD |
85 | #if defined(CONFIG_MPC8220) |
86 | print_str ("inpfreq", strmhz(buf, bd->bi_inpfreq)); | |
87 | print_str ("flbfreq", strmhz(buf, bd->bi_flbfreq)); | |
88 | print_str ("pcifreq", strmhz(buf, bd->bi_pcifreq)); | |
89 | print_str ("vcofreq", strmhz(buf, bd->bi_vcofreq)); | |
90 | print_str ("pevfreq", strmhz(buf, bd->bi_pevfreq)); | |
91 | #endif | |
03f5c550 | 92 | |
4b9206ed | 93 | puts ("ethaddr ="); |
8bde7f77 WD |
94 | for (i=0; i<6; ++i) { |
95 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
96 | } | |
03f5c550 | 97 | |
e2ffd59b | 98 | #if defined(CONFIG_HAS_ETH1) |
4b9206ed | 99 | puts ("\neth1addr ="); |
8bde7f77 WD |
100 | for (i=0; i<6; ++i) { |
101 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet1addr[i]); | |
102 | } | |
03f5c550 WD |
103 | #endif |
104 | ||
e2ffd59b | 105 | #if defined(CONFIG_HAS_ETH2) |
4b9206ed | 106 | puts ("\neth2addr ="); |
42d1f039 WD |
107 | for (i=0; i<6; ++i) { |
108 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet2addr[i]); | |
109 | } | |
110 | #endif | |
03f5c550 | 111 | |
e2ffd59b | 112 | #if defined(CONFIG_HAS_ETH3) |
03f5c550 WD |
113 | puts ("\neth3addr ="); |
114 | for (i=0; i<6; ++i) { | |
115 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet3addr[i]); | |
116 | } | |
117 | #endif | |
118 | ||
8bde7f77 WD |
119 | #ifdef CONFIG_HERMES |
120 | print_str ("ethspeed", strmhz(buf, bd->bi_ethspeed)); | |
121 | #endif | |
4b9206ed | 122 | puts ("\nIP addr = "); print_IPaddr (bd->bi_ip_addr); |
8bde7f77 WD |
123 | printf ("\nbaudrate = %6ld bps\n", bd->bi_baudrate ); |
124 | return 0; | |
125 | } | |
126 | ||
4a551709 WD |
127 | #elif defined(CONFIG_NIOS) /* NIOS*/ |
128 | ||
129 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
130 | { | |
4a551709 WD |
131 | int i; |
132 | bd_t *bd = gd->bd; | |
133 | ||
134 | print_num ("memstart", (ulong)bd->bi_memstart); | |
135 | print_num ("memsize", (ulong)bd->bi_memsize); | |
136 | print_num ("flashstart", (ulong)bd->bi_flashstart); | |
137 | print_num ("flashsize", (ulong)bd->bi_flashsize); | |
138 | print_num ("flashoffset", (ulong)bd->bi_flashoffset); | |
139 | ||
4b9206ed | 140 | puts ("ethaddr ="); |
4a551709 WD |
141 | for (i=0; i<6; ++i) { |
142 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
143 | } | |
4b9206ed | 144 | puts ("\nip_addr = "); |
4a551709 WD |
145 | print_IPaddr (bd->bi_ip_addr); |
146 | printf ("\nbaudrate = %ld bps\n", bd->bi_baudrate); | |
147 | ||
148 | return 0; | |
149 | } | |
150 | ||
5c952cf0 WD |
151 | #elif defined(CONFIG_NIOS2) /* Nios-II */ |
152 | ||
153 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
154 | { | |
252f60b0 | 155 | #if defined(CONFIG_CMD_NET) |
5c952cf0 | 156 | int i; |
252f60b0 | 157 | #endif |
5c952cf0 WD |
158 | bd_t *bd = gd->bd; |
159 | ||
160 | print_num ("mem start", (ulong)bd->bi_memstart); | |
161 | print_num ("mem size", (ulong)bd->bi_memsize); | |
162 | print_num ("flash start", (ulong)bd->bi_flashstart); | |
163 | print_num ("flash size", (ulong)bd->bi_flashsize); | |
164 | print_num ("flash offset", (ulong)bd->bi_flashoffset); | |
165 | ||
166 | #if defined(CFG_SRAM_BASE) | |
167 | print_num ("sram start", (ulong)bd->bi_sramstart); | |
168 | print_num ("sram size", (ulong)bd->bi_sramsize); | |
169 | #endif | |
170 | ||
90253178 | 171 | #if defined(CONFIG_CMD_NET) |
5c952cf0 WD |
172 | puts ("ethaddr ="); |
173 | for (i=0; i<6; ++i) { | |
174 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
175 | } | |
176 | puts ("\nip_addr = "); | |
177 | print_IPaddr (bd->bi_ip_addr); | |
178 | #endif | |
179 | ||
180 | printf ("\nbaudrate = %ld bps\n", bd->bi_baudrate); | |
181 | ||
182 | return 0; | |
183 | } | |
cfc67116 MS |
184 | #elif defined(CONFIG_MICROBLAZE) /* ! PPC, which leaves Microblaze */ |
185 | ||
186 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
187 | { | |
188 | int i; | |
189 | bd_t *bd = gd->bd; | |
190 | print_num ("mem start ", (ulong)bd->bi_memstart); | |
191 | print_num ("mem size ", (ulong)bd->bi_memsize); | |
192 | print_num ("flash start ", (ulong)bd->bi_flashstart); | |
193 | print_num ("flash size ", (ulong)bd->bi_flashsize); | |
194 | print_num ("flash offset ", (ulong)bd->bi_flashoffset); | |
195 | #if defined(CFG_SRAM_BASE) | |
196 | print_num ("sram start ", (ulong)bd->bi_sramstart); | |
197 | print_num ("sram size ", (ulong)bd->bi_sramsize); | |
198 | #endif | |
90253178 | 199 | #if defined(CONFIG_CMD_NET) |
cfc67116 MS |
200 | puts ("ethaddr ="); |
201 | for (i=0; i<6; ++i) { | |
202 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
203 | } | |
204 | puts ("\nip_addr = "); | |
205 | print_IPaddr (bd->bi_ip_addr); | |
206 | #endif | |
207 | printf ("\nbaudrate = %d bps\n", (ulong)bd->bi_baudrate); | |
208 | return 0; | |
209 | } | |
4a551709 | 210 | |
8e585f02 | 211 | #elif defined(CONFIG_M68K) /* M68K */ |
8ae158cd | 212 | static void print_str(const char *, const char *); |
8e585f02 TL |
213 | |
214 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
215 | { | |
216 | int i; | |
217 | bd_t *bd = gd->bd; | |
8ae158cd TL |
218 | char buf[32]; |
219 | ||
8e585f02 TL |
220 | print_num ("memstart", (ulong)bd->bi_memstart); |
221 | print_num ("memsize", (ulong)bd->bi_memsize); | |
222 | print_num ("flashstart", (ulong)bd->bi_flashstart); | |
223 | print_num ("flashsize", (ulong)bd->bi_flashsize); | |
224 | print_num ("flashoffset", (ulong)bd->bi_flashoffset); | |
225 | #if defined(CFG_INIT_RAM_ADDR) | |
8ae158cd TL |
226 | print_num ("sramstart", (ulong)bd->bi_sramstart); |
227 | print_num ("sramsize", (ulong)bd->bi_sramsize); | |
8e585f02 TL |
228 | #endif |
229 | #if defined(CFG_MBAR) | |
8ae158cd | 230 | print_num ("mbar", bd->bi_mbar_base); |
8e585f02 | 231 | #endif |
8ae158cd TL |
232 | print_str ("busfreq", strmhz(buf, bd->bi_busfreq)); |
233 | #ifdef CONFIG_PCI | |
234 | print_str ("pcifreq", strmhz(buf, bd->bi_pcifreq)); | |
235 | #endif | |
236 | #ifdef CONFIG_EXTRA_CLOCK | |
237 | print_str ("flbfreq", strmhz(buf, bd->bi_flbfreq)); | |
238 | print_str ("inpfreq", strmhz(buf, bd->bi_inpfreq)); | |
239 | print_str ("vcofreq", strmhz(buf, bd->bi_vcofreq)); | |
240 | #endif | |
26667b7f | 241 | #if defined(CONFIG_CMD_NET) |
8e585f02 TL |
242 | puts ("ethaddr ="); |
243 | for (i=0; i<6; ++i) { | |
244 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
245 | } | |
246 | ||
247 | #if defined(CONFIG_HAS_ETH1) | |
248 | puts ("\neth1addr ="); | |
249 | for (i=0; i<6; ++i) { | |
250 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet1addr[i]); | |
251 | } | |
252 | #endif | |
253 | ||
254 | #if defined(CONFIG_HAS_ETH2) | |
ab77bc54 TL |
255 | puts ("\neth2addr ="); |
256 | for (i=0; i<6; ++i) { | |
8e585f02 TL |
257 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet2addr[i]); |
258 | } | |
259 | #endif | |
260 | ||
261 | #if defined(CONFIG_HAS_ETH3) | |
ab77bc54 TL |
262 | puts ("\neth3addr ="); |
263 | for (i=0; i<6; ++i) { | |
8e585f02 TL |
264 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enet3addr[i]); |
265 | } | |
266 | #endif | |
267 | ||
268 | puts ("\nip_addr = "); | |
269 | print_IPaddr (bd->bi_ip_addr); | |
26667b7f | 270 | #endif |
8e585f02 TL |
271 | printf ("\nbaudrate = %d bps\n", bd->bi_baudrate); |
272 | ||
273 | return 0; | |
274 | } | |
275 | ||
8dc48d71 MF |
276 | #elif defined(CONFIG_BLACKFIN) |
277 | ||
278 | int do_bdinfo(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
279 | { | |
280 | int i; | |
281 | bd_t *bd = gd->bd; | |
282 | ||
283 | printf("U-Boot = %s\n", bd->bi_r_version); | |
284 | printf("CPU = %s\n", bd->bi_cpu); | |
285 | printf("Board = %s\n", bd->bi_board_name); | |
286 | printf("VCO = %lu MHz\n", bd->bi_vco / 1000000); | |
287 | printf("CCLK = %lu MHz\n", bd->bi_cclk / 1000000); | |
288 | printf("SCLK = %lu MHz\n", bd->bi_sclk / 1000000); | |
289 | ||
290 | print_num("boot_params", (ulong)bd->bi_boot_params); | |
291 | print_num("memstart", (ulong)bd->bi_memstart); | |
292 | print_num("memsize", (ulong)bd->bi_memsize); | |
293 | print_num("flashstart", (ulong)bd->bi_flashstart); | |
294 | print_num("flashsize", (ulong)bd->bi_flashsize); | |
295 | print_num("flashoffset", (ulong)bd->bi_flashoffset); | |
296 | ||
297 | puts("ethaddr ="); | |
298 | for (i = 0; i < 6; ++i) | |
299 | printf("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
300 | puts("\nip_addr = "); | |
301 | print_IPaddr(bd->bi_ip_addr); | |
302 | printf("\nbaudrate = %d bps\n", bd->bi_baudrate); | |
303 | ||
304 | return 0; | |
305 | } | |
306 | ||
8bde7f77 WD |
307 | #else /* ! PPC, which leaves MIPS */ |
308 | ||
309 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
310 | { | |
8bde7f77 WD |
311 | int i; |
312 | bd_t *bd = gd->bd; | |
313 | ||
314 | print_num ("boot_params", (ulong)bd->bi_boot_params); | |
315 | print_num ("memstart", (ulong)bd->bi_memstart); | |
316 | print_num ("memsize", (ulong)bd->bi_memsize); | |
317 | print_num ("flashstart", (ulong)bd->bi_flashstart); | |
318 | print_num ("flashsize", (ulong)bd->bi_flashsize); | |
319 | print_num ("flashoffset", (ulong)bd->bi_flashoffset); | |
320 | ||
4b9206ed | 321 | puts ("ethaddr ="); |
8bde7f77 WD |
322 | for (i=0; i<6; ++i) { |
323 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
324 | } | |
4b9206ed | 325 | puts ("\nip_addr = "); |
8bde7f77 WD |
326 | print_IPaddr (bd->bi_ip_addr); |
327 | printf ("\nbaudrate = %d bps\n", bd->bi_baudrate); | |
328 | ||
329 | return 0; | |
330 | } | |
331 | #endif /* MIPS */ | |
332 | ||
333 | #else /* ARM */ | |
334 | ||
335 | int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) | |
336 | { | |
8bde7f77 WD |
337 | int i; |
338 | bd_t *bd = gd->bd; | |
339 | ||
340 | print_num ("arch_number", bd->bi_arch_number); | |
341 | print_num ("env_t", (ulong)bd->bi_env); | |
342 | print_num ("boot_params", (ulong)bd->bi_boot_params); | |
343 | ||
344 | for (i=0; i<CONFIG_NR_DRAM_BANKS; ++i) { | |
345 | print_num("DRAM bank", i); | |
346 | print_num("-> start", bd->bi_dram[i].start); | |
347 | print_num("-> size", bd->bi_dram[i].size); | |
348 | } | |
349 | ||
a41dbbd9 | 350 | #if defined(CONFIG_CMD_NET) |
4b9206ed | 351 | puts ("ethaddr ="); |
8bde7f77 WD |
352 | for (i=0; i<6; ++i) { |
353 | printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]); | |
354 | } | |
4b9206ed | 355 | puts ( "\n" |
8bde7f77 WD |
356 | "ip_addr = "); |
357 | print_IPaddr (bd->bi_ip_addr); | |
a41dbbd9 | 358 | #endif |
b79a11cc | 359 | printf ("\n" |
8bde7f77 WD |
360 | "baudrate = %d bps\n", bd->bi_baudrate); |
361 | ||
362 | return 0; | |
363 | } | |
364 | ||
365 | #endif /* CONFIG_ARM XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX */ | |
366 | ||
367 | static void print_num(const char *name, ulong value) | |
368 | { | |
369 | printf ("%-12s= 0x%08lX\n", name, value); | |
370 | } | |
371 | ||
8ae158cd | 372 | #if defined(CONFIG_PPC) || defined(CONFIG_M68K) |
8bde7f77 WD |
373 | static void print_str(const char *name, const char *str) |
374 | { | |
375 | printf ("%-12s= %6s MHz\n", name, str); | |
376 | } | |
377 | #endif /* CONFIG_PPC */ | |
378 | ||
379 | ||
380 | /* -------------------------------------------------------------------- */ | |
381 | ||
0d498393 WD |
382 | U_BOOT_CMD( |
383 | bdinfo, 1, 1, do_bdinfo, | |
8bde7f77 WD |
384 | "bdinfo - print Board Info structure\n", |
385 | NULL | |
386 | ); |