Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/isaki-audio2]: src/sys/arch/sgimips/mace Adapt to audio2.
details:   https://anonhg.NetBSD.org/src/rev/ce92a4c7d07e
branches:  isaki-audio2
changeset: 455983:ce92a4c7d07e
user:      isaki <isaki%NetBSD.org@localhost>
date:      Sun Apr 21 13:05:46 2019 +0000
description:
Adapt to audio2.
- The driver does not support recording so drop CAPTURE property.
diffstat:
 sys/arch/sgimips/mace/mavb.c |  236 ++++++++----------------------------------
 1 files changed, 47 insertions(+), 189 deletions(-)
diffs (truncated from 373 to 300 lines):
diff -r 910773531e5c -r ce92a4c7d07e sys/arch/sgimips/mace/mavb.c
--- a/sys/arch/sgimips/mace/mavb.c      Sun Apr 21 12:54:25 2019 +0000
+++ b/sys/arch/sgimips/mace/mavb.c      Sun Apr 21 13:05:46 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: mavb.c,v 1.12.2.1 2019/04/21 05:11:21 isaki Exp $ */
+/* $NetBSD: mavb.c,v 1.12.2.2 2019/04/21 13:05:46 isaki Exp $ */
 /* $OpenBSD: mavb.c,v 1.6 2005/04/15 13:05:14 mickey Exp $ */
 
 /*
@@ -29,7 +29,6 @@
 #include <machine/autoconf.h>
 
 #include <sys/audioio.h>
-#include <dev/auconv.h>
 #include <dev/audio_if.h>
 
 #include <arch/sgimips/mace/macevar.h>
@@ -108,22 +107,19 @@
        AudioNmono              /* AD1843_MISC_SETTINGS */
 };
 
