summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/mips64/include/arcbios.h7
-rw-r--r--sys/arch/sgi/hpc/hpc.c8
-rw-r--r--sys/arch/sgi/localbus/imc.c12
-rw-r--r--sys/arch/sgi/sgi/ip22.h9
-rw-r--r--sys/arch/sgi/sgi/ip22_machdep.c46
5 files changed, 58 insertions, 24 deletions
diff --git a/sys/arch/mips64/include/arcbios.h b/sys/arch/mips64/include/arcbios.h
index b4d53126202..ce38370f81f 100644
--- a/sys/arch/mips64/include/arcbios.h
+++ b/sys/arch/mips64/include/arcbios.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: arcbios.h,v 1.20 2012/04/06 19:00:49 miod Exp $ */
+/* $OpenBSD: arcbios.h,v 1.21 2012/04/15 20:38:08 miod Exp $ */
/*-
* Copyright (c) 1996 M. Warner Losh. All rights reserved.
*
@@ -40,10 +40,15 @@ typedef enum arc_config_class
arc_SystemClass,
arc_ProcessorClass,
arc_CacheClass,
+#ifdef __sgi__
+ arc_MemoryClass,
+#endif
arc_AdapterClass,
arc_ControllerClass,
arc_PeripheralClass,
+#ifdef __arc__
arc_MemoryClass
+#endif
} arc_config_class_t;
typedef enum arc_config_type
diff --git a/sys/arch/sgi/hpc/hpc.c b/sys/arch/sgi/hpc/hpc.c
index 6014fa33ce8..9af8b30cc9c 100644
--- a/sys/arch/sgi/hpc/hpc.c
+++ b/sys/arch/sgi/hpc/hpc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: hpc.c,v 1.5 2012/04/08 22:08:25 miod Exp $ */
+/* $OpenBSD: hpc.c,v 1.6 2012/04/15 20:38:10 miod Exp $ */
/* $NetBSD: hpc.c,v 1.66 2011/07/01 18:53:46 dyoung Exp $ */
/* $NetBSD: ioc.c,v 1.9 2011/07/01 18:53:47 dyoung Exp $ */
@@ -475,8 +475,8 @@ hpc_attach(struct device *parent, struct device *self, void *aux)
*/
isonboard = (sc->sc_base == HPC_BASE_ADDRESS_0);
isioplus = (sc->sc_base == HPC_BASE_ADDRESS_1 && hpctype == 3 &&
- sysmask == HPCDEV_IP24);
-
+ (sysmask & HPCDEV_IP24) != 0);
+
printf(": SGI HPC%d%s (%s)\n", (hpctype == 3) ? 3 : 1,
(hpctype == 15) ? ".5" : "", (isonboard) ? "onboard" :
(isioplus) ? "IOPLUS mezzanine" : "GIO slot");
@@ -501,7 +501,7 @@ hpc_attach(struct device *parent, struct device *self, void *aux)
/* XXX: the firmware should have taken care of this already */
#if 0
- if (sys_config.system_subtype == IP22_INDY) {
+ if (sys_config.system_subtype != IP22_INDIGO) {
bus_space_write_4(sc->sc_ct, sc->sc_ch,
IOC_BASE + IOC_GCSEL, 0xff);
bus_space_write_4(sc->sc_ct, sc->sc_ch,
diff --git a/sys/arch/sgi/localbus/imc.c b/sys/arch/sgi/localbus/imc.c
index 2003029c407..65a518a8fa5 100644
--- a/sys/arch/sgi/localbus/imc.c
+++ b/sys/arch/sgi/localbus/imc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: imc.c,v 1.3 2012/04/09 16:55:22 miod Exp $ */
+/* $OpenBSD: imc.c,v 1.4 2012/04/15 20:38:10 miod Exp $ */
/* $NetBSD: imc.c,v 1.32 2011/07/01 18:53:46 dyoung Exp $ */
/*
@@ -571,7 +571,7 @@ imc_attach(struct device *parent, struct device *self, void *aux)
*/
switch (sys_config.system_type) {
case SGI_IP22:
- if (sys_config.system_subtype != IP22_INDY)
+ if (sys_config.system_subtype == IP22_INDIGO2)
break;
/* FALLTHROUGH */
case SGI_IP20:
@@ -621,11 +621,12 @@ imc_attach(struct device *parent, struct device *self, void *aux)
switch (sys_config.system_subtype) {
default:
case IP22_INDY:
+ case IP22_CHALLS:
/* XXX is MST mutually exclusive? */
reg |= IMC_GIO64ARB_EXP0RT | IMC_GIO64ARB_EXP1RT;
reg |= IMC_GIO64ARB_EXP0MST | IMC_GIO64ARB_EXP1MST;
- /* EISA can bus-master, is 64-bit */
+ /* EISA (VINO, really) can bus-master, is 64-bit */
reg |= IMC_GIO64ARB_EISAMST | IMC_GIO64ARB_EISA64;
break;
@@ -636,6 +637,11 @@ imc_attach(struct device *parent, struct device *self, void *aux)
*/
reg |= IMC_GIO64ARB_HPCEXP64 | IMC_GIO64ARB_EXP0PIPE;
+ /*
+ * The EISA bus is the real thing, and is a 32-bit bus.
+ */
+ reg &= ~IMC_GIO64ARB_EISA64;
+
if (rev < 2) {
/* EXP0 realtime, EXP1 can master */
reg |= IMC_GIO64ARB_EXP0RT |
diff --git a/sys/arch/sgi/sgi/ip22.h b/sys/arch/sgi/sgi/ip22.h
index 20c6c270a9f..abd8f1064d0 100644
--- a/sys/arch/sgi/sgi/ip22.h
+++ b/sys/arch/sgi/sgi/ip22.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: ip22.h,v 1.3 2012/04/06 19:00:49 miod Exp $ */
+/* $OpenBSD: ip22.h,v 1.4 2012/04/15 20:38:10 miod Exp $ */
/*
* Copyright (c) 2012 Miodrag Vallat.
@@ -20,10 +20,11 @@
* IP20/IP22/IP24 definitions
*/
-/* IP22 system types */
+/* IP22/IP24 system types */
-#define IP22_INDY 0 /* Indy, Challenge S */
-#define IP22_INDIGO2 1 /* Indigo 2 */
+#define IP22_INDY 0 /* IP24 Indy */
+#define IP22_CHALLS 1 /* IP24 Challenge S */
+#define IP22_INDIGO2 2 /* IP22 Indigo 2, Challenge M */
/* Interrupt handling priority */
diff --git a/sys/arch/sgi/sgi/ip22_machdep.c b/sys/arch/sgi/sgi/ip22_machdep.c
index ffffcc216ac..2d357b9e1bf 100644
--- a/sys/arch/sgi/sgi/ip22_machdep.c
+++ b/sys/arch/sgi/sgi/ip22_machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ip22_machdep.c,v 1.3 2012/04/06 19:00:49 miod Exp $ */
+/* $OpenBSD: ip22_machdep.c,v 1.4 2012/04/15 20:38:10 miod Exp $ */
/*
* Copyright (c) 2012 Miodrag Vallat.
@@ -48,10 +48,14 @@ int ip22_arcbios_walk_component(arc_config_t *);
void ip22_memory_setup(void);
/*
- * Walk the ARCBios component tree to get L2 cache information.
- * This is the only way we can get the L2 cache size.
+ * Walk the ARCBios component tree to get hardware information we can't
+ * obtain by other means.
*/
+static int ip22_arcwalk_results = 0;
+#define IP22_HAS_L2 0x01
+#define IP22_HAS_AUDIO 0x02
+
int
ip22_arcbios_walk_component(arc_config_t *cf)
{
@@ -72,9 +76,18 @@ ip22_arcbios_walk_component(arc_config_t *cf)
ci->ci_l2size = (1 << 12) << (cf->key & 0x0000ffff);
/* L2 line size */
ci->ci_cacheconfiguration = 1 << ((cf->key >> 16) & 0xff);
- return 0; /* abort walk */
+
+ ip22_arcwalk_results |= IP22_HAS_L2;
+ }
+
+ if (cf->class == arc_ControllerClass &&
+ cf->type == arc_AudioController) {
+ ip22_arcwalk_results |= IP22_HAS_AUDIO;
}
+ if (ip22_arcwalk_results == (IP22_HAS_L2 | IP22_HAS_AUDIO))
+ return 0; /* abort walk */
+
/*
* It is safe to assume we have a 32-bit ARCBios, until
* IP26 and IP28 support is added, hence unconditional
@@ -224,11 +237,20 @@ ip22_setup()
bootcpu_hwinfo.type = (bootcpu_hwinfo.c0prid >> 8) & 0xff;
/*
+ * Scan ARCBios component list for useful information (L2 cache
+ * configuration, audio device availability)
+ */
+ ip22_arcbios_walk();
+
+ /*
* Figure out what critter we are running on.
*/
switch (sys_config.system_type) {
case SGI_IP20:
- hw_prod = "Indigo";
+ if (ip22_arcwalk_results & IP22_HAS_AUDIO)
+ hw_prod = "Indigo";
+ else
+ hw_prod = "VME Indigo";
break;
case SGI_IP22:
sysid = (volatile uint32_t *)
@@ -238,8 +260,13 @@ ip22_setup()
sys_config.system_subtype = IP22_INDIGO2;
hw_prod = "Indigo2";
} else {
- sys_config.system_subtype = IP22_INDY;
- hw_prod = "Indy";
+ if (ip22_arcwalk_results & IP22_HAS_AUDIO) {
+ sys_config.system_subtype = IP22_INDY;
+ hw_prod = "Indy";
+ } else {
+ sys_config.system_subtype = IP22_CHALLS;
+ hw_prod = "Challenge S";
+ }
}
break;
case SGI_IP26:
@@ -297,11 +324,6 @@ ip22_setup()
}
/*
- * Scan ARCBios component list for L2 cache information.
- */
- ip22_arcbios_walk();
-
- /*
* Get ARCBios' current time.
*/
bios_year = Bios_GetTime()->Year;