Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev Rate conversion works at 8 bits, so enable it.
details: https://anonhg.NetBSD.org/src/rev/7b1dfd18a1f6
branches: trunk
changeset: 354528:7b1dfd18a1f6
user: nat <nat%NetBSD.org@localhost>
date: Tue Jun 20 07:13:09 2017 +0000
description:
Rate conversion works at 8 bits, so enable it.
Ok christos@.
diffstat:
sys/dev/aurateconv.c | 15 +++++++++++----
1 files changed, 11 insertions(+), 4 deletions(-)
diffs (57 lines):
diff -r 28a1f82d2c7f -r 7b1dfd18a1f6 sys/dev/aurateconv.c
--- a/sys/dev/aurateconv.c Tue Jun 20 01:17:13 2017 +0000
+++ b/sys/dev/aurateconv.c Tue Jun 20 07:13:09 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: aurateconv.c,v 1.19 2011/11/23 23:07:31 jmcneill Exp $ */
+/* $NetBSD: aurateconv.c,v 1.20 2017/06/20 07:13:09 nat Exp $ */
/*-
* Copyright (c) 2002 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: aurateconv.c,v 1.19 2011/11/23 23:07:31 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: aurateconv.c,v 1.20 2017/06/20 07:13:09 nat Exp $");
#include <sys/systm.h>
#include <sys/types.h>
@@ -68,6 +68,8 @@
static int aurateconv_fetch_to(struct audio_softc *, stream_fetcher_t *,
audio_stream_t *, int);
static void aurateconv_dtor(stream_filter_t *);
+static int aurateconv_slinear8_LE(aurateconv_t *, audio_stream_t *,
+ int, int, int);
static int aurateconv_slinear16_LE(aurateconv_t *, audio_stream_t *,
int, int, int);
static int aurateconv_slinear24_LE(aurateconv_t *, audio_stream_t *,
@@ -118,8 +120,9 @@
}
if ((from->encoding != AUDIO_ENCODING_SLINEAR_LE
&& from->encoding != AUDIO_ENCODING_SLINEAR_BE)
- || (from->precision != 16 && from->precision != 24 && from->precision != 32)) {
- printf("%s: encoding/precision must be SLINEAR_LE 16/24/32bit, "
+ || (from->precision != 8 && from->precision != 16 &&
+ from->precision != 24 && from->precision != 32)) {
+ printf("%s: encoding/precision must be SLINEAR_LE 8/16/24/32bit, "
"or SLINEAR_BE 16/24/32bit", __func__);
return NULL;
}
@@ -189,6 +192,9 @@
switch (this->from.encoding) {
case AUDIO_ENCODING_SLINEAR_LE:
switch (this->from.precision) {
+ case 8:
+ return aurateconv_slinear8_LE(this, dst, m,
+ frame_src, frame_dst);
case 16:
return aurateconv_slinear16_LE(this, dst, m,
frame_src, frame_dst);
@@ -458,6 +464,7 @@
return 0; \
}
+AURATECONV_SLINEAR(8, LE)
AURATECONV_SLINEAR(16, LE)
AURATECONV_SLINEAR(24, LE)
AURATECONV_SLINEAR32(LE)
Home |
Main Index |
Thread Index |
Old Index