patch-2.4.19 linux-2.4.19/arch/mips/arc/identify.c
Next file: linux-2.4.19/arch/mips/arc/init.c
Previous file: linux-2.4.19/arch/mips/arc/file.c
Back to the patch index
Back to the overall index
- Lines: 106
- Date:
Fri Aug 2 17:39:43 2002
- Orig file:
linux-2.4.18/arch/mips/arc/identify.c
- Orig date:
Mon Jul 2 13:56:40 2001
diff -urN linux-2.4.18/arch/mips/arc/identify.c linux-2.4.19/arch/mips/arc/identify.c
@@ -7,6 +7,7 @@
*
* Copyright (C) 1996 David S. Miller (dm@engr.sgi.com)
*/
+#include <linux/config.h>
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/types.h>
@@ -17,49 +18,81 @@
#include <asm/bootinfo.h>
struct smatch {
- char *name;
+ char *arcname;
+ char *liname;
int group;
int type;
int flags;
};
static struct smatch mach_table[] = {
- {"SGI-IP22", MACH_GROUP_SGI, MACH_SGI_INDY, PROM_FLAG_ARCS},
- {"Microsoft-Jazz", MACH_GROUP_JAZZ, MACH_MIPS_MAGNUM_4000, 0},
- {"PICA-61", MACH_GROUP_JAZZ, MACH_ACER_PICA_61, 0},
- {"RM200PCI", MACH_GROUP_SNI_RM, MACH_SNI_RM200_PCI, 0}
+ { "SGI-IP22",
+ "SGI Indy",
+ MACH_GROUP_SGI,
+ MACH_SGI_INDY,
+ PROM_FLAG_ARCS
+ }, { "Microsoft-Jazz",
+ "Jazz MIPS_Magnum_4000",
+ MACH_GROUP_JAZZ,
+ MACH_MIPS_MAGNUM_4000,
+ 0
+ }, { "PICA-61",
+ "Jazz Acer_PICA_61",
+ MACH_GROUP_JAZZ,
+ MACH_ACER_PICA_61,
+ 0
+ }, { "RM200PCI",
+ "SNI RM200_PCI",
+ MACH_GROUP_SNI_RM,
+ MACH_SNI_RM200_PCI,
+ 0
+ }
};
int prom_flags;
-static struct smatch *__init string_to_mach(char *s)
+static struct smatch *__init string_to_mach(const char *s)
{
int i;
for (i = 0; i < (sizeof(mach_table) / sizeof (mach_table[0])); i++) {
- if (!strcmp(s, mach_table[i].name))
+ if (!strcmp(s, mach_table[i].arcname))
return &mach_table[i];
}
- prom_printf("\nYeee, could not determine architecture type <%s>\n",
- s);
- prom_printf("press a key to reboot\n");
- prom_getchar();
- romvec->imode();
- return NULL;
+
+ panic("Yeee, could not determine architecture type <%s>", s);
+}
+
+char *system_type;
+
+const char *get_system_type(void)
+{
+ return system_type;
}
void __init prom_identify_arch(void)
{
pcomponent *p;
struct smatch *mach;
+ const char *iname;
/*
* The root component tells us what machine architecture we
* have here.
*/
- p = prom_getchild(PROM_NULL_COMPONENT);
- printk("ARCH: %s\n", p->iname);
- mach = string_to_mach(p->iname);
+ p = ArcGetChild(PROM_NULL_COMPONENT);
+ if (p == NULL) {
+#ifdef CONFIG_SGI_IP27
+ /* IP27 PROM bisbehaves, seems to not implement ARC
+ GetChild(). So we just assume it's an IP27. */
+ iname = "SGI-IP27";
+#endif
+ } else
+ iname = (char *) (long) p->iname;
+
+ printk(KERN_INFO "ARCH: %s\n", iname);
+ mach = string_to_mach(iname);
+ system_type = mach->liname;
mips_machgroup = mach->group;
mips_machtype = mach->type;
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)