summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMartin Pieuchot <mpi@cvs.openbsd.org>2011-05-15 09:10:27 +0000
committerMartin Pieuchot <mpi@cvs.openbsd.org>2011-05-15 09:10:27 +0000
commitba4a2dd268e0b0f4a560e51e8b0d8fde9e11fea0 (patch)
tree72404b966034fa5c72d2c657ea92c5e46db3b970
parentb23c9010b334312c087e605426a2d7ff7324fd9f (diff)
Unify various gpio access using methods that take an offset relative to the
mac-io bus base address. Needed by upcoming dfs(4) support. On some Apple machines, the openfirmware returns a gpio offset relative to the gpio controller (generaly at 0x50). These offsets should be corrected to be relative to the bus base address. looks fine to kettenis@, ok miod@
-rw-r--r--sys/arch/macppc/dev/i2s.c30
-rw-r--r--sys/arch/macppc/dev/smu.c13
-rw-r--r--sys/arch/macppc/dev/xlights.c11
-rw-r--r--sys/arch/macppc/pci/macobio.c23
-rw-r--r--sys/arch/macppc/pci/macobio.h33
5 files changed, 60 insertions, 50 deletions
diff --git a/sys/arch/macppc/dev/i2s.c b/sys/arch/macppc/dev/i2s.c
index 3d0727fee02..40774112d96 100644
--- a/sys/arch/macppc/dev/i2s.c
+++ b/sys/arch/macppc/dev/i2s.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: i2s.c,v 1.20 2011/05/05 18:54:23 jasper Exp $ */
+/* $OpenBSD: i2s.c,v 1.21 2011/05/15 09:10:26 mpi Exp $ */
/* $NetBSD: i2s.c,v 1.1 2003/12/27 02:19:34 grant Exp $ */
/*-
@@ -46,6 +46,7 @@
#include <macppc/dev/i2svar.h>
#include <macppc/dev/i2sreg.h>
+#include <macppc/pci/macobio.h>
#ifdef I2S_DEBUG
# define DPRINTF(x) printf x
@@ -78,10 +79,6 @@ void i2s_init(struct i2s_softc *, int);
int i2s_intr(void *);
int i2s_iintr(void *);
-/* XXX */
-void keylargo_fcr_enable(int, u_int32_t);
-void keylargo_fcr_disable(int, u_int32_t);
-
struct cfdriver i2s_cd = {
NULL, "i2s", DV_DULL
};
@@ -95,25 +92,6 @@ static int headphone_detect_active;
static u_char *lineout_detect;
static int lineout_detect_active;
-/* GPIO bits */
-#define GPIO_OUTSEL 0xf0 /* Output select */
- /* 0x00 GPIO bit0 is output
- 0x10 media-bay power
- 0x20 reserved
- 0x30 MPIC */
-
-#define GPIO_ALTOE 0x08 /* Alternate output enable */
- /* 0x00 Use DDR
- 0x08 Use output select */
-
-#define GPIO_DDR 0x04 /* Data direction */
-#define GPIO_DDR_OUTPUT 0x04 /* Output */
-#define GPIO_DDR_INPUT 0x00 /* Input */
-
-#define GPIO_LEVEL 0x02 /* Pin level (RO) */
-
-#define GPIO_DATA 0x01 /* Data */
-
void
i2s_attach(struct device *parent, struct i2s_softc *sc, struct confargs *ca)
{
@@ -992,7 +970,7 @@ i2s_set_rate(sc, rate)
/* Clear CLKSTOPPEND */
out32rb(sc->sc_reg + I2S_INT, I2S_INT_CLKSTOPPEND);
- keylargo_fcr_disable(I2SClockOffset, I2S0CLKEN);
+ macobio_disable(I2SClockOffset, I2S0CLKEN);
/* Wait until clock is stopped */
for (timo = 50; timo > 0; timo--) {
@@ -1008,7 +986,7 @@ done:
in32rb(sc->sc_reg + I2S_FORMAT), reg));
out32rb(sc->sc_reg + I2S_FORMAT, reg);
- keylargo_fcr_enable(I2SClockOffset, I2S0CLKEN);
+ macobio_enable(I2SClockOffset, I2S0CLKEN);
sc->sc_rate = rate;
diff --git a/sys/arch/macppc/dev/smu.c b/sys/arch/macppc/dev/smu.c
index dc933372032..1285278fe48 100644
--- a/sys/arch/macppc/dev/smu.c
+++ b/sys/arch/macppc/dev/smu.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: smu.c,v 1.22 2009/08/12 14:11:52 kettenis Exp $ */
+/* $OpenBSD: smu.c,v 1.23 2011/05/15 09:10:26 mpi Exp $ */
/*
* Copyright (c) 2005 Mark Kettenis
@@ -31,7 +31,8 @@
#include <dev/i2c/i2cvar.h>
#include <dev/ofw/openfirm.h>
-#include <arch/macppc/dev/maci2cvar.h>
+#include <macppc/dev/maci2cvar.h>
+#include <macppc/pci/macobio.h>
int smu_match(struct device *, void *, void *);
void smu_attach(struct device *, struct device *, void *);
@@ -154,14 +155,6 @@ int smu_i2c_exec(void *, i2c_op_t, i2c_addr_t,
void smu_slew_voltage(u_int);
-#define GPIO_DDR 0x04 /* Data direction */
-#define GPIO_DDR_OUTPUT 0x04 /* Output */
-#define GPIO_DDR_INPUT 0x00 /* Input */
-
-#define GPIO_LEVEL 0x02 /* Pin level (RO) */
-
-#define GPIO_DATA 0x01 /* Data */
-
int
smu_match(struct device *parent, void *cf, void *aux)
{
diff --git a/sys/arch/macppc/dev/xlights.c b/sys/arch/macppc/dev/xlights.c
index 8793070c851..daf2e0e2603 100644
--- a/sys/arch/macppc/dev/xlights.c
+++ b/sys/arch/macppc/dev/xlights.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: xlights.c,v 1.4 2008/09/30 04:54:00 drahn Exp $ */
+/* $OpenBSD: xlights.c,v 1.5 2011/05/15 09:10:26 mpi Exp $ */
/*
* Copyright (c) 2007 Gordon Willem Klok <gwk@openbsd,org>
*
@@ -27,6 +27,7 @@
#include <machine/autoconf.h>
#include <macppc/dev/dbdma.h>
#include <macppc/dev/i2sreg.h>
+#include <macppc/pci/macobio.h>
struct xlights_softc {
struct device sc_dev;
@@ -55,8 +56,6 @@ void xlights_startdma(struct xlights_softc *);
void xlights_deferred(void *);
void xlights_theosDOT(void *);
void xlights_timeout(void *);
-extern void keylargo_fcr_enable(int, u_int32_t);
-extern void keylargo_fcr_disable(int, u_int32_t);
struct cfattach xlights_ca = {
sizeof(struct xlights_softc), xlights_match,
@@ -170,9 +169,9 @@ xlights_attach(struct device *parent, struct device *self, void *aux)
printf(": irq %d\n", sc->sc_intr);
- keylargo_fcr_enable(I2SClockOffset, I2S0EN);
+ macobio_enable(I2SClockOffset, I2S0EN);
out32rb(sc->sc_reg + I2S_INT, I2S_INT_CLKSTOPPEND);
- keylargo_fcr_disable(I2SClockOffset, I2S0CLKEN);
+ macobio_disable(I2SClockOffset, I2S0CLKEN);
for (error = 0; error < 1000; error++) {
if (in32rb(sc->sc_reg + I2S_INT) & I2S_INT_CLKSTOPPEND) {
error = 0;
@@ -189,7 +188,7 @@ xlights_attach(struct device *parent, struct device *self, void *aux)
type, IPL_AUDIO, xlights_intr, sc, sc->sc_dev.dv_xname);
out32rb(sc->sc_reg + I2S_FORMAT, CLKSRC_VS);
- keylargo_fcr_enable(I2SClockOffset, I2S0CLKEN);
+ macobio_enable(I2SClockOffset, I2S0CLKEN);
kthread_create_deferred(xlights_deferred, sc);
timeout_set(&sc->sc_tmo, xlights_timeout, sc);
diff --git a/sys/arch/macppc/pci/macobio.c b/sys/arch/macppc/pci/macobio.c
index b335c558866..a4656a65506 100644
--- a/sys/arch/macppc/pci/macobio.c
+++ b/sys/arch/macppc/pci/macobio.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: macobio.c,v 1.18 2009/08/22 02:54:50 mk Exp $ */
+/* $OpenBSD: macobio.c,v 1.19 2011/05/15 09:10:26 mpi Exp $ */
/* $NetBSD: obio.c,v 1.6 1999/05/01 10:36:08 tsubai Exp $ */
/*-
@@ -45,6 +45,7 @@
#include <machine/bus.h>
#include <machine/autoconf.h>
+#include <macppc/pci/macobio.h>
void macobio_attach(struct device *, struct device *, void *);
int macobio_match(struct device *, void *, void *);
@@ -257,12 +258,8 @@ mac_intr_disestablish(void *lcp, void *arg)
(*mac_intr_disestablish_func)(lcp, arg);
}
-void keylargo_fcr_enable(int offset, u_int32_t bits);
-void keylargo_fcr_disable(int offset, u_int32_t bits);
-u_int32_t keylargo_fcr_read(int offset);
-
void
-keylargo_fcr_enable(int offset, u_int32_t bits)
+macobio_enable(int offset, u_int32_t bits)
{
struct macobio_softc *sc = macobio_cd.cd_devs[0];
if (sc->obiomem == 0)
@@ -272,7 +269,7 @@ keylargo_fcr_enable(int offset, u_int32_t bits)
out32rb(sc->obiomem + offset, bits);
}
void
-keylargo_fcr_disable(int offset, u_int32_t bits)
+macobio_disable(int offset, u_int32_t bits)
{
struct macobio_softc *sc = macobio_cd.cd_devs[0];
if (sc->obiomem == 0)
@@ -283,7 +280,7 @@ keylargo_fcr_disable(int offset, u_int32_t bits)
}
u_int32_t
-keylargo_fcr_read(int offset)
+macobio_read(int offset)
{
struct macobio_softc *sc = macobio_cd.cd_devs[0];
if (sc->obiomem == 0)
@@ -293,6 +290,16 @@ keylargo_fcr_read(int offset)
}
void
+macobio_write(int offset, u_int32_t bits)
+{
+ struct macobio_softc *sc = macobio_cd.cd_devs[0];
+ if (sc->obiomem == 0)
+ return;
+
+ out32rb(sc->obiomem + offset, bits);
+}
+
+void
macobio_modem_power(int enable)
{
u_int32_t val;
diff --git a/sys/arch/macppc/pci/macobio.h b/sys/arch/macppc/pci/macobio.h
new file mode 100644
index 00000000000..a87b08a3480
--- /dev/null
+++ b/sys/arch/macppc/pci/macobio.h
@@ -0,0 +1,33 @@
+/* $OpenBSD: macobio.h,v 1.1 2011/05/15 09:10:26 mpi Exp $ */
+/*
+ * Copyright (c) 2011 Martin Pieuchot <mp@nolizard.org>
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#ifndef _MACOBIO_H_
+#define _MACOBIO_H_
+
+#define GPIO_DDR_INPUT 0x00
+#define GPIO_DDR_OUTPUT 0x04
+
+#define GPIO_DATA 0x01 /* Data */
+#define GPIO_LEVEL 0x02 /* Pin level (RO) */
+
+void macobio_enable(int, u_int32_t);
+void macobio_disable(int, u_int32_t);
+u_int32_t macobio_read(int);
+void macobio_write(int, u_int32_t);
+
+
+#endif /* _MACOBIO_H_ */