diff options
author | Ralf Baechle <ralf@linux-mips.org> | 1997-03-25 23:40:36 +0000 |
---|---|---|
committer | <ralf@linux-mips.org> | 1997-03-25 23:40:36 +0000 |
commit | 7206675c40394c78a90e74812bbdbf8cf3cca1be (patch) | |
tree | 251895cf5a0008e2b4ce438cb01ad4d55fb5b97b /arch/mips/sgi/kernel/system.c | |
parent | beb116954b9b7f3bb56412b2494b562f02b864b1 (diff) |
Import of Linux/MIPS 2.1.14.2
Diffstat (limited to 'arch/mips/sgi/kernel/system.c')
-rw-r--r-- | arch/mips/sgi/kernel/system.c | 168 |
1 files changed, 168 insertions, 0 deletions
diff --git a/arch/mips/sgi/kernel/system.c b/arch/mips/sgi/kernel/system.c new file mode 100644 index 000000000..051ad09c5 --- /dev/null +++ b/arch/mips/sgi/kernel/system.c @@ -0,0 +1,168 @@ +/* $Id: system.c,v 1.2 1996/06/10 16:38:32 dm Exp $ + * system.c: Probe the system type using ARCS prom interface library. + * + * Copyright (C) 1996 David S. Miller (dm@engr.sgi.com) + */ +#include <linux/kernel.h> +#include <linux/types.h> +#include <linux/string.h> + +#include <asm/sgi.h> +#include <asm/sgialib.h> +#include <asm/bootinfo.h> + +#ifndef __GOGOGO__ +#error "... You're fearless, aren't you?" +#endif + +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; +} + +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"); +} |