2 * Copyright 2001 MontaVista Software Inc.
3 * Author: jsun@mvista.com or jsun@junsun.net
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; either version 2 of the License, or (at your
8 * option) any later version.
10 #include <linux/config.h>
11 #include <linux/init.h>
13 #include <linux/sched.h>
14 #include <linux/bootmem.h>
16 #include <asm/addrspace.h>
17 #include <asm/bootinfo.h>
18 #include <asm/ddb5xxx/ddb5xxx.h>
19 #include <asm/debug.h>
21 const char *get_system_type(void)
23 switch (mips_machtype) {
24 case MACH_NEC_DDB5074: return "NEC DDB Vrc-5074";
25 case MACH_NEC_DDB5476: return "NEC DDB Vrc-5476";
26 case MACH_NEC_DDB5477: return "NEC DDB Vrc-5477";
27 case MACH_NEC_ROCKHOPPER: return "NEC Rockhopper";
28 case MACH_NEC_ROCKHOPPERII: return "NEC RockhopperII";
29 default: return "Unknown NEC board";
33 #if defined(CONFIG_DDB5477)
34 void ddb5477_runtime_detection(void);
37 /* [jsun@junsun.net] PMON passes arguments in C main() style */
38 void __init prom_init(void)
41 char **arg = (char**) fw_arg1;
44 /* if user passes kernel args, ignore the default one */
46 arcs_cmdline[0] = '\0';
48 /* arg[0] is "g", the rest is boot parameters */
49 for (i = 1; i < argc; i++) {
50 if (strlen(arcs_cmdline) + strlen(arg[i] + 1)
51 >= sizeof(arcs_cmdline))
53 strcat(arcs_cmdline, arg[i]);
54 strcat(arcs_cmdline, " ");
57 mips_machgroup = MACH_GROUP_NEC_DDB;
59 #if defined(CONFIG_DDB5477)
60 ddb5477_runtime_detection();
61 add_memory_region(0, board_ram_size, BOOT_MEM_RAM);
65 unsigned long __init prom_free_prom_memory(void)
70 #if defined(CONFIG_DDB5477)
72 #define DEFAULT_LCS1_BASE 0x19000000
77 void ddb5477_runtime_detection(void)
79 volatile char *test_offset;
82 /* Determine if this is a DDB5477 board, or a BSB-VR0300
83 base board. We can tell by checking for the location of
84 the NVRAM. It lives at the beginning of LCS1 on the DDB5477,
85 and the beginning of LCS1 on the BSB-VR0300 is flash memory.
86 The first 2K of the NVRAM are reserved, so don't we'll poke
87 around just after that.
90 /* We can only use the PCI bus to distinquish between
91 the Rockhopper and RockhopperII backplanes and this must
92 wait until ddb5477_board_init() in setup.c after the 5477
93 is initialized. So, until then handle
94 both Rockhopper and RockhopperII backplanes as Rockhopper 1
97 test_offset = (char *)KSEG1ADDR(DEFAULT_LCS1_BASE + 0x800);
98 saved_test_byte = *test_offset;
100 *test_offset = TESTVAL1;
101 if (*test_offset != TESTVAL1) {
102 /* We couldn't set our test value, so it must not be NVRAM,
103 so it's a BSB_VR0300 */
104 mips_machtype = MACH_NEC_ROCKHOPPER;
106 /* We may have gotten lucky, and the TESTVAL1 was already
107 stored at the test location, so we must check a second
109 *test_offset = TESTVAL2;
110 if (*test_offset != TESTVAL2) {
111 /* OK, we couldn't set this value either, so it must
112 definately be a BSB_VR0300 */
113 mips_machtype = MACH_NEC_ROCKHOPPER;
115 /* We could change the value twice, so it must be
116 NVRAM, so it's a DDB_VRC5477 */
117 mips_machtype = MACH_NEC_DDB5477;
120 /* Restore the original byte */
121 *test_offset = saved_test_byte;
123 /* before we know a better way, we will trust PMON for getting
126 board_ram_size = 1 << (36 - (ddb_in32(DDB_SDRAM0) & 0xf));
128 db_run(printk("DDB run-time detection : %s, %d MB RAM\n",
129 mips_machtype == MACH_NEC_DDB5477 ?
130 "DDB5477" : "Rockhopper",
131 board_ram_size >> 20));
133 /* we can't handle ram size > 128 MB */
134 db_assert(board_ram_size <= (128 << 20));