Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/isaki-audio2]: src/sys/dev/ic Adapt to audio2.
details: https://anonhg.NetBSD.org/src/rev/6052a03c915f
branches: isaki-audio2
changeset: 998480:6052a03c915f
user: isaki <isaki%NetBSD.org@localhost>
date: Sun Apr 21 14:00:19 2019 +0000
description:
Adapt to audio2.
diffstat:
sys/arch/x68k/dev/vs.c | 207 +++++++---------------------
sys/arch/x68k/dev/vsvar.h | 4 +-
sys/dev/ic/msm6258.c | 330 ++++++---------------------------------------
sys/dev/ic/msm6258var.h | 16 +-
4 files changed, 117 insertions(+), 440 deletions(-)
diffs (truncated from 760 to 300 lines):
diff -r ac21c0f32456 -r 6052a03c915f sys/arch/x68k/dev/vs.c
--- a/sys/arch/x68k/dev/vs.c Sun Apr 21 13:05:46 2019 +0000
+++ b/sys/arch/x68k/dev/vs.c Sun Apr 21 14:00:19 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: vs.c,v 1.50 2019/03/16 12:09:57 isaki Exp $ */
+/* $NetBSD: vs.c,v 1.50.2.1 2019/04/21 14:00:19 isaki Exp $ */
/*
* Copyright (c) 2001 Tetsuya Isaki. All rights reserved.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vs.c,v 1.50 2019/03/16 12:09:57 isaki Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vs.c,v 1.50.2.1 2019/04/21 14:00:19 isaki Exp $");
#include "audio.h"
#include "vs.h"
@@ -43,7 +43,6 @@
#include <sys/audioio.h>
#include <dev/audio_if.h>
-#include <dev/mulaw.h>
#include <machine/bus.h>
#include <machine/cpu.h>
@@ -75,11 +74,11 @@
/* MI audio layer interface */
static int vs_open(void *, int);
static void vs_close(void *);
-static int vs_query_encoding(void *, struct audio_encoding *);
-static int vs_set_params(void *, int, int, audio_params_t *,
- audio_params_t *, stream_filter_list_t *, stream_filter_list_t *);
-static int vs_init_output(void *, void *, int);
-static int vs_init_input(void *, void *, int);
+static int vs_query_format(void *, audio_format_query_t *);
+static int vs_set_format(void *, int,
+ const audio_params_t *, const audio_params_t *,
+ audio_filter_reg_t *, audio_filter_reg_t *);
+static int vs_commit_settings(void *);
static int vs_start_input(void *, void *, int, void (*)(void *), void *);
static int vs_start_output(void *, void *, int, void (*)(void *), void *);
static int vs_halt_output(void *);
@@ -99,8 +98,7 @@
/* lower functions */
static int vs_round_sr(u_long);
-static void vs_set_sr(struct vs_softc *, int);
-static inline void vs_set_po(struct vs_softc *, u_long);
+static inline void vs_set_panout(struct vs_softc *, u_long);
extern struct cfdriver vs_cd;
@@ -112,10 +110,9 @@
static const struct audio_hw_if vs_hw_if = {
.open = vs_open,
.close = vs_close,
- .query_encoding = vs_query_encoding,
- .set_params = vs_set_params,
- .init_output = vs_init_output,
- .init_input = vs_init_input,
+ .query_format = vs_query_format,
+ .set_format = vs_set_format,
+ .commit_settings = vs_commit_settings,
.start_output = vs_start_output,
.start_input = vs_start_input,
.halt_output = vs_halt_output,
@@ -137,6 +134,18 @@
"vs"
};
+static const struct audio_format vs_formats = {
+ .mode = AUMODE_PLAY | AUMODE_RECORD,
+ .encoding = AUDIO_ENCODING_ADPCM,
+ .validbits = 4,
+ .precision = 4,
+ .channels = 1,
+ .channel_mask = AUFMT_MONAURAL,
+ .frequency_type = 5,
+ .frequency = { VS_RATE_3K, VS_RATE_5K, VS_RATE_7K,
+ VS_RATE_10K, VS_RATE_15K },
+};
+
struct {
u_long rate;
u_char clk;
@@ -213,7 +222,7 @@
sc->sc_prev_vd = NULL;
sc->sc_active = 0;
mutex_init(&sc->sc_lock, MUTEX_DEFAULT, IPL_NONE);
- mutex_init(&sc->sc_intr_lock, MUTEX_DEFAULT, IPL_SCHED);
+ mutex_init(&sc->sc_intr_lock, MUTEX_DEFAULT, IPL_VM);
/* XXX */
bus_space_map(iot, PPI_ADDR, PPI_MAPSIZE, BUS_SPACE_MAP_SHIFTED,
@@ -298,169 +307,84 @@
}
static int
-vs_query_encoding(void *hdl, struct audio_encoding *fp)
+vs_query_format(void *hdl, audio_format_query_t *afp)
{
- DPRINTF(1, ("vs_query_encoding\n"));
-
- if (fp->index == 0) {
- strcpy(fp->name, AudioEslinear);
- fp->encoding = AUDIO_ENCODING_SLINEAR;
- fp->precision = 8;
- fp->flags = 0;
- return 0;
- }
- if (fp->index == 1) {
- strcpy(fp->name, AudioEslinear_be);
- fp->encoding = AUDIO_ENCODING_SLINEAR_BE;
- fp->precision = 16;
- fp->flags = 0;
- return 0;
- }
- return EINVAL;
+ return audio_query_format(&vs_formats, 1, afp);
}
static int
vs_round_sr(u_long rate)
{
int i;
- int diff;
- int nearest;
- diff = rate;
- nearest = 0;
for (i = 0; i < NUM_RATE; i++) {
- if (rate >= vs_l2r[i].rate) {
- if (rate - vs_l2r[i].rate < diff) {
- diff = rate - vs_l2r[i].rate;
- nearest = i;
- }
- } else {
- if (vs_l2r[i].rate - rate < diff) {
- diff = vs_l2r[i].rate - rate;
- nearest = i;
- }
- }
+ if (rate == vs_l2r[i].rate)
+ return i;
}
- if (diff * 100 / rate > 15)
- return -1;
- else
- return nearest;
+ return -1;
}
static int
-vs_set_params(void *hdl, int setmode, int usemode,
- audio_params_t *play, audio_params_t *rec,
- stream_filter_list_t *pfil, stream_filter_list_t *rfil)
+vs_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 vs_softc *sc;
- audio_params_t hw;
- stream_filter_factory_t *pconv;
- stream_filter_factory_t *rconv;
int rate;
sc = hdl;
- DPRINTF(1, ("vs_set_params: mode=%d enc=%d rate=%d prec=%d ch=%d: ",
- setmode, play->encoding, play->sample_rate,
- play->precision, play->channels));
+ DPRINTF(1, ("%s: mode=%d %s/%dbit/%dch/%dHz: ", __func__,
+ setmode, audio_encoding_name(play->encoding),
+ play->precision, play->channels, play->sample_rate));
/* *play and *rec are identical because !AUDIO_PROP_INDEPENDENT */
- if (play->channels != 1) {
- DPRINTF(1, ("channels not matched\n"));
- return EINVAL;
- }
-
rate = vs_round_sr(play->sample_rate);
- if (rate < 0) {
- DPRINTF(1, ("rate not matched\n"));
- return EINVAL;
- }
-
- if (play->precision == 8 && play->encoding == AUDIO_ENCODING_SLINEAR) {
- pconv = msm6258_linear8_to_adpcm;
- rconv = msm6258_adpcm_to_linear8;
- } else if (play->precision == 16 &&
- play->encoding == AUDIO_ENCODING_SLINEAR_BE) {
- pconv = msm6258_slinear16_to_adpcm;
- rconv = msm6258_adpcm_to_slinear16;
- } else {
- DPRINTF(1, ("prec/enc not matched\n"));
- return EINVAL;
- }
-
+ KASSERT(rate >= 0);
sc->sc_current.rate = rate;
- /* pfil and rfil are independent even if !AUDIO_PROP_INDEPENDENT */
-
if ((setmode & AUMODE_PLAY) != 0) {
- hw = *play;
- hw.encoding = AUDIO_ENCODING_ADPCM;
- hw.precision = 4;
- hw.validbits = 4;
- pfil->prepend(pfil, pconv, &hw);
+ pfil->codec = msm6258_internal_to_adpcm;
+ pfil->context = &sc->sc_codecvar;
}
if ((setmode & AUMODE_RECORD) != 0) {
- hw = *rec;
- hw.encoding = AUDIO_ENCODING_ADPCM;
- hw.precision = 4;
- hw.validbits = 4;
- rfil->prepend(rfil, rconv, &hw);
+ rfil->codec = msm6258_adpcm_to_internal;
+ rfil->context = &sc->sc_codecvar;
}
DPRINTF(1, ("accepted\n"));
return 0;
}
-static void
-vs_set_sr(struct vs_softc *sc, int rate)
+static int
+vs_commit_settings(void *hdl)
{
+ struct vs_softc *sc;
+ int rate;
- DPRINTF(1, ("setting sample rate to %d, %d\n",
+ sc = hdl;
+ rate = sc->sc_current.rate;
+
+ DPRINTF(1, ("commit_settings: sample rate to %d, %d\n",
rate, (int)vs_l2r[rate].rate));
bus_space_write_1(sc->sc_iot, sc->sc_ppi, PPI_PORTC,
(bus_space_read_1 (sc->sc_iot, sc->sc_ppi,
PPI_PORTC) & 0xf0)
| vs_l2r[rate].den);
adpcm_chgclk(vs_l2r[rate].clk);
-}
-
-static inline void
-vs_set_po(struct vs_softc *sc, u_long po)
-{
- bus_space_write_1(sc->sc_iot, sc->sc_ppi, PPI_PORTC,
- (bus_space_read_1(sc->sc_iot, sc->sc_ppi, PPI_PORTC)
- & 0xfc) | po);
-}
-
-static int
-vs_init_output(void *hdl, void *buffer, int size)
-{
- struct vs_softc *sc;
-
- DPRINTF(1, ("%s\n", __func__));
- sc = hdl;
-
- /* Set rate and pan */
- vs_set_sr(sc, sc->sc_current.rate);
- vs_set_po(sc, VS_PANOUT_LR);
return 0;
}
-static int
-vs_init_input(void *hdl, void *buffer, int size)
+static inline void
+vs_set_panout(struct vs_softc *sc, u_long po)
{
- struct vs_softc *sc;
- DPRINTF(1, ("%s\n", __func__));
- sc = hdl;
-
- /* Set rate */
- vs_set_sr(sc, sc->sc_current.rate);
-
- return 0;
+ bus_space_write_1(sc->sc_iot, sc->sc_ppi, PPI_PORTC,
+ (bus_space_read_1(sc->sc_iot, sc->sc_ppi, PPI_PORTC)
+ & 0xfc) | po);
}
static int
@@ -501,6 +425,7 @@
(int)block - (int)KVADDR(vd), blksize);
if (sc->sc_active == 0) {
+ vs_set_panout(sc, VS_PANOUT_LR);
bus_space_write_1(sc->sc_iot, sc->sc_ioh,
Home |
Main Index |
Thread Index |
Old Index