summaryrefslogtreecommitdiff
path: root/sys/arch/macppc/pci/macobio.c
diff options
context:
space:
mode:
authorDale Rahn <drahn@cvs.openbsd.org>2002-09-06 13:56:52 +0000
committerDale Rahn <drahn@cvs.openbsd.org>2002-09-06 13:56:52 +0000
commit284201d8c10822c1d342c2a286b0a219d4050235 (patch)
tree1dbda06f3823660ed4e4ba17138395eb09f546f9 /sys/arch/macppc/pci/macobio.c
parentfef04d296c9d04387f613eb1a5dfcedac5688d5b (diff)
Serial console support for macppc. Serial console will work if the modem
has been replaced with a serial port adapter on any machine that has a real serial port internally. This will also power on the internal modem for keylargo based machines (tested on original PBG4) when the serial port is open. ok miod@
Diffstat (limited to 'sys/arch/macppc/pci/macobio.c')
-rw-r--r--sys/arch/macppc/pci/macobio.c39
1 files changed, 38 insertions, 1 deletions
diff --git a/sys/arch/macppc/pci/macobio.c b/sys/arch/macppc/pci/macobio.c
index 32411cc17f3..8a5edc7b17c 100644
--- a/sys/arch/macppc/pci/macobio.c
+++ b/sys/arch/macppc/pci/macobio.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: macobio.c,v 1.4 2002/03/14 03:15:56 millert Exp $ */
+/* $OpenBSD: macobio.c,v 1.5 2002/09/06 13:56:51 drahn Exp $ */
/* $NetBSD: obio.c,v 1.6 1999/05/01 10:36:08 tsubai Exp $ */
/*-
@@ -57,6 +57,8 @@ struct macobio_softc {
struct device sc_dev;
int sc_node;
struct ppc_bus_space sc_membus_space;
+ int sc_id; /* copy of the PCI pa_id */
+ u_int8_t *obiomem;
};
struct cfdriver macobio_cd = {
NULL, "macobio", DV_DULL,
@@ -110,6 +112,8 @@ macobio_attach(parent, self, aux)
char name[32];
int need_interrupt_controller = 0;
+ sc->sc_id = pa->pa_id; /* save of type for later */
+
switch (PCI_PRODUCT(pa->pa_id)) {
/* XXX should not use name */
@@ -141,6 +145,11 @@ macobio_attach(parent, self, aux)
node = OF_finddevice("mac-io");
if (node == -1)
node = OF_finddevice("/pci/mac-io");
+ if (OF_getprop(node, "assigned-addresses", reg, sizeof(reg))
+ == (sizeof (reg[0]) * 5))
+ {
+ sc->obiomem = mapiodev(reg[2], 0x100);
+ }
break;
default:
@@ -271,3 +280,31 @@ mac_intr_disestablish(lcp, arg)
{
(*mac_intr_disestablish_func)(lcp, arg);
}
+
+void macobio_modem_power(int enable);
+void
+macobio_modem_power(int enable)
+{
+ u_int32_t val;
+ struct macobio_softc *sc = macobio_cd.cd_devs[0];
+ if (PCI_PRODUCT(sc->sc_id) == PCI_PRODUCT_APPLE_KEYLARGO) {
+ val = in32rb(sc->obiomem + 0x40);
+ if (enable)
+ val = val & ~((u_int32_t)1<<25);
+ else
+ val = val | ((u_int32_t)1<<25);
+ out32rb(sc->obiomem + 0x40, val);
+ }
+ if (PCI_PRODUCT(sc->sc_id) == PCI_PRODUCT_APPLE_PANGEA_MACIO) {
+ if (enable) {
+ /* set reset */
+ out8(sc->obiomem + 0x006a + 0x03, 0x04);
+ /* power modem on */
+ out8(sc->obiomem + 0x006a + 0x02, 0x04);
+ /* unset reset */
+ out8(sc->obiomem + 0x006a + 0x03, 0x05);
+ } else {
+ /* disable it how? */
+ }
+ }
+}