summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorcg <cg@FreeBSD.org>1999-12-12 02:18:58 +0000
committercg <cg@FreeBSD.org>1999-12-12 02:18:58 +0000
commit1698a08e9a67d82f9a1b778dda598e34ff59c19b (patch)
treef9bc21c7a120c7f74f2d80e234a56840e7644662
parentf1be6706cf778d9ab56e7bc0f0c7d2ba5fc27b84 (diff)
downloadFreeBSD-src-1698a08e9a67d82f9a1b778dda598e34ff59c19b.zip
FreeBSD-src-1698a08e9a67d82f9a1b778dda598e34ff59c19b.tar.gz
move channel-swapping support to the hardware driver since it knows the card
state best
-rw-r--r--sys/dev/sound/pcm/datatypes.h2
-rw-r--r--sys/dev/sound/pcm/dsp.c11
-rw-r--r--sys/dev/sound/pcm/sound.c7
-rw-r--r--sys/dev/sound/pcm/sound.h3
4 files changed, 11 insertions, 12 deletions
diff --git a/sys/dev/sound/pcm/datatypes.h b/sys/dev/sound/pcm/datatypes.h
index a163d12..5a719c4 100644
--- a/sys/dev/sound/pcm/datatypes.h
+++ b/sys/dev/sound/pcm/datatypes.h
@@ -129,6 +129,7 @@ struct _pcm_channel {
void *devinfo;
};
+typedef void (pcm_swap_t)(void *data, int dir);
#define SND_STATUSLEN 64
/* descriptor of audio device */
struct _snddev_info {
@@ -138,6 +139,7 @@ struct _snddev_info {
u_long magic;
unsigned flags;
void *devinfo;
+ pcm_swap_t *swap;
char status[SND_STATUSLEN];
};
diff --git a/sys/dev/sound/pcm/dsp.c b/sys/dev/sound/pcm/dsp.c
index 3955155..eceab19 100644
--- a/sys/dev/sound/pcm/dsp.c
+++ b/sys/dev/sound/pcm/dsp.c
@@ -70,16 +70,7 @@ setchns(snddev_info *d, int chan)
KASSERT((d->flags & SD_F_PRIO_SET) != SD_F_PRIO_SET, \
("getchns: read and write both prioritised"));
d->flags |= SD_F_DIR_SET;
- if (d->flags & SD_F_EVILSB16) {
- if ((d->flags & SD_F_PRIO_RD) && (d->aplay[chan])) {
- pcm_channel *tmp;
- tmp = d->arec[chan];
- d->arec[chan] = d->aplay[chan];
- d->aplay[chan] = tmp;
- }
- if (d->aplay[chan]) chn_setdir(d->aplay[chan], PCMDIR_PLAY);
- if (d->arec[chan]) chn_setdir(d->arec[chan], PCMDIR_REC);
- }
+ if (d->swap) d->swap(d->devinfo, (d->flags & SD_F_PRIO_WR)? PCMDIR_PLAY : PCMDIR_REC);
}
int
diff --git a/sys/dev/sound/pcm/sound.c b/sys/dev/sound/pcm/sound.c
index b464ebd..a76a6b0 100644
--- a/sys/dev/sound/pcm/sound.c
+++ b/sys/dev/sound/pcm/sound.c
@@ -129,6 +129,12 @@ pcm_setflags(device_t dev, u_int32_t val)
d->flags = val;
}
+void
+pcm_setswap(device_t dev, pcm_swap_t *swap)
+{
+ snddev_info *d = device_get_softc(dev);
+ d->swap = swap;
+}
/* This is the generic init routine */
int
pcm_register(device_t dev, void *devinfo, int numplay, int numrec)
@@ -172,6 +178,7 @@ pcm_register(device_t dev, void *devinfo, int numplay, int numrec)
fkchan_setup(&d->fakechan);
chn_init(&d->fakechan, NULL, 0);
d->magic = MAGIC(unit); /* debugging... */
+ d->swap = NULL;
return 0;
no:
diff --git a/sys/dev/sound/pcm/sound.h b/sys/dev/sound/pcm/sound.h
index 97cbd0d..d2409ef 100644
--- a/sys/dev/sound/pcm/sound.h
+++ b/sys/dev/sound/pcm/sound.h
@@ -97,8 +97,6 @@ struct isa_device { int dummy; };
#define MAGIC(unit) (0xa4d10de0 + unit)
#define SD_F_SIMPLEX 0x00000001
-#define SD_F_EVILSB16 0x00000002
-#define SD_F_EVILERSB16X 0x00000004
#define SD_F_PRIO_RD 0x10000000
#define SD_F_PRIO_WR 0x20000000
#define SD_F_PRIO_SET (SD_F_PRIO_RD | SD_F_PRIO_WR)
@@ -165,6 +163,7 @@ int pcm_register(device_t dev, void *devinfo, int numplay, int numrec);
int pcm_setstatus(device_t dev, char *str);
u_int32_t pcm_getflags(device_t dev);
void pcm_setflags(device_t dev, u_int32_t val);
+void pcm_setswap(device_t dev, pcm_swap_t *swap);
#endif /* KERNEL */
OpenPOWER on IntegriCloud