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