summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2007-12-09 21:53:02 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2007-12-09 21:53:02 +0000
commit8fa549358cd894ca554b22c6d76d2272ad08a3dc (patch)
tree963e0a5f1b43aa61b30ce53985f74e2d4d057acf
parente1bd73e21db8f0e35dc77f7ffacea9dd43ae5411 (diff)
Be more careful when checking for hardware, so as not to attach to SPX
option boards.
-rw-r--r--sys/arch/vax/vsa/gpx.c25
1 files changed, 23 insertions, 2 deletions
diff --git a/sys/arch/vax/vsa/gpx.c b/sys/arch/vax/vsa/gpx.c
index b39e1f6c652..b25f07fcb05 100644
--- a/sys/arch/vax/vsa/gpx.c
+++ b/sys/arch/vax/vsa/gpx.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: gpx.c,v 1.16 2006/11/29 19:08:22 miod Exp $ */
+/* $OpenBSD: gpx.c,v 1.17 2007/12/09 21:53:01 miod Exp $ */
/*
* Copyright (c) 2006 Miodrag Vallat.
*
@@ -235,9 +235,10 @@ int
gpx_match(struct device *parent, void *vcf, void *aux)
{
struct vsbus_attach_args *va = aux;
- struct adder *adder;
+ volatile struct adder *adder;
vaddr_t tmp;
u_int depth;
+ u_short status;
extern struct consdev wsdisplay_cons;
extern int oldvsbus;
@@ -260,6 +261,17 @@ gpx_match(struct device *parent, void *vcf, void *aux)
break;
}
+ /* Check for hardware */
+ adder = (volatile struct adder *)
+ vax_map_physmem(va->va_paddr + GPX_ADDER_OFFSET, 1);
+ if (adder == NULL)
+ return (0);
+ adder->status = 0;
+ status = adder->status;
+ vax_unmap_physmem((vaddr_t)adder, 1);
+ if (status == offsetof(struct adder, status))
+ return (0);
+
/* Check for a recognized color depth */
tmp = vax_map_physmem(va->va_paddr + GPX_READBACK_OFFSET, 1);
if (tmp == 0L)
@@ -1223,6 +1235,7 @@ int
gpxcnprobe()
{
extern vaddr_t virtual_avail;
+ volatile struct adder *adder;
vaddr_t tmp;
int depth;
@@ -1236,6 +1249,14 @@ gpxcnprobe()
if ((vax_confdata & KA420_CFG_VIDOPT) == 0)
break; /* no color option */
+ /* Check for hardware */
+ tmp = virtual_avail;
+ ioaccess(tmp, vax_trunc_page(GPXADDR + GPX_ADDER_OFFSET), 1);
+ adder = (struct adder *)tmp;
+ adder->status = 0;
+ if (adder->status == offsetof(struct adder, status))
+ return (0);
+
/* Check for a recognized color depth */
tmp = virtual_avail;
ioaccess(tmp, vax_trunc_page(GPXADDR + GPX_READBACK_OFFSET), 1);