Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/isaki-audio2]: src/sys/dev/hdaudio Adapt to audio2.
details: https://anonhg.NetBSD.org/src/rev/a78896335c14
branches: isaki-audio2
changeset: 455968:a78896335c14
user: isaki <isaki%NetBSD.org@localhost>
date: Sun Apr 21 05:22:57 2019 +0000
description:
Adapt to audio2.
- Fix wrong blocksize restrictions.
diffstat:
sys/dev/hdaudio/hdafg.c | 75 +++++++++++++-----------------------------------
1 files changed, 21 insertions(+), 54 deletions(-)
diffs (159 lines):
diff -r a7f89342351b -r a78896335c14 sys/dev/hdaudio/hdafg.c
--- a/sys/dev/hdaudio/hdafg.c Sun Apr 21 05:11:21 2019 +0000
+++ b/sys/dev/hdaudio/hdafg.c Sun Apr 21 05:22:57 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: hdafg.c,v 1.16 2018/09/27 01:18:11 manu Exp $ */
+/* $NetBSD: hdafg.c,v 1.16.2.1 2019/04/21 05:22:57 isaki Exp $ */
/*
* Copyright (c) 2009 Precedence Technologies Ltd <support%precedence.co.uk@localhost>
@@ -60,7 +60,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: hdafg.c,v 1.16 2018/09/27 01:18:11 manu Exp $");
+__KERNEL_RCSID(0, "$NetBSD: hdafg.c,v 1.16.2.1 2019/04/21 05:22:57 isaki Exp $");
#include <sys/types.h>
#include <sys/param.h>
@@ -357,7 +357,7 @@
hdafg_childdet
);
-static int hdafg_query_encoding(void *, struct audio_encoding *);
+static int hdafg_query_format(void *, audio_format_query_t *);
static int hdafg_set_params(void *, int, int,
audio_params_t *,
audio_params_t *,
@@ -374,8 +374,6 @@
static void * hdafg_allocm(void *, int, size_t);
static void hdafg_freem(void *, void *, size_t);
static int hdafg_getdev(void *, struct audio_device *);
-static size_t hdafg_round_buffersize(void *, int, size_t);
-static paddr_t hdafg_mappage(void *, void *, off_t, int);
static int hdafg_get_props(void *);
static int hdafg_trigger_output(void *, void *, void *, int,
void (*)(void *), void *,
@@ -386,7 +384,7 @@
static void hdafg_get_locks(void *, kmutex_t **, kmutex_t **);
static const struct audio_hw_if hdafg_hw_if = {
- .query_encoding = hdafg_query_encoding,
+ .query_format = hdafg_query_format,
.set_params = hdafg_set_params,
.round_blocksize = hdafg_round_blocksize,
.commit_settings = hdafg_commit_settings,
@@ -398,8 +396,6 @@
.query_devinfo = hdafg_query_devinfo,
.allocm = hdafg_allocm,
.freem = hdafg_freem,
- .round_buffersize = hdafg_round_buffersize,
- .mappage = hdafg_mappage,
.get_props = hdafg_get_props,
.trigger_output = hdafg_trigger_output,
.trigger_input = hdafg_trigger_input,
@@ -3380,6 +3376,9 @@
if (hdafg_rate_supported(sc, rate))
f.frequency[f.frequency_type++] = rate;
}
+ /* XXX ad hoc.. */
+ if (encoding == AUDIO_ENCODING_AC3)
+ f.priority = -1;
#define HDAUDIO_INITFMT(ch, chmask) \
do { \
@@ -3920,10 +3919,11 @@
}
static int
-hdafg_query_encoding(void *opaque, struct audio_encoding *ae)
+hdafg_query_format(void *opaque, audio_format_query_t *afp)
{
struct hdaudio_audiodev *ad = opaque;
- return auconv_query_encoding(ad->ad_encodings, ae);
+
+ return audio_query_format(ad->ad_formats, ad->ad_nformats, afp);
}
static int
@@ -3961,7 +3961,7 @@
{
struct hdaudio_audiodev *ad = opaque;
struct hdaudio_stream *st;
- int bufsize, nblksize;
+ int bufsize;
st = (mode == AUMODE_PLAY) ? ad->ad_playback : ad->ad_capture;
if (st == NULL) {
@@ -3970,24 +3970,21 @@
return 128;
}
- if (blksize > 8192)
- blksize = 8192;
- else if (blksize < 0)
- blksize = 128;
-
- /* HD audio wants a multiple of 128, and OSS wants a power of 2 */
- for (nblksize = 128; nblksize < blksize; nblksize <<= 1)
- ;
+ /*
+ * HD audio's buffer constraint looks like following:
+ * - The buffer MUST start on a 128bytes boundary.
+ * - The buffer size MUST be one sample or more.
+ * - The buffer size is preferred multiple of 128bytes for efficiency.
+ *
+ * https://www.intel.co.jp/content/www/jp/ja/standards/high-definition-audio-specification.html , p70.
+ */
/* Make sure there are enough BDL descriptors */
bufsize = st->st_data.dma_size;
- if (bufsize > HDAUDIO_BDL_MAX * nblksize) {
+ if (bufsize > HDAUDIO_BDL_MAX * blksize) {
blksize = bufsize / HDAUDIO_BDL_MAX;
- for (nblksize = 128; nblksize < blksize; nblksize <<= 1)
- ;
}
-
- return nblksize;
+ return blksize;
}
static int
@@ -4230,36 +4227,6 @@
hdaudio_dma_free(st->st_host, &st->st_data);
}
-static size_t
-hdafg_round_buffersize(void *opaque, int direction, size_t bufsize)
-{
- /* Multiple of 128 */
- bufsize &= ~127;
- if (bufsize <= 0)
- bufsize = 128;
- return bufsize;
-}
-
-static paddr_t
-hdafg_mappage(void *opaque, void *addr, off_t off, int prot)
-{
- struct hdaudio_audiodev *ad = opaque;
- struct hdaudio_stream *st;
-
- if (addr == DMA_KERNADDR(&ad->ad_playback->st_data))
- st = ad->ad_playback;
- else if (addr == DMA_KERNADDR(&ad->ad_capture->st_data))
- st = ad->ad_capture;
- else
- return -1;
-
- if (st->st_data.dma_valid == false)
- return -1;
-
- return bus_dmamem_mmap(st->st_host->sc_dmat, st->st_data.dma_segs,
- st->st_data.dma_nsegs, off, prot, BUS_DMA_WAITOK);
-}
-
static int
hdafg_get_props(void *opaque)
{
Home |
Main Index |
Thread Index |
Old Index