Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/isaki-audio2]: src/sys/dev Remove query_encoding and set_params interfac...
details: https://anonhg.NetBSD.org/src/rev/4fa61e61101a
branches: isaki-audio2
changeset: 998525:4fa61e61101a
user: isaki <isaki%NetBSD.org@localhost>
date: Fri May 03 05:15:33 2019 +0000
description:
Remove query_encoding and set_params interfaces from audio_hw_if
and remove related backward compatible routines.
All drivers were converted to use new query_format/set_format.
diffstat:
sys/dev/audio/audio.c | 229 ++++---------------------------------------------
sys/dev/audio_if.h | 24 +----
2 files changed, 27 insertions(+), 226 deletions(-)
diffs (truncated from 432 to 300 lines):
diff -r 345e58366cc6 -r 4fa61e61101a sys/dev/audio/audio.c
--- a/sys/dev/audio/audio.c Fri May 03 04:15:23 2019 +0000
+++ b/sys/dev/audio/audio.c Fri May 03 05:15:33 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: audio.c,v 1.1.2.3 2019/04/27 12:05:28 isaki Exp $ */
+/* $NetBSD: audio.c,v 1.1.2.4 2019/05/03 05:15:33 isaki Exp $ */
/*-
* Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -104,8 +104,8 @@
* open x x +
* close x x +
* drain x x (Not used in AUDIO2)
- * query_encoding - x (Not used in AUDIO2)
- * set_params - x (Obsoleted in AUDIO2)
+ * query_format - x
+ * set_format - x
* round_blocksize - x
* commit_settings - x
* init_output x x
@@ -129,8 +129,6 @@
* trigger_input x x +
* dev_ioctl - x
* get_locks - - Called at attach time
- * query_format - x (Added in AUDIO2)
- * set_format - x (Added in AUDIO2)
*
* *1 Note: Before 8.0, since these have been called only at attach time,
* neither lock were necessary. In AUDIO2, on the other hand, since
@@ -154,7 +152,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: audio.c,v 1.1.2.3 2019/04/27 12:05:28 isaki Exp $");
+__KERNEL_RCSID(0, "$NetBSD: audio.c,v 1.1.2.4 2019/05/03 05:15:33 isaki Exp $");
#ifdef _KERNEL_OPT
#include "audio.h"
@@ -164,7 +162,6 @@
#if NAUDIO > 0
#ifdef _KERNEL
-#define OLD_FILTER
#include <sys/types.h>
#include <sys/param.h>
@@ -197,7 +194,6 @@
#include <dev/audio_if.h>
#include <dev/audiovar.h>
-#include <dev/auconv.h>
#include <dev/audio/audiodef.h>
#include <dev/audio/linear.h>
#include <dev/audio/mulaw.h>
@@ -211,7 +207,7 @@
/*
* 0: No debug logs
- * 1: action changes like open/close/set_param...
+ * 1: action changes like open/close/set_format...
* 2: + normal operations like read/write/ioctl...
* 3: + TRACEs except interrupt
* 4: + TRACEs including interrupt
@@ -485,15 +481,6 @@
int mask;
};
-#if defined(OLD_FILTER)
-typedef struct uio_fetcher {
- stream_fetcher_t base;
- struct uio *uio;
- int usedhigh;
- int last_used;
-} uio_fetcher_t;
-#endif
-
static int audiomatch(device_t, cfdata_t, void *);
static void audioattach(device_t, device_t, void *);
static int audiodetach(device_t, int);
@@ -570,7 +557,7 @@
const struct audio_info *);
static int audio_hw_setinfo(struct audio_softc *, const struct audio_info *,
struct audio_info *);
-static int audio_hw_set_params(struct audio_softc *, int,
+static int audio_hw_set_format(struct audio_softc *, int,
audio_format2_t *, audio_format2_t *,
audio_filter_reg_t *, audio_filter_reg_t *);
static int audiogetinfo(struct audio_softc *, struct audio_info *, int,
@@ -586,10 +573,6 @@
static int audio_hw_probe(struct audio_softc *, int, int *,
audio_format2_t *, audio_format2_t *);
static int audio_hw_probe_fmt(struct audio_softc *, audio_format2_t *, int);
-static int audio_hw_probe_by_format(struct audio_softc *, audio_format2_t *,
- int);
-static int audio_hw_probe_by_encoding(struct audio_softc *, audio_format2_t *,
- int);
static int audio_hw_validate_format(struct audio_softc *, int,
const audio_format2_t *);
static int audio_mixers_set_format(struct audio_softc *,
@@ -635,15 +618,6 @@
static void audio_rmixer_input(struct audio_softc *);
static int audio_rmixer_halt(struct audio_softc *);
-#if defined(OLD_FILTER)
-static void stream_filter_list_append(stream_filter_list_t *,
- stream_filter_factory_t, const audio_params_t *);
-static void stream_filter_list_prepend(stream_filter_list_t *,
- stream_filter_factory_t, const audio_params_t *);
-static void stream_filter_list_set(stream_filter_list_t *, int,
- stream_filter_factory_t, const audio_params_t *);
-#endif
-
static void mixer_init(struct audio_softc *);
static int mixer_open(dev_t, struct audio_softc *, int, int, struct lwp *);
static int mixer_close(struct audio_softc *, audio_file_t *);
@@ -897,7 +871,8 @@
hw_if->get_locks(hdlp, &sc->sc_intr_lock, &sc->sc_lock);
#ifdef DIAGNOSTIC
- if ((hw_if->set_params == NULL && hw_if->set_format == NULL) ||
+ if (hw_if->query_format == NULL ||
+ hw_if->set_format == NULL ||
(hw_if->start_output == NULL && hw_if->trigger_output == NULL) ||
(hw_if->start_input == NULL && hw_if->trigger_input == NULL) ||
hw_if->halt_output == NULL ||
@@ -965,7 +940,7 @@
}
/* Init hardware. */
/* hw_probe() also validates [pr]hwfmt. */
- error = audio_hw_set_params(sc, mode, &phwfmt, &rhwfmt, &pfil, &rfil);
+ error = audio_hw_set_format(sc, mode, &phwfmt, &rhwfmt, &pfil, &rfil);
if (error) {
mutex_exit(sc->sc_lock);
goto bad;
@@ -1368,59 +1343,6 @@
return config_found(dev, &arg, audioprint);
}
-#if defined(OLD_FILTER)
-static void
-stream_filter_list_append(stream_filter_list_t *list,
- stream_filter_factory_t factory,
- const audio_params_t *param)
-{
-
- if (list->req_size >= AUDIO_MAX_FILTERS) {
- printf("%s: increase AUDIO_MAX_FILTERS in sys/dev/audio_if.h\n",
- __func__);
- return;
- }
- list->filters[list->req_size].factory = factory;
- list->filters[list->req_size].param = *param;
- list->req_size++;
-}
-
-static void
-stream_filter_list_set(stream_filter_list_t *list, int i,
- stream_filter_factory_t factory,
- const audio_params_t *param)
-{
-
- if (i < 0 || i >= AUDIO_MAX_FILTERS) {
- printf("%s: invalid index: %d\n", __func__, i);
- return;
- }
-
- list->filters[i].factory = factory;
- list->filters[i].param = *param;
- if (list->req_size <= i)
- list->req_size = i + 1;
-}
-
-static void
-stream_filter_list_prepend(stream_filter_list_t *list,
- stream_filter_factory_t factory,
- const audio_params_t *param)
-{
-
- if (list->req_size >= AUDIO_MAX_FILTERS) {
- printf("%s: increase AUDIO_MAX_FILTERS in sys/dev/audio_if.h\n",
- __func__);
- return;
- }
- memmove(&list->filters[1], &list->filters[0],
- sizeof(struct stream_filter_req) * list->req_size);
- list->filters[0].factory = factory;
- list->filters[0].param = *param;
- list->req_size++;
-}
-#endif /* OLD_FILTER */
-
/*
* Acquire sc_lock and enter exlock critical section.
* If successful, it returns 0. Otherwise returns errno.
@@ -6240,35 +6162,13 @@
}
/*
- * Probe the hardware format depending on mode.
- * Must be called with sc_lock held.
- * XXX Once all hw drivers go to use query_format, the function will be gone.
- */
-static int
-audio_hw_probe_fmt(struct audio_softc *sc, audio_format2_t *cand, int mode)
-{
-
- KASSERT(mutex_owned(sc->sc_lock));
-
- /* XXX Display the message only during the transition period. */
- if (sc->hw_if->query_format) {
- aprint_normal_dev(sc->sc_dev, "use new query_format method\n");
- return audio_hw_probe_by_format(sc, cand, mode);
- } else {
- aprint_normal_dev(sc->sc_dev, "use old set_param method\n");
- return audio_hw_probe_by_encoding(sc, cand, mode);
- }
-}
-
-/*
- * Choose the most preferred hardware format using query_format.
+ * Choose the most preferred hardware format.
* If successful, it will store the chosen format into *cand and return 0.
* Otherwise, return errno.
* Must be called with sc_lock held.
*/
static int
-audio_hw_probe_by_format(struct audio_softc *sc, audio_format2_t *cand,
- int mode)
+audio_hw_probe_fmt(struct audio_softc *sc, audio_format2_t *cand, int mode)
{
audio_format_query_t query;
int cand_score;
@@ -6377,52 +6277,6 @@
}
/*
- * Probe the hardware format using old set_params.
- * It is only provided for backward compatibility. Please don't try to
- * improve.
- * Must be called with sc_lock held.
- */
-static int
-audio_hw_probe_by_encoding(struct audio_softc *sc, audio_format2_t *cand,
- int mode)
-{
- static u_int freqlist[] = { 48000, 44100, 22050, 11025, 8000, 4000 };
- audio_format2_t fmt;
- u_int ch;
- u_int i;
- int error;
-
- KASSERT(mutex_owned(sc->sc_lock));
-
- fmt.encoding = AUDIO_ENCODING_SLINEAR_NE;
- fmt.precision = AUDIO_INTERNAL_BITS;
- fmt.stride = AUDIO_INTERNAL_BITS;
-
- for (ch = 2; ch > 0; ch--) {
- for (i = 0; i < __arraycount(freqlist); i++) {
- fmt.channels = ch;
- fmt.sample_rate = freqlist[i];
- error = audio_hw_set_params(sc, mode, &fmt, &fmt,
- NULL, NULL);
- if (error == 0) {
- /* Accept it because we were able to set. */
- *cand = fmt;
- DPRINTF(1, "%s selected: ch=%d freq=%d\n",
- __func__,
- fmt.channels,
- fmt.sample_rate);
- return 0;
- }
- DPRINTF(1, "%s trying ch=%d freq=%d failed\n",
- __func__,
- fmt.channels,
- fmt.sample_rate);
- }
- }
- return ENXIO;
-}
-
-/*
* Validate fmt with query_format.
* If fmt is included in the result of query_format, returns 0.
* Otherwise returns EINVAL.
@@ -6608,7 +6462,7 @@
/* Configure the mixers. */
memset(&pfil, 0, sizeof(pfil));
memset(&rfil, 0, sizeof(rfil));
- error = audio_hw_set_params(sc, mode, &phwfmt, &rhwfmt, &pfil, &rfil);
+ error = audio_hw_set_format(sc, mode, &phwfmt, &rhwfmt, &pfil, &rfil);
if (error)
return error;
@@ -7216,74 +7070,35 @@
* - phwfmt and rhwfmt must not be NULL regardless of setmode.
* - On non-independent devices, phwfmt and rhwfmt must have the same
* parameters.
- * - pfil and rfil must be zero-filled when using set_format, or can be
- * NULL when using set_params.
Home |
Main Index |
Thread Index |
Old Index