Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/isaki-audio2]: src/sys/arch/arm/imx Adapt to audio2.



details:   https://anonhg.NetBSD.org/src/rev/b0c6bd2d695f
branches:  isaki-audio2
changeset: 998484:b0c6bd2d695f
user:      isaki <isaki%NetBSD.org@localhost>
date:      Wed Apr 24 12:01:50 2019 +0000

description:
Adapt to audio2.
- move resetting sc_cmd_index from drain to halt_output since
  drain is obsoleted.

diffstat:

 sys/arch/arm/imx/imx23_digfilt.c |  58 +++++++++++----------------------------
 1 files changed, 16 insertions(+), 42 deletions(-)

diffs (123 lines):

diff -r b1300a41d647 -r b0c6bd2d695f sys/arch/arm/imx/imx23_digfilt.c
--- a/sys/arch/arm/imx/imx23_digfilt.c  Tue Apr 23 13:38:48 2019 +0000
+++ b/sys/arch/arm/imx/imx23_digfilt.c  Wed Apr 24 12:01:50 2019 +0000
@@ -1,4 +1,4 @@
-/* $Id: imx23_digfilt.c,v 1.1 2015/01/10 12:16:28 jmcneill Exp $ */
+/* $Id: imx23_digfilt.c,v 1.1.24.1 2019/04/24 12:01:50 isaki Exp $ */
 
 /*
  * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -39,7 +39,6 @@
 #include <sys/mutex.h>
 #include <sys/audioio.h>
 #include <dev/audio_if.h>
-#include <dev/auconv.h>
 #include <sys/mallocvar.h>
 #include <arm/imx/imx23_digfiltreg.h>
 #include <arm/imx/imx23_rtcvar.h>
@@ -56,11 +55,10 @@
 static int digfilt_activate(device_t, enum devact);
 
 /* Audio driver interface. */
-static int digfilt_drain(void *);
-static int digfilt_query_encoding(void *, struct audio_encoding *);
-static int digfilt_set_params(void *, int, int, audio_params_t *,
-    audio_params_t *, stream_filter_list_t *,
-    stream_filter_list_t *);
+static int digfilt_query_format(void *, audio_format_query_t *);
+static int digfilt_set_format(void *, int,
+    const audio_params_t *, const audio_params_t *,
+    audio_filter_reg_t *, audio_filter_reg_t *);
 static int digfilt_round_blocksize(void *, int, int, const audio_params_t *);
 static int digfilt_init_output(void *, void *, int );
 static int digfilt_start_output(void *, void *, int, void (*)(void *), void *);
@@ -116,7 +114,6 @@
        device_t sc_dev;
        device_t sc_audiodev;
        struct audio_format sc_format;
-       struct audio_encoding_set *sc_encodings;
        bus_space_handle_t sc_aihdl;
        bus_space_handle_t sc_aohdl;
        apbdma_softc_t sc_dmac;
@@ -151,9 +148,8 @@
 static const struct audio_hw_if digfilt_hw_if = {
        .open = NULL,
        .close = NULL,
-       .drain = digfilt_drain,
-       .query_encoding = digfilt_query_encoding,
-       .set_params = digfilt_set_params,
+       .query_format = digfilt_query_format,
+       .set_format = digfilt_set_format,
        .round_blocksize = digfilt_round_blocksize,
        .commit_settings = NULL,
        .init_output = digfilt_init_output,
@@ -309,11 +305,6 @@
        sc->sc_format.frequency[6] = 32000;
        sc->sc_format.frequency[7] = 44100;
 
-       if (auconv_create_encodings(&sc->sc_format, 1, &sc->sc_encodings)) {
-               aprint_error_dev(self, "could not create encodings\n");
-               return;
-       }
-
        sc->sc_audiodev = audio_attach_mi(&digfilt_hw_if, sc, sc->sc_dev);
 
        /* Default mutes. */
@@ -359,41 +350,21 @@
 }
 
 static int
-digfilt_drain(void *priv)
+digfilt_query_format(void *priv, audio_format_query_t *afp)
 {
-
        struct digfilt_softc *sc = priv;
 
-       apbdma_wait(sc->sc_dmac, 1);
-       sc->sc_cmd_index = 0;
-       
-       return 0;
+       return audio_query_format(&sc->sc_format, 1, afp);
 }
 
 static int
-digfilt_query_encoding(void *priv, struct audio_encoding *ae)
-{
-       struct digfilt_softc *sc = priv;
-       return auconv_query_encoding(sc->sc_encodings, ae);
-}
-
-static int
-digfilt_set_params(void *priv, int setmode, int usemode,
-    audio_params_t *play, audio_params_t *rec,
-    stream_filter_list_t *pfil, stream_filter_list_t *rfil)
+digfilt_set_format(void *priv, int setmode,
+    const audio_params_t *play, const audio_params_t *rec,
+    audio_filter_reg_t *pfil, audio_filter_reg_t *rfil)
 {
        struct digfilt_softc *sc = priv;
-       int index;
 
-       if (play && (setmode & AUMODE_PLAY)) {
-               index = auconv_set_converter(&sc->sc_format, 1,
-                   AUMODE_PLAY, play, true, pfil);
-               if (index < 0)
-                       return EINVAL;
-               sc->sc_pparam = pfil->req_size > 0 ?
-                   pfil->filters[0].param :
-                   *play;
-
+       if ((setmode & AUMODE_PLAY)) {
                /* At this point bitrate should be figured out. */
                digfilt_ao_set_rate(sc, sc->sc_pparam.sample_rate);
        }
@@ -486,6 +457,9 @@
 static int
 digfilt_halt_output(void *priv)
 {
+       struct digfilt_softc *sc = priv;
+
+       sc->sc_cmd_index = 0;
        return 0;
 }
 



Home | Main Index | Thread Index | Old Index