/* * system.c: Probe the system type using ARCS prom interface library. * * Copyright (C) 1996 David S. Miller (dm@engr.sgi.com) * * $Id: system.c,v 1.3 1997/09/13 02:19:18 ralf Exp $ */ #include #include #include #include #include #include enum sgi_mach sgimach; struct smatch { char *name; int type; }; static struct smatch sgi_mtable[] = { { "SGI-IP4", ip4 }, { "SGI-IP5", ip5 }, { "SGI-IP6", ip6 }, { "SGI-IP7", ip7 }, { "SGI-IP9", ip9 }, { "SGI-IP12", ip12 }, { "SGI-IP15", ip15 }, { "SGI-IP17", ip17 }, { "SGI-IP19", ip19 }, { "SGI-IP20", ip20 }, { "SGI-IP21", ip21 }, { "SGI-IP22", ip22 }, { "SGI-IP25", ip25 }, { "SGI-IP26", ip26 }, { "SGI-IP28", ip28 }, { "SGI-IP30", ip30 }, { "SGI-IP32", ip32 } }; #define NUM_MACHS 17 /* for now */ static struct smatch sgi_cputable[] = { { "MIPS-R2000", CPU_R2000 }, { "MIPS-R3000", CPU_R3000 }, { "MIPS-R3000A", CPU_R3000A }, { "MIPS-R4000", CPU_R4000SC }, { "MIPS-R4400", CPU_R4400SC }, { "MIPS-R4600", CPU_R4600 }, { "MIPS-R8000", CPU_R8000 }, { "MIPS-R5000", CPU_R5000 }, { "MIPS-R5000A", CPU_R5000A } }; #define NUM_CPUS 9 /* for now */ static enum sgi_mach string_to_mach(char *s) { int i; for(i = 0; i < NUM_MACHS; i++) { if(!strcmp(s, sgi_mtable[i].name)) return (enum sgi_mach) sgi_mtable[i].type; } prom_printf("\nYeee, could not determine SGI architecture type <%s>\n", s); prom_printf("press a key to reboot\n"); prom_getchar(); romvec->imode(); return (enum sgi_mach) 0; } static int string_to_cpu(char *s) { int i; for(i = 0; i < NUM_CPUS; i++) { if(!strcmp(s, sgi_cputable[i].name)) return sgi_mtable[i].type; } prom_printf("\nYeee, could not determine MIPS cpu type <%s>\n", s); prom_printf("press a key to reboot\n"); prom_getchar(); romvec->imode(); return 0; } /* * We' call this early before loadmmu(). If we do the other way around * the firmware will crash and burn. */ void sgi_sysinit(void) { pcomponent *p, *toplev, *cpup = 0; int cputype = -1; /* The root component tells us what machine architecture we * have here. */ p = prom_getchild(PROM_NULL_COMPONENT); printk("ARCH: %s\n", p->iname); sgimach = string_to_mach(p->iname); /* Now scan for cpu(s). */ toplev = p = prom_getchild(p); while(p) { int ncpus = 0; if(p->type == Cpu) { if(++ncpus > 1) { prom_printf("\nYeee, SGI MP not ready yet\n"); prom_printf("press a key to reboot\n"); prom_getchar(); romvec->imode(); } printk("CPU: %s ", p->iname); cpup = p; cputype = string_to_cpu(cpup->iname); } p = prom_getsibling(p); } if(cputype == -1) { prom_printf("\nYeee, could not find cpu ARCS component\n"); prom_printf("press a key to reboot\n"); prom_getchar(); romvec->imode(); } p = prom_getchild(cpup); while(p) { switch(p->class) { case processor: switch(p->type) { case Fpu: printk("FPU<%s> ", p->iname); break; default: break; }; break; case cache: switch(p->type) { case picache: printk("ICACHE "); break; case pdcache: printk("DCACHE "); break; case sccache: printk("SCACHE "); break; default: break; }; break; default: break; }; p = prom_getsibling(p); } printk("\n"); }