summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2006-08-15 20:26:31 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2006-08-15 20:26:31 +0000
commit021655257d6491f8ae303edbfedb263beec410dd (patch)
tree54057c408c048648bcdda385a2a977eb48c89201 /sys/arch
parent0ae7198a680333ac8ea8de85576b1c9c1f6f0d8c (diff)
A more reliable LCSPX probe, based on information from Blaz Antonic, tested
by aanriot@
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/vax/vsa/lcspx.c40
1 files changed, 6 insertions, 34 deletions
diff --git a/sys/arch/vax/vsa/lcspx.c b/sys/arch/vax/vsa/lcspx.c
index 84b63e35120..a48bd2e682c 100644
--- a/sys/arch/vax/vsa/lcspx.c
+++ b/sys/arch/vax/vsa/lcspx.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: lcspx.c,v 1.5 2006/08/05 22:04:53 miod Exp $ */
+/* $OpenBSD: lcspx.c,v 1.6 2006/08/15 20:26:30 miod Exp $ */
/*
* Copyright (c) 2006 Miodrag Vallat.
*
@@ -156,8 +156,6 @@ lcspx_match(struct device *parent, void *vcf, void *aux)
{
struct vsbus_softc *sc = (void *)parent;
struct vsbus_attach_args *va = aux;
- volatile u_int8_t *ch;
- int rc;
switch (vax_boardtype) {
default:
@@ -167,23 +165,12 @@ lcspx_match(struct device *parent, void *vcf, void *aux)
if (va->va_paddr != LCSPX_REG_ADDR)
return (0);
+ if ((vax_confdata & 0x12) != 0x02)
+ return (0);
+
break;
}
- /*
- * Check for video memory.
- * We can not use badaddr() on these models.
- */
- ch = (volatile u_int8_t *)vax_map_physmem(LCSPX_FB_ADDR, 1);
- rc = 1;
- *ch = 0x01;
- if ((*ch & 0x01) == 0)
- rc = 0;
- *ch = 0x00;
- if ((*ch & 0x01) != 0)
- rc = 0;
- vax_unmap_physmem((vaddr_t)ch, 1);
-
sc->sc_mask = 0x04; /* XXX - should be generated */
scb_fake(0x120, 0x15);
return (20);
@@ -502,28 +489,13 @@ void lcspxcninit(void);
int
lcspxcnprobe()
{
- extern vaddr_t virtual_avail;
- vaddr_t tmp;
- volatile u_int8_t *ch;
-
switch (vax_boardtype) {
case VAX_BTYP_49:
if ((vax_confdata & 8) != 0)
break; /* doesn't use graphics console */
- /*
- * Check for video memory.
- * We can not use badaddr() on these models.
- */
- tmp = virtual_avail;
- ch = (volatile u_int8_t *)tmp;
- ioaccess(tmp, LCSPX_FB_ADDR, 1);
- *ch = 0x01;
- if ((*ch & 0x01) == 0)
- break;
- *ch = 0x00;
- if ((*ch & 0x01) != 0)
- break;
+ if ((vax_confdata & 0x12) != 0x02)
+ return (0);
return (1);