From 021655257d6491f8ae303edbfedb263beec410dd Mon Sep 17 00:00:00 2001 From: Miod Vallat Date: Tue, 15 Aug 2006 20:26:31 +0000 Subject: A more reliable LCSPX probe, based on information from Blaz Antonic, tested by aanriot@ --- sys/arch/vax/vsa/lcspx.c | 40 ++++++---------------------------------- 1 file changed, 6 insertions(+), 34 deletions(-) (limited to 'sys/arch') 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); -- cgit v1.2.3