diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2007-12-09 21:53:02 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2007-12-09 21:53:02 +0000 |
commit | 8fa549358cd894ca554b22c6d76d2272ad08a3dc (patch) | |
tree | 963e0a5f1b43aa61b30ce53985f74e2d4d057acf | |
parent | e1bd73e21db8f0e35dc77f7ffacea9dd43ae5411 (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.c | 25 |
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); |