-#define MAVB_NFORMATS 2
-#define MAVB_FORMAT(ch, chmask) \
-       { \
-               .mode           = AUMODE_PLAY | AUMODE_RECORD, \
-               .encoding       = AUDIO_ENCODING_SLINEAR_BE, \
-               .validbits      = 16, \
-               .precision      = 16, \
-               .channels       = (ch), \
-               .channel_mask   = (chmask), \
-               .frequency_type = 0, \
-               .frequency      = { 8000, 48000 }, \
-       }
-static const struct audio_format mavb_formats[MAVB_NFORMATS] = {
-       MAVB_FORMAT(1, AUFMT_MONAURAL),
-       MAVB_FORMAT(2, AUFMT_STEREO),
+static const struct audio_format mavb_formats[] = {
+       {
+               .mode           = AUMODE_PLAY,
+               .encoding       = AUDIO_ENCODING_SLINEAR_BE,
+               .validbits      = 16,
+               .precision      = 16,
+               .channels       = 2,
+               .channel_mask   = AUFMT_STEREO,
+               .frequency_type = 0,
+               .frequency      = { 8000, 48000 },
+       },
 };
+#define MAVB_NFORMATS __arraycount(mavb_formats)
 
 struct mavb_softc {
        device_t sc_dev;
@@ -152,101 +148,8 @@
        u_int sc_play_format;
 
        struct callout sc_volume_button_ch;
-
-       struct audio_format sc_formats[MAVB_NFORMATS];
-       struct audio_encoding_set *sc_encodings;
 };
 
-struct mavb_codecvar {
-       stream_filter_t base;
-};
-
-static stream_filter_t *mavb_factory
-    (struct audio_softc *,
-     int (*)(struct audio_softc *, stream_fetcher_t *, audio_stream_t *, int));
-static void mavb_dtor(stream_filter_t *);
-
-/* XXX I'm going to complain every time I have to copy this macro */
-#define DEFINE_FILTER(name)                                            \
-static int                                                             \
-name##_fetch_to(struct audio_softc *, stream_fetcher_t *,              \
-               audio_stream_t *, int);                                 \
-stream_filter_t *name(struct audio_softc *,                            \
-    const audio_params_t *, const audio_params_t *);                   \
-stream_filter_t *                                                      \
-name(struct audio_softc *sc, const audio_params_t *from,               \
-    const audio_params_t *to)                                          \
-{                                                                      \
-       return mavb_factory(sc, name##_fetch_to);                       \
-}                                                                      \
-static int                                                             \
-name##_fetch_to(struct audio_softc *asc, stream_fetcher_t *self,       \
-    audio_stream_t *dst, int max_used)
-
-DEFINE_FILTER(mavb_16to24)
-{
-       stream_filter_t *this;
-       int m, err;
-
-       this = (stream_filter_t *)self;
-       max_used = (max_used + 1) & ~1;
-       if ((err = this->prev->fetch_to(asc, this->prev, this->src, max_used)))
-               return err;
-       m = (dst->end - dst->start) & ~1;
-       m = uimin(m, max_used);
-       FILTER_LOOP_PROLOGUE(this->src, 2, dst, 4, m) {
-               d[3] = 0;
-               d[2] = s[1];
-               d[1] = s[0];
-               d[0] = (s[0] & 0x80) ? 0xff : 0;
-       } FILTER_LOOP_EPILOGUE(this->src, dst);
-
-       return 0;
-}
-
-DEFINE_FILTER(mavb_mts)
-{
-       stream_filter_t *this;
-       int m, err;
-
-       this = (stream_filter_t *)self;
-       max_used = (max_used + 1) & ~1;
-       if ((err = this->prev->fetch_to(asc, this->prev, this->src, max_used)))
-               return err;
-       m = (dst->end - dst->start) & ~1;
-       m = uimin(m, max_used);
-       FILTER_LOOP_PROLOGUE(this->src, 4, dst, 8, m) {
-               d[3] = d[7] = s[3];
-               d[2] = d[6] = s[2];
-               d[1] = d[5] = s[1];
-               d[0] = d[4] = s[0];
-       } FILTER_LOOP_EPILOGUE(this->src, dst);
-
-       return 0;
-}
-
-static stream_filter_t *
-mavb_factory(struct audio_softc *asc, int (*fetch_to)(struct audio_softc *, stream_fetcher_t *, audio_stream_t *, int))
-{
-       struct mavb_codecvar *this;
-
-       this = kmem_zalloc(sizeof(*this), KM_SLEEP);
-       this->base.base.fetch_to = fetch_to;
-       this->base.dtor = mavb_dtor;
-       this->base.set_fetcher = stream_filter_set_fetcher;
-       this->base.set_inputbuffer = stream_filter_set_inputbuffer;
-
-       return &this->base;
-}
-
-static void
-mavb_dtor(stream_filter_t *this)
-{
-
-       if (this != NULL)
-               kmem_free(this, sizeof(struct mavb_codecvar));
-}
-
 typedef uint64_t ad1843_addr_t;
 
 uint16_t ad1843_reg_read(struct mavb_softc *, ad1843_addr_t);
@@ -258,13 +161,11 @@
 
 CFATTACH_DECL_NEW(mavb, sizeof(struct mavb_softc),
     mavb_match, mavb_attach, NULL, NULL);
-    
-int mavb_open(void *, int);
-void mavb_close(void *);
-int mavb_query_encoding(void *, struct audio_encoding *);
-int mavb_set_params(void *, int, int, struct audio_params *,
-                   struct audio_params *, stream_filter_list_t *,
-                   stream_filter_list_t *);
+
+int mavb_query_format(void *, audio_format_query_t *);
+int mavb_set_format(void *, int,
+                   const audio_params_t *, const audio_params_t *,
+                   audio_filter_reg_t *, audio_filter_reg_t *);
 int mavb_round_blocksize(void *hdl, int, int, const audio_params_t *);
 int mavb_halt_output(void *);
 int mavb_halt_input(void *);
@@ -272,7 +173,6 @@
 int mavb_set_port(void *, struct mixer_ctrl *);
 int mavb_get_port(void *, struct mixer_ctrl *);
 int mavb_query_devinfo(void *, struct mixer_devinfo *);
-size_t mavb_round_buffersize(void *, int, size_t);
 int mavb_get_props(void *);
 int mavb_trigger_output(void *, void *, void *, int, void (*)(void *),
                        void *, const audio_params_t *);
