Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/macppc/dev don't poke GPIOs directly, use obio_*() ...
details: https://anonhg.NetBSD.org/src/rev/de2b3c110c2e
branches: trunk
changeset: 321587:de2b3c110c2e
user: macallan <macallan%NetBSD.org@localhost>
date: Sat Mar 24 16:22:48 2018 +0000
description:
don't poke GPIOs directly, use obio_*() access functions, now this
has a chance of working on G5 where we can't just BAT-map everything with
paddr == busaddr.
Doesn't play audio yet but things like headphone detection work.
diffstat:
sys/arch/macppc/dev/snapper.c | 67 +++++++++++++++++++++++-------------------
1 files changed, 36 insertions(+), 31 deletions(-)
diffs (180 lines):
diff -r cd46bd9870d5 -r de2b3c110c2e sys/arch/macppc/dev/snapper.c
--- a/sys/arch/macppc/dev/snapper.c Sat Mar 24 15:51:57 2018 +0000
+++ b/sys/arch/macppc/dev/snapper.c Sat Mar 24 16:22:48 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: snapper.c,v 1.43 2018/01/29 19:33:39 macallan Exp $ */
+/* $NetBSD: snapper.c,v 1.44 2018/03/24 16:22:48 macallan Exp $ */
/* Id: snapper.c,v 1.11 2002/10/31 17:42:13 tsubai Exp */
/* Id: i2s.c,v 1.12 2005/01/15 14:32:35 tsubai Exp */
@@ -35,7 +35,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: snapper.c,v 1.43 2018/01/29 19:33:39 macallan Exp $");
+__KERNEL_RCSID(0, "$NetBSD: snapper.c,v 1.44 2018/03/24 16:22:48 macallan Exp $");
#include <sys/param.h>
#include <sys/audioio.h>
@@ -145,8 +145,8 @@
static void snapper_write_mixers(struct snapper_softc *);
static int tas3004_write(struct snapper_softc *, u_int, const void *);
-static int gpio_read(char *);
-static void gpio_write(char *, int);
+static int gpio_read(bus_size_t);
+static void gpio_write(bus_size_t, int);
static void snapper_mute_speaker(struct snapper_softc *, int);
static void snapper_mute_headphone(struct snapper_softc *, int);
static int snapper_cint(void *);
@@ -549,11 +549,11 @@
2, AUFMT_STEREO, 4, {32000, 44100, 48000, 96000}},
};
-static u_char *amp_mute;
-static u_char *headphone_mute;
-static u_char *audio_hw_reset;
-static u_char *headphone_detect;
-static int headphone_detect_active;
+static bus_size_t amp_mute;
+static bus_size_t headphone_mute;
+static bus_size_t audio_hw_reset;
+static bus_size_t headphone_detect;
+static uint8_t headphone_detect_active;
/* I2S registers */
@@ -761,6 +761,7 @@
sizeof(struct dbdma_command), NULL);
sc->sc_baseaddr = ca->ca_baseaddr;
+
OF_getprop(soundbus, "reg", reg, sizeof reg);
reg[0] += ca->ca_baseaddr;
reg[2] += ca->ca_baseaddr;
@@ -1894,24 +1895,23 @@
}
static int
-gpio_read(char *addr)
+gpio_read(bus_size_t addr)
{
- if (*addr & GPIO_DATA)
+ if (obio_read_1(addr) & GPIO_DATA)
return 1;
return 0;
}
static void
-gpio_write(char *addr, int val)
+gpio_write(bus_size_t addr, int val)
{
- u_int data;
+ uint8_t data;
data = GPIO_DDR_OUTPUT;
if (val)
data |= GPIO_DATA;
- *addr = data;
- __asm volatile ("eieio");
+ obio_write_1(addr, data);
}
#define headphone_active 0 /* XXX OF */
@@ -1920,7 +1920,7 @@
static void
snapper_mute_speaker(struct snapper_softc *sc, int mute)
{
- u_int x;
+ int x;
if (amp_mute) {
DPRINTF("ampmute %d --> ", gpio_read(amp_mute));
@@ -1941,7 +1941,7 @@
{
u_int x;
- if (headphone_mute != NULL) {
+ if (headphone_mute != 0) {
DPRINTF("headphonemute %d --> ", gpio_read(headphone_mute));
if (mute)
@@ -1961,9 +1961,9 @@
struct snapper_softc *sc;
u_int sense;
- if (headphone_detect != NULL) {
+ if (headphone_detect != 0) {
sc = v;
- sense = *headphone_detect;
+ sense = obio_read_1(headphone_detect);
DPRINTF("headphone detect = 0x%x\n", sense);
if (((sense & 0x02) >> 1) == headphone_detect_active) {
@@ -1992,7 +1992,7 @@
{
/* No reset port. Nothing to do. */
- if (audio_hw_reset == NULL)
+ if (audio_hw_reset == 0)
goto noreset;
/* Reset TAS3004. */
@@ -2065,7 +2065,7 @@
while (gpio) {
char name[64], audio_gpio[64];
int intr[2];
- char *addr;
+ bus_size_t addr;
memset(name, 0, sizeof name);
memset(audio_gpio, 0, sizeof audio_gpio);
@@ -2075,9 +2075,14 @@
if (OF_getprop(gpio, "AAPL,address", &addr, sizeof addr) == -1)
if (OF_getprop(gpio, "reg", reg, sizeof reg)
== sizeof reg)
- addr = (char *)sc->sc_baseaddr +
- gpio_base + reg[0];
- DPRINTF(" 0x%x %s %s\n", gpio, name, audio_gpio);
+ addr = gpio_base + reg[0];
+ /*
+ * XXX
+ * APL,address contains the absolute address, we only want the
+ * offset from mac-io's base address
+ */
+ addr &= 0x7fff;
+ DPRINTF(" 0x%x %s %s %08x\n", gpio, name, audio_gpio, addr);
/* gpio5 */
if (strcmp(audio_gpio, "headphone-mute") == 0 ||
@@ -2105,12 +2110,12 @@
gpio = OF_peer(gpio);
}
- DPRINTF(" headphone-mute %p\n", headphone_mute);
- DPRINTF(" amp-mute %p\n", amp_mute);
- DPRINTF(" headphone-detect %p\n", headphone_detect);
+ DPRINTF(" headphone-mute %x\n", headphone_mute);
+ DPRINTF(" amp-mute %x\n", amp_mute);
+ DPRINTF(" headphone-detect %x\n", headphone_detect);
DPRINTF(" headphone-detect active %x\n", headphone_detect_active);
DPRINTF(" headphone-detect intr %x\n", headphone_detect_intr);
- DPRINTF(" audio-hw-reset %p\n", audio_hw_reset);
+ DPRINTF(" audio-hw-reset %x\n", audio_hw_reset);
if (headphone_detect_intr != -1)
intr_establish(headphone_detect_intr, IST_EDGE, IPL_AUDIO,
@@ -2120,9 +2125,9 @@
sc->sc_bitspersample = 16;
/* Enable headphone interrupt? */
- if (headphone_detect != NULL) {
- *headphone_detect |= 0x80;
- __asm volatile ("eieio");
+ if (headphone_detect != 0) {
+ obio_write_1(headphone_detect,
+ obio_read_1(headphone_detect) | 0x80);
}
if (tas3004_init(sc))
Home |
Main Index |
Thread Index |
Old Index