summaryrefslogtreecommitdiff
path: root/sys/arch/sparc64
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2004-11-02 21:17:40 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2004-11-02 21:17:40 +0000
commit0791e66967a73654da6e0b4e49cfbc88b4704f35 (patch)
tree39cb58efe0b637eb6f7b995cb9d3ece6819c8f2d /sys/arch/sparc64
parent85c0aba9e59ff55fb696367d773eeb5503b67d69 (diff)
Use PROM mappings, if available, whenever we are the console device or not;
should help on SPARCenginc Ultra AXe, does not change anything on other machines.
Diffstat (limited to 'sys/arch/sparc64')
-rw-r--r--sys/arch/sparc64/dev/pckbc_ebus.c35
1 files changed, 20 insertions, 15 deletions
diff --git a/sys/arch/sparc64/dev/pckbc_ebus.c b/sys/arch/sparc64/dev/pckbc_ebus.c
index e9d3dd7c679..82e9a942213 100644
--- a/sys/arch/sparc64/dev/pckbc_ebus.c
+++ b/sys/arch/sparc64/dev/pckbc_ebus.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pckbc_ebus.c,v 1.6 2003/12/16 15:08:50 jason Exp $ */
+/* $OpenBSD: pckbc_ebus.c,v 1.7 2004/11/02 21:17:39 miod Exp $ */
/*
* Copyright (c) 2002 Jason L. Wright (jason@thought.net)
@@ -97,10 +97,26 @@ pckbc_ebus_attach(parent, self, aux)
struct pckbc_internal *t = NULL;
int console;
- sc->sc_iot = ea->ea_iotag;
sc->sc_node = ea->ea_node;
console = pckbc_ebus_is_console(sc);
+ /* Use prom address if available, otherwise map it. */
+ if (ea->ea_nvaddrs && bus_space_map(ea->ea_iotag, ea->ea_vaddrs[0], 0,
+ 0, &sc->sc_ioh) == 0) {
+ sc->sc_iot = ea->ea_iotag;
+ } else if (ebus_bus_map(ea->ea_iotag, 0,
+ EBUS_PADDR_FROM_REG(&ea->ea_regs[0]), ea->ea_regs[0].size,
+ 0, 0, &sc->sc_ioh) == 0) {
+ sc->sc_iot = ea->ea_iotag;
+ } else if (ebus_bus_map(ea->ea_memtag, 0,
+ EBUS_PADDR_FROM_REG(&ea->ea_regs[0]), ea->ea_regs[0].size,
+ 0, 0, &sc->sc_ioh) == 0) {
+ sc->sc_iot = ea->ea_memtag;
+ } else {
+ printf(": can't map register space\n");
+ return;
+ }
+
if (console) {
if (pckbc_cnattach(sc->sc_iot,
EBUS_PADDR_FROM_REG(&ea->ea_regs[0]), KBCMDP,
@@ -114,17 +130,6 @@ pckbc_ebus_attach(parent, self, aux)
}
if (console == 0) {
- /* Use prom address if available, otherwise map it. */
- if (ea->ea_nvaddrs)
- bus_space_map(sc->sc_iot, ea->ea_vaddrs[0], 0, 0,
- &sc->sc_ioh);
- else if (ebus_bus_map(sc->sc_iot, 0,
- EBUS_PADDR_FROM_REG(&ea->ea_regs[0]), ea->ea_regs[0].size,
- 0, 0, &sc->sc_ioh) != 0) {
- printf(": can't map register space\n");
- return;
- }
-
if (bus_space_subregion(sc->sc_iot, sc->sc_ioh,
KBCMDP, sizeof(u_int32_t), &sc->sc_ioh_c) != 0) {
printf(": couldn't get cmd subregion\n");
@@ -142,14 +147,14 @@ pckbc_ebus_attach(parent, self, aux)
psc->intr_establish = pckbc_ebus_intr_establish;
- sc->sc_irq[0] = bus_intr_establish(ea->ea_iotag, ea->ea_intrs[0],
+ sc->sc_irq[0] = bus_intr_establish(sc->sc_iot, ea->ea_intrs[0],
IPL_TTY, 0, pckbcintr, psc, self->dv_xname);
if (sc->sc_irq[0] == NULL) {
printf(": couldn't get intr0\n");
return;
}
- sc->sc_irq[1] = bus_intr_establish(ea->ea_iotag, ea->ea_intrs[1],
+ sc->sc_irq[1] = bus_intr_establish(sc->sc_iot, ea->ea_intrs[1],
IPL_TTY, 0, pckbcintr, psc, self->dv_xname);
if (sc->sc_irq[1] == NULL) {
printf(": couldn't get intr1\n");