@@ -281,10 +181,8 @@
 void mavb_get_locks(void *, kmutex_t **, kmutex_t **);
 
 struct audio_hw_if mavb_sa_hw_if = {
-       .open                   = mavb_open,
-       .close                  = mavb_close,
-       .query_encoding         = mavb_query_encoding,
-       .set_params             = mavb_set_params,
+       .query_format           = mavb_query_format,
+       .set_format             = mavb_set_format,
        .round_blocksize        = mavb_round_blocksize,
        .halt_output            = mavb_halt_output,
        .halt_input             = mavb_halt_input,
@@ -292,7 +190,6 @@
        .set_port               = mavb_set_port,
        .get_port               = mavb_get_port,
        .query_devinfo          = mavb_query_devinfo,
-       .round_buffersize       = mavb_round_buffersize,
        .get_props              = mavb_get_props,
        .trigger_output         = mavb_trigger_output,
        .trigger_input          = mavb_trigger_input,
@@ -305,32 +202,34 @@
        "mavb"
 };
 
-int
-mavb_open(void *hdl, int flags)
+static void
+mavb_internal_to_slinear24_32(audio_filter_arg_t *arg)
 {
+       const aint_t *src;
+       uint32_t *dst;
+       u_int sample_count;
+       u_int i;
 
-       return 0;
-}
-
-void
-mavb_close(void *hdl)
-{
+       src = arg->src;
+       dst = arg->dst;
+       sample_count = arg->count * arg->srcfmt->channels;
+       for (i = 0; i < sample_count; i++) {
+               *dst++ = (*src++) << 8;
+       }
 }
 
 int
-mavb_query_encoding(void *hdl, struct audio_encoding *ae)
+mavb_query_format(void *hdl, audio_format_query_t *afp)
 {
-       struct mavb_softc *sc = (struct mavb_softc *)hdl;
 
-       return auconv_query_encoding(sc->sc_encodings, ae);
+       return audio_query_format(mavb_formats, MAVB_NFORMATS, afp);
 }
 
 static int
 mavb_set_play_rate(struct mavb_softc *sc, u_long sample_rate)
 {
 
-       if (sample_rate < 4000 || sample_rate > 48000)
-               return EINVAL;
+       KASSERT((4000 <= sample_rate && sample_rate <= 48000));
 
        if (sc->sc_play_rate != sample_rate) {
                ad1843_reg_write(sc, AD1843_CLOCK2_SAMPLE_RATE, sample_rate);
@@ -346,18 +245,9 @@
        u_int format;
 
        switch(encoding) {
-       case AUDIO_ENCODING_ULINEAR_BE:
-               format = AD1843_PCM8;
-               break;
        case AUDIO_ENCODING_SLINEAR_BE:
                format = AD1843_PCM16;
                break;
-       case AUDIO_ENCODING_ULAW:
-               format = AD1843_ULAW;
-               break;
-       case AUDIO_ENCODING_ALAW:
-               format = AD1843_ALAW;
-               break;
        default:
                return EINVAL;
        }
@@ -373,48 +263,31 @@
 }
 
 int
-mavb_set_params(void *hdl, int setmode, int usemode,
-    struct audio_params *play, struct audio_params *rec,
-    stream_filter_list_t *pfil, stream_filter_list_t *rfil)
+mavb_set_format(void *hdl, int setmode,
+    const audio_params_t *play, const audio_params_t *rec,
+    audio_filter_reg_t *pfil, audio_filter_reg_t *rfil)
 {
        struct mavb_softc *sc = (struct mavb_softc *)hdl;
-       struct audio_params *p;
-       stream_filter_list_t *fil;
        int error;
 
-       DPRINTF(1, ("%s: mavb_set_params: sample=%u precision=%d "
-           "channels=%d\n", device_xname(sc->sc_dev), play->sample_rate,
-           play->precision, play->channels));
+       DPRINTF(1, ("%s: %s: sample=%u precision=%d channels=%d\n",
+           device_xname(sc->sc_dev), __func__,
+           play->sample_rate, play->precision, play->channels));
 
        if (setmode & AUMODE_PLAY) {
-               if (play->sample_rate < 4000 || play->sample_rate > 48000)
-                       return EINVAL;
-
-               p = play;
-               fil = pfil;
-               if (auconv_set_converter(sc->sc_formats, MAVB_NFORMATS,
-                   AUMODE_PLAY, p, TRUE, fil) < 0)
Home |
Main Index |
Thread Index |
Old Index