blob: b5ba2a03741e57123b3c41aa70526c9efa7d919c [file] [log] [blame]
wdenk8bde7f72003-06-27 21:31:46 +00001/*
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>
wdenk9d2b18a2003-06-28 23:11:04 +000029#include <net.h> /* for print_IPaddr */
wdenk8bde7f72003-06-27 21:31:46 +000030
Wolfgang Denkd87080b2006-03-31 18:32:53 +020031DECLARE_GLOBAL_DATA_PTR;
wdenk8bde7f72003-06-27 21:31:46 +000032
Jon Loeligera76adc82007-06-11 19:01:43 -050033#if (CONFIG_COMMANDS & CFG_CMD_BDI) || defined(CONFIG_CMD_BDI)
wdenk8bde7f72003-06-27 21:31:46 +000034static void print_num(const char *, ulong);
35
36#ifndef CONFIG_ARM /* PowerPC and other */
37
38#ifdef CONFIG_PPC
39static void print_str(const char *, const char *);
40
41int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
42{
wdenk8bde7f72003-06-27 21:31:46 +000043 int i;
44 bd_t *bd = gd->bd;
45 char buf[32];
46
47#ifdef DEBUG
48 print_num ("bd address", (ulong)bd );
49#endif
50 print_num ("memstart", bd->bi_memstart );
51 print_num ("memsize", bd->bi_memsize );
52 print_num ("flashstart", bd->bi_flashstart );
53 print_num ("flashsize", bd->bi_flashsize );
54 print_num ("flashoffset", bd->bi_flashoffset );
55 print_num ("sramstart", bd->bi_sramstart );
56 print_num ("sramsize", bd->bi_sramsize );
wdenk97d80fc2004-06-09 00:34:46 +000057#if defined(CONFIG_5xx) || defined(CONFIG_8xx) || \
58 defined(CONFIG_8260) || defined(CONFIG_E500)
wdenk8bde7f72003-06-27 21:31:46 +000059 print_num ("immr_base", bd->bi_immr_base );
60#endif
61 print_num ("bootflags", bd->bi_bootflags );
wdenk97d80fc2004-06-09 00:34:46 +000062#if defined(CONFIG_405GP) || defined(CONFIG_405CR) || \
Stefan Roesec157d8e2005-08-01 16:41:48 +020063 defined(CONFIG_405EP) || defined(CONFIG_XILINX_ML300) || \
Marian Balakowicz6c5879f2006-06-30 16:30:46 +020064 defined(CONFIG_440EP) || defined(CONFIG_440GR) || \
Stefan Roese887e2ec2006-09-07 11:51:23 +020065 defined(CONFIG_440EPX) || defined(CONFIG_440GRX) || \
66 defined(CONFIG_440SP) || defined(CONFIG_440SPE)
wdenk8bde7f72003-06-27 21:31:46 +000067 print_str ("procfreq", strmhz(buf, bd->bi_procfreq));
wdenk983fda82004-10-28 00:09:35 +000068 print_str ("plb_busfreq", strmhz(buf, bd->bi_plb_busfreq));
Stefan Roesec157d8e2005-08-01 16:41:48 +020069#if defined(CONFIG_405GP) || defined(CONFIG_405EP) || defined(CONFIG_XILINX_ML300) || \
Stefan Roese887e2ec2006-09-07 11:51:23 +020070 defined(CONFIG_440EP) || defined(CONFIG_440GR) || defined(CONFIG_440SPE) || \
71 defined(CONFIG_440EPX) || defined(CONFIG_440GRX)
wdenk983fda82004-10-28 00:09:35 +000072 print_str ("pci_busfreq", strmhz(buf, bd->bi_pci_busfreq));
wdenk8bde7f72003-06-27 21:31:46 +000073#endif
Stefan Roese846b0dd2005-08-08 12:42:22 +020074#else /* ! CONFIG_405GP, CONFIG_405CR, CONFIG_405EP, CONFIG_XILINX_ML300, CONFIG_440EP CONFIG_440GR */
Jon Loeliger9c4c5ae2005-07-23 10:37:35 -050075#if defined(CONFIG_CPM2)
wdenk8bde7f72003-06-27 21:31:46 +000076 print_str ("vco", strmhz(buf, bd->bi_vco));
77 print_str ("sccfreq", strmhz(buf, bd->bi_sccfreq));
78 print_str ("brgfreq", strmhz(buf, bd->bi_brgfreq));
79#endif
80 print_str ("intfreq", strmhz(buf, bd->bi_intfreq));
Jon Loeliger9c4c5ae2005-07-23 10:37:35 -050081#if defined(CONFIG_CPM2)
wdenk8bde7f72003-06-27 21:31:46 +000082 print_str ("cpmfreq", strmhz(buf, bd->bi_cpmfreq));
83#endif
84 print_str ("busfreq", strmhz(buf, bd->bi_busfreq));
Stefan Roese846b0dd2005-08-08 12:42:22 +020085#endif /* CONFIG_405GP, CONFIG_405CR, CONFIG_405EP, CONFIG_XILINX_ML300, CONFIG_440EP CONFIG_440GR */
wdenk983fda82004-10-28 00:09:35 +000086#if defined(CONFIG_MPC8220)
87 print_str ("inpfreq", strmhz(buf, bd->bi_inpfreq));
88 print_str ("flbfreq", strmhz(buf, bd->bi_flbfreq));
89 print_str ("pcifreq", strmhz(buf, bd->bi_pcifreq));
90 print_str ("vcofreq", strmhz(buf, bd->bi_vcofreq));
91 print_str ("pevfreq", strmhz(buf, bd->bi_pevfreq));
92#endif
wdenk03f5c552004-10-10 21:21:55 +000093
wdenk4b9206e2004-03-23 22:14:11 +000094 puts ("ethaddr =");
wdenk8bde7f72003-06-27 21:31:46 +000095 for (i=0; i<6; ++i) {
96 printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]);
97 }
wdenk03f5c552004-10-10 21:21:55 +000098
wdenke2ffd592004-12-31 09:32:47 +000099#if defined(CONFIG_HAS_ETH1)
wdenk4b9206e2004-03-23 22:14:11 +0000100 puts ("\neth1addr =");
wdenk8bde7f72003-06-27 21:31:46 +0000101 for (i=0; i<6; ++i) {
102 printf ("%c%02X", i ? ':' : ' ', bd->bi_enet1addr[i]);
103 }
wdenk03f5c552004-10-10 21:21:55 +0000104#endif
105
wdenke2ffd592004-12-31 09:32:47 +0000106#if defined(CONFIG_HAS_ETH2)
wdenk4b9206e2004-03-23 22:14:11 +0000107 puts ("\neth2addr =");
wdenk42d1f032003-10-15 23:53:47 +0000108 for (i=0; i<6; ++i) {
109 printf ("%c%02X", i ? ':' : ' ', bd->bi_enet2addr[i]);
110 }
111#endif
wdenk03f5c552004-10-10 21:21:55 +0000112
wdenke2ffd592004-12-31 09:32:47 +0000113#if defined(CONFIG_HAS_ETH3)
wdenk03f5c552004-10-10 21:21:55 +0000114 puts ("\neth3addr =");
115 for (i=0; i<6; ++i) {
116 printf ("%c%02X", i ? ':' : ' ', bd->bi_enet3addr[i]);
117 }
118#endif
119
wdenk8bde7f72003-06-27 21:31:46 +0000120#ifdef CONFIG_HERMES
121 print_str ("ethspeed", strmhz(buf, bd->bi_ethspeed));
122#endif
wdenk4b9206e2004-03-23 22:14:11 +0000123 puts ("\nIP addr = "); print_IPaddr (bd->bi_ip_addr);
wdenk8bde7f72003-06-27 21:31:46 +0000124 printf ("\nbaudrate = %6ld bps\n", bd->bi_baudrate );
125 return 0;
126}
127
wdenk4a551702003-10-08 23:26:14 +0000128#elif defined(CONFIG_NIOS) /* NIOS*/
129
130int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
131{
wdenk4a551702003-10-08 23:26:14 +0000132 int i;
133 bd_t *bd = gd->bd;
134
135 print_num ("memstart", (ulong)bd->bi_memstart);
136 print_num ("memsize", (ulong)bd->bi_memsize);
137 print_num ("flashstart", (ulong)bd->bi_flashstart);
138 print_num ("flashsize", (ulong)bd->bi_flashsize);
139 print_num ("flashoffset", (ulong)bd->bi_flashoffset);
140
wdenk4b9206e2004-03-23 22:14:11 +0000141 puts ("ethaddr =");
wdenk4a551702003-10-08 23:26:14 +0000142 for (i=0; i<6; ++i) {
143 printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]);
144 }
wdenk4b9206e2004-03-23 22:14:11 +0000145 puts ("\nip_addr = ");
wdenk4a551702003-10-08 23:26:14 +0000146 print_IPaddr (bd->bi_ip_addr);
147 printf ("\nbaudrate = %ld bps\n", bd->bi_baudrate);
148
149 return 0;
150}
151
wdenk5c952cf2004-10-10 21:27:30 +0000152#elif defined(CONFIG_NIOS2) /* Nios-II */
153
154int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
155{
wdenk5c952cf2004-10-10 21:27:30 +0000156 int i;
157 bd_t *bd = gd->bd;
158
159 print_num ("mem start", (ulong)bd->bi_memstart);
160 print_num ("mem size", (ulong)bd->bi_memsize);
161 print_num ("flash start", (ulong)bd->bi_flashstart);
162 print_num ("flash size", (ulong)bd->bi_flashsize);
163 print_num ("flash offset", (ulong)bd->bi_flashoffset);
164
165#if defined(CFG_SRAM_BASE)
166 print_num ("sram start", (ulong)bd->bi_sramstart);
167 print_num ("sram size", (ulong)bd->bi_sramsize);
168#endif
169
170#if defined(CFG_CMD_NET)
171 puts ("ethaddr =");
172 for (i=0; i<6; ++i) {
173 printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]);
174 }
175 puts ("\nip_addr = ");
176 print_IPaddr (bd->bi_ip_addr);
177#endif
178
179 printf ("\nbaudrate = %ld bps\n", bd->bi_baudrate);
180
181 return 0;
182}
Michal Simekcfc67112007-03-11 13:48:24 +0100183#elif defined(CONFIG_MICROBLAZE) /* ! PPC, which leaves Microblaze */
184
185int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
186{
187 int i;
188 bd_t *bd = gd->bd;
189 print_num ("mem start ", (ulong)bd->bi_memstart);
190 print_num ("mem size ", (ulong)bd->bi_memsize);
191 print_num ("flash start ", (ulong)bd->bi_flashstart);
192 print_num ("flash size ", (ulong)bd->bi_flashsize);
193 print_num ("flash offset ", (ulong)bd->bi_flashoffset);
194#if defined(CFG_SRAM_BASE)
195 print_num ("sram start ", (ulong)bd->bi_sramstart);
196 print_num ("sram size ", (ulong)bd->bi_sramsize);
197#endif
198#if defined(CFG_CMD_NET)
199 puts ("ethaddr =");
200 for (i=0; i<6; ++i) {
201 printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]);
202 }
203 puts ("\nip_addr = ");
204 print_IPaddr (bd->bi_ip_addr);
205#endif
206 printf ("\nbaudrate = %d bps\n", (ulong)bd->bi_baudrate);
207 return 0;
208}
wdenk4a551702003-10-08 23:26:14 +0000209
wdenk8bde7f72003-06-27 21:31:46 +0000210#else /* ! PPC, which leaves MIPS */
211
212int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
213{
wdenk8bde7f72003-06-27 21:31:46 +0000214 int i;
215 bd_t *bd = gd->bd;
216
217 print_num ("boot_params", (ulong)bd->bi_boot_params);
218 print_num ("memstart", (ulong)bd->bi_memstart);
219 print_num ("memsize", (ulong)bd->bi_memsize);
220 print_num ("flashstart", (ulong)bd->bi_flashstart);
221 print_num ("flashsize", (ulong)bd->bi_flashsize);
222 print_num ("flashoffset", (ulong)bd->bi_flashoffset);
223
wdenk4b9206e2004-03-23 22:14:11 +0000224 puts ("ethaddr =");
wdenk8bde7f72003-06-27 21:31:46 +0000225 for (i=0; i<6; ++i) {
226 printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]);
227 }
wdenk4b9206e2004-03-23 22:14:11 +0000228 puts ("\nip_addr = ");
wdenk8bde7f72003-06-27 21:31:46 +0000229 print_IPaddr (bd->bi_ip_addr);
230 printf ("\nbaudrate = %d bps\n", bd->bi_baudrate);
231
232 return 0;
233}
234#endif /* MIPS */
235
236#else /* ARM */
237
238int do_bdinfo ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
239{
wdenk8bde7f72003-06-27 21:31:46 +0000240 int i;
241 bd_t *bd = gd->bd;
242
243 print_num ("arch_number", bd->bi_arch_number);
244 print_num ("env_t", (ulong)bd->bi_env);
245 print_num ("boot_params", (ulong)bd->bi_boot_params);
246
247 for (i=0; i<CONFIG_NR_DRAM_BANKS; ++i) {
248 print_num("DRAM bank", i);
249 print_num("-> start", bd->bi_dram[i].start);
250 print_num("-> size", bd->bi_dram[i].size);
251 }
252
wdenk4b9206e2004-03-23 22:14:11 +0000253 puts ("ethaddr =");
wdenk8bde7f72003-06-27 21:31:46 +0000254 for (i=0; i<6; ++i) {
255 printf ("%c%02X", i ? ':' : ' ', bd->bi_enetaddr[i]);
256 }
wdenk4b9206e2004-03-23 22:14:11 +0000257 puts ( "\n"
wdenk8bde7f72003-06-27 21:31:46 +0000258 "ip_addr = ");
259 print_IPaddr (bd->bi_ip_addr);
wdenkb79a11c2004-03-25 15:14:43 +0000260 printf ("\n"
wdenk8bde7f72003-06-27 21:31:46 +0000261 "baudrate = %d bps\n", bd->bi_baudrate);
262
263 return 0;
264}
265
266#endif /* CONFIG_ARM XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX */
267
268static void print_num(const char *name, ulong value)
269{
270 printf ("%-12s= 0x%08lX\n", name, value);
271}
272
273#ifdef CONFIG_PPC
274static void print_str(const char *name, const char *str)
275{
276 printf ("%-12s= %6s MHz\n", name, str);
277}
278#endif /* CONFIG_PPC */
279
280
281/* -------------------------------------------------------------------- */
282
wdenk0d498392003-07-01 21:06:45 +0000283U_BOOT_CMD(
284 bdinfo, 1, 1, do_bdinfo,
wdenk8bde7f72003-06-27 21:31:46 +0000285 "bdinfo - print Board Info structure\n",
286 NULL
287);
288#endif /* CFG_CMD_BDI */