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/b861bb1b5f71
branches: isaki-audio2
changeset: 998491:b861bb1b5f71
user: isaki <isaki%NetBSD.org@localhost>
date: Thu Apr 25 13:49:39 2019 +0000
description:
Adapt to audio2.
- The sample rate seems to be determined by peripherals so
move uda1341_formats[] structure from ic/uda1341.c to audio_mini2440.c.
- XXX Resetting the device in open() (and close()) might be harmful
but I don't know details about what does this reset do.
diffstat:
sys/arch/evbarm/mini2440/audio_mini2440.c | 85 +++++++++++++-----------------
sys/dev/ic/uda1341.c | 69 +-----------------------
sys/dev/ic/uda1341var.h | 10 +--
3 files changed, 44 insertions(+), 120 deletions(-)
diffs (264 lines):
diff -r 984de7286c3e -r b861bb1b5f71 sys/arch/evbarm/mini2440/audio_mini2440.c
--- a/sys/arch/evbarm/mini2440/audio_mini2440.c Thu Apr 25 13:24:11 2019 +0000
+++ b/sys/arch/evbarm/mini2440/audio_mini2440.c Thu Apr 25 13:49:39 2019 +0000
@@ -72,8 +72,10 @@
int uda_ssio_open(void *, int);
void uda_ssio_close(void *);
-int uda_ssio_set_params(void *, int, int, audio_params_t *, audio_params_t *,
- stream_filter_list_t *, stream_filter_list_t *);
+int uda_ssio_query_format(void *, audio_format_query_t *);
+int uda_ssio_set_format(void *, int,
+ const audio_params_t *, const audio_params_t *,
+ audio_filter_reg_t *, audio_filter_reg_t *);
int uda_ssio_round_blocksize(void *, int, int, const audio_params_t *);
int uda_ssio_start_output(void *, void *, int, void (*)(void *),
void *);
@@ -91,8 +93,8 @@
struct audio_hw_if uda1341_hw_if = {
.open = uda_ssio_open,
.close = uda_ssio_close,
- .query_encoding = uda1341_query_encodings,
- .set_params = uda_ssio_set_params,
+ .query_format = uda_ssio_query_format,
+ .set_format = uda_ssio_set_format,
.round_blocksize = uda_ssio_round_blocksize,
.start_output = uda_ssio_start_output,
.start_input = uda_ssio_start_input,
@@ -115,6 +117,21 @@
"uda_ssio"
};
+static const struct audio_format uda_ssio_formats[] =
+{
+ {
+ .mode = AUMODE_PLAY | AUMODE_RECORD,
+ .encoding = AUDIO_ENCODING_SLINEAR_LE,
+ .validbits = 16,
+ .precision = 16,
+ .channels = 2,
+ .channel_mask = AUFMT_STEREO,
+ .frequency_type = 6,
+ .frequency = { 8000, 11025, 22050, 32000, 44100, 48000 },
+ }
+};
+#define UDA_SSIO_NFORMATS __arraycount(uda_ssio_formats)
+
void uda_ssio_l3_write(void *,int mode, int value);
int uda_ssio_match(device_t, cfdata_t, void*);
@@ -233,54 +250,28 @@
}
int
-uda_ssio_set_params(void *handle, int setmode, int usemode,
- audio_params_t *play, audio_params_t *rec,
- stream_filter_list_t *pfil, stream_filter_list_t *rfil)
+uda_ssio_query_format(void *handle, audio_format_query_t *afp)
+{
+
+ return audio_query_format(uda_ssio_formats, UDA_SSIO_NFORMATS, afp);
+}
+
+int
+uda_ssio_set_format(void *handle, int setmode,
+ const audio_params_t *play, const audio_params_t *rec,
+ audio_filter_reg_t *pfil, audio_filter_reg_t *rfil)
{
struct uda1341_softc *uc = handle;
struct uda_softc *sc = uc->parent;
- const struct audio_format *selected_format;
- audio_params_t *params;
- stream_filter_list_t *fil;
int retval;
DPRINTF(("%s: setmode: %d\n", __func__, setmode));
- DPRINTF(("%s: usemode: %d\n", __func__, usemode));
- if (setmode == 0)
- setmode = usemode;
-
- if (setmode & AUMODE_PLAY) {
- params = play;
- fil = pfil;
- } else if (setmode == AUMODE_RECORD) {
- params = rec;
- fil = rfil;
- } else {
- return EINVAL;
- }
+ /* *play and *rec are the identical because !AUDIO_PROP_INDEPENDENT. */
DPRINTF(("%s: %dHz, encoding: %d, precision: %d, channels: %d\n",
- __func__, params->sample_rate, params->encoding, play->precision,
- params->channels));
-
- if (params->sample_rate != 8000 &&
- params->sample_rate != 11025 &&
- params->sample_rate != 22050 &&
- params->sample_rate != 32000 &&
- params->sample_rate != 44100 &&
- params->sample_rate != 48000) {
- return EINVAL;
- }
-
- retval = auconv_set_converter(uda1341_formats, UDA1341_NFORMATS,
- setmode, params, true, fil);
- if (retval < 0) {
- printf("Could not find valid format\n");
- return EINVAL;
- }
-
- selected_format = &uda1341_formats[retval];
+ __func__, play->sample_rate, play->encoding, play->precision,
+ play->channels));
if (setmode == AUMODE_PLAY) {
s3c2440_i2s_set_direction(sc->sc_i2s_handle,
@@ -290,9 +281,8 @@
S3C2440_I2S_RECEIVE);
}
- s3c2440_i2s_set_sample_rate(sc->sc_i2s_handle, params->sample_rate);
- s3c2440_i2s_set_sample_width(sc->sc_i2s_handle,
- selected_format->precision);
+ s3c2440_i2s_set_sample_rate(sc->sc_i2s_handle, play->sample_rate);
+ s3c2440_i2s_set_sample_width(sc->sc_i2s_handle, 16);
/* It is vital that sc_system_clock is set PRIOR to calling
uda1341_set_params. */
@@ -307,8 +297,7 @@
return EINVAL;
}
- retval = uda1341_set_params(handle, setmode, usemode,
- play, rec, pfil, rfil);
+ retval = uda1341_set_format(handle, setmode, play, rec, pfil, rfil);
if (retval != 0) {
return retval;
}
diff -r 984de7286c3e -r b861bb1b5f71 sys/dev/ic/uda1341.c
--- a/sys/dev/ic/uda1341.c Thu Apr 25 13:24:11 2019 +0000
+++ b/sys/dev/ic/uda1341.c Thu Apr 25 13:49:39 2019 +0000
@@ -47,25 +47,6 @@
#define DPRINTF(s) do {} while (/*CONSTCOND*/0)
#endif
-#define UDA1341_FORMAT(enc, prec) \
- { \
- .mode = AUMODE_PLAY | AUMODE_RECORD, \
- .encoding = (enc), \
- .validbits = (prec), \
- .precision = (prec), \
- .channels = 2, \
- .channel_mask = AUFMT_STEREO, \
- .frequency_type = 0, \
- .frequency = { 8000, 48000 }, \
- }
-const struct audio_format uda1341_formats[UDA1341_NFORMATS] =
-{
- UDA1341_FORMAT(AUDIO_ENCODING_SLINEAR_LE, 8),
- UDA1341_FORMAT(AUDIO_ENCODING_SLINEAR_LE, 16),
- UDA1341_FORMAT(AUDIO_ENCODING_ULINEAR_LE, 8),
- UDA1341_FORMAT(AUDIO_ENCODING_ULINEAR_LE, 16),
-};
-
static void uda1341_update_sound_settings(struct uda1341_softc *sc);
@@ -95,48 +76,6 @@
}
int
-uda1341_query_encodings(void *handle, audio_encoding_t *ae)
-{
- switch(ae->index) {
- case 0:
- strlcpy(ae->name, AudioEmulaw, sizeof(ae->name));
- ae->encoding = AUDIO_ENCODING_ULAW;
- ae->precision = 8;
- ae->flags = AUDIO_ENCODINGFLAG_EMULATED;
- break;
- case 1:
- strlcpy(ae->name, AudioEslinear_le, sizeof(ae->name));
- ae->encoding = AUDIO_ENCODING_SLINEAR_LE;
- ae->precision = 8;
- ae->flags = 0;
- break;
- case 2:
- strlcpy(ae->name, AudioEslinear_le, sizeof(ae->name));
- ae->encoding = AUDIO_ENCODING_SLINEAR_LE;
- ae->precision = 16;
- ae->flags = 0;
- break;
- case 3:
- strlcpy(ae->name, AudioEulinear_le, sizeof(ae->name));
- ae->encoding = AUDIO_ENCODING_ULINEAR_LE;
- ae->precision = 8;
- ae->flags = 0;
- break;
- case 4:
- strlcpy(ae->name, AudioEulinear_le, sizeof(ae->name));
- ae->encoding = AUDIO_ENCODING_ULINEAR_LE;
- ae->precision = 16;
- ae->flags = 0;
- break;
-
- default:
- return EINVAL;
- }
-
- return 0;
-}
-
-int
uda1341_open(void *handle, int flags)
{
struct uda1341_softc *sc = handle;
@@ -188,13 +127,13 @@
}
int
-uda1341_set_params(void *handle, int setmode, int usemode,
- audio_params_t *play, audio_params_t *rec,
- stream_filter_list_t *pfil, stream_filter_list_t *rfil)
+uda1341_set_format(void *handle, int setmode,
+ const audio_params_t *play, const audio_params_t *rec,
+ audio_filter_reg_t *pfil, audio_filter_reg_t *rfil)
{
struct uda1341_softc *sc = handle;
if (sc->sc_system_clock == UDA1341_CLOCK_NA)
- panic("uda1341_set_params was called without sc_system_clock set!\n");
+ panic("%s was called without sc_system_clock set!\n", __func__);
/* Select status register */
sc->sc_l3_write(sc, 0, UDA1341_L3_ADDR_DEVICE |
diff -r 984de7286c3e -r b861bb1b5f71 sys/dev/ic/uda1341var.h
--- a/sys/dev/ic/uda1341var.h Thu Apr 25 13:24:11 2019 +0000
+++ b/sys/dev/ic/uda1341var.h Thu Apr 25 13:49:39 2019 +0000
@@ -32,11 +32,6 @@
#include <sys/device.h>
#include <sys/audioio.h>
-#include <dev/auconv.h>
-
-#define UDA1341_NFORMATS 4
-extern const struct audio_format uda1341_formats[UDA1341_NFORMATS];
-
struct uda1341_softc {
/* Pointer to the driver that holds this sc */
void *parent;
@@ -85,10 +80,11 @@
};
int uda1341_attach(struct uda1341_softc *);
-int uda1341_query_encodings(void *, audio_encoding_t *);
int uda1341_open(void *, int );
void uda1341_close(void *);
-int uda1341_set_params(void *, int, int, audio_params_t*, audio_params_t*, stream_filter_list_t *, stream_filter_list_t*);
+int uda1341_set_format(void *, int,
+ const audio_params_t *, const audio_params_t *,
+ audio_filter_reg_t *, audio_filter_reg_t *);
int uda1341_query_devinfo(void *, mixer_devinfo_t *);
int uda1341_get_port(void *, mixer_ctrl_t *);
int uda1341_set_port(void *, mixer_ctrl_t *);
Home |
Main Index |
Thread Index |
Old Index