Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src Improved mixing function - more expensive in cycles though.



details:   https://anonhg.NetBSD.org/src/rev/e41767e7eee3
branches:  trunk
changeset: 353028:e41767e7eee3
user:      nat <nat%NetBSD.org@localhost>
date:      Mon Apr 17 22:40:06 2017 +0000

description:
Improved mixing function - more expensive in cycles though.
hw.driverN.saturate is no longer needed and has been removed.

Mixing function thanks to jmcneill@.

diffstat:

 share/man/man4/audio.4 |  17 +--------
 sys/dev/audio.c        |  96 ++++++++-----------------------------------------
 sys/dev/audiovar.h     |   3 +-
 3 files changed, 19 insertions(+), 97 deletions(-)

diffs (226 lines):

diff -r 4b5b55c4d63e -r e41767e7eee3 share/man/man4/audio.4
--- a/share/man/man4/audio.4    Mon Apr 17 20:17:08 2017 +0000
+++ b/share/man/man4/audio.4    Mon Apr 17 22:40:06 2017 +0000
@@ -1,4 +1,4 @@
-.\"    $NetBSD: audio.4,v 1.77 2017/04/17 20:17:08 nat Exp $
+.\"    $NetBSD: audio.4,v 1.78 2017/04/17 22:40:06 nat Exp $
 .\"
 .\" Copyright (c) 1996 The NetBSD Foundation, Inc.
 .\" All rights reserved.
@@ -112,7 +112,6 @@
 .It hw.driverN.precision
 .It hw.driverN.frequency
 .It hw.driverN.channels
-.It hw.driverN.saturate
 .It hw.driverN.multiuser
 .El
 .Pp
@@ -127,20 +126,6 @@
 .Pp
 An additional
 .Xr sysctl 8
-variable controls how the samples are combined, hw.driverN.saturate.
-.Pp
-By default is set to 16.
-This means that volumes are not adjusted for the first 16 channels to be mixed.
-All virtual channels will use the
-.Em maximum
-set master volume unless the virtual channel volume is lowered by the user.
-.Pp
-If a greater number of channels are opened all channels are
-.Em divided
-evenly in volume with respect to the master volume.
-.Pp
-An additional
-.Xr sysctl 8
 variable determines if multiple users are allowed to access the sampling
 device, hw.driverN.multiuser.
 .Pp
diff -r 4b5b55c4d63e -r e41767e7eee3 sys/dev/audio.c
--- a/sys/dev/audio.c   Mon Apr 17 20:17:08 2017 +0000
+++ b/sys/dev/audio.c   Mon Apr 17 22:40:06 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: audio.c,v 1.325 2017/04/17 20:17:08 nat Exp $  */
+/*     $NetBSD: audio.c,v 1.326 2017/04/17 22:40:06 nat Exp $  */
 
 /*-
  * Copyright (c) 2016 Nathanial Sloss <nathanialsloss%yahoo.com.au@localhost>
@@ -148,7 +148,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: audio.c,v 1.325 2017/04/17 20:17:08 nat Exp $");
+__KERNEL_RCSID(0, "$NetBSD: audio.c,v 1.326 2017/04/17 22:40:06 nat Exp $");
 
 #include "audio.h"
 #if NAUDIO > 0
@@ -257,7 +257,6 @@
 void   audio_rec_thread(void *);
 void   recswvol_func(struct audio_softc *, struct audio_ringbuffer *,
                      size_t, struct virtual_channel *);
-void   saturate_func(struct audio_softc *);
 void   mix_func(struct audio_softc *, struct audio_ringbuffer *,
                 struct virtual_channel *);
 void   mix_write(void *);
@@ -641,7 +640,6 @@
        }
 
        sc->sc_lastgain = 128;
-       sc->sc_saturate = 16;
        sc->sc_multiuser = false;
        mutex_exit(sc->sc_lock);
 
@@ -837,15 +835,6 @@
 
                sysctl_createv(&sc->sc_log, 0, NULL, NULL,
                        CTLFLAG_READWRITE,
-                       CTLTYPE_INT, "saturate",
-                       SYSCTL_DESCR("saturate to max. volume this many channels"),
-                       NULL, 0,
-                       &sc->sc_saturate, 0,
-                       CTL_HW, node->sysctl_num,
-                       CTL_CREATE, CTL_EOL);
-
-               sysctl_createv(&sc->sc_log, 0, NULL, NULL,
-                       CTLFLAG_READWRITE,
                        CTLTYPE_BOOL, "multiuser",
                        SYSCTL_DESCR("allow multiple user acess"),
                        NULL, 0,
@@ -3786,8 +3775,6 @@
                                sc->schedule_rih = true;
        }
        mutex_enter(sc->sc_intr_lock);
-       if (sc->sc_opens < sc->sc_saturate && sc->sc_opens > 1)
-               saturate_func(sc);
 
        vc = SIMPLEQ_FIRST(&sc->sc_audiochan)->vc;
        cb = &sc->sc_pr;
@@ -5557,12 +5544,14 @@
        }
 }
 
-#define DEF_MIX_FUNC(name, type)                                       \
+#define DEF_MIX_FUNC(name, type, MINVAL, MAXVAL)               \
        static void                                             \
        mix_func##name(struct audio_softc *sc, struct audio_ringbuffer *cb, \
                  struct virtual_channel *vc)                           \
        {                                                               \
                int blksize, cc, cc1, cc2, m, resid;                    \
+               int64_t product;                                        \
+               int64_t result;                                         \
                type *orig, *tomix;                                     \
                                                                        \
                blksize = sc->sc_pr.blksize;                            \
@@ -5581,9 +5570,15 @@
                                cc = cc2;                               \
                                                                        \
                        for (m = 0; m < (cc / (name / 8)); m++) {       \
-                               orig[m] += (type)((int32_t)(tomix[m] *  \
-                                   (vc->sc_swvol + 1)) / (sc->sc_opens * \
-                                   256));                              \
+                               tomix[m] = tomix[m] *                   \
+                                   (int32_t)(vc->sc_swvol) / 255;      \
+                               result = orig[m] + tomix[m];            \
+                               product = orig[m] * tomix[m];           \
+                               if (orig[m] > 0 && tomix[m] > 0)        \
+                                       result -= product / MAXVAL;     \
+                               else if (orig[m] < 0 && tomix[m] < 0)   \
+                                       result -= product / MINVAL;     \
+                               orig[m] = result;                       \
                        }                                               \
                                                                        \
                        if (&orig[m] >= (type *)sc->sc_pr.s.end)        \
@@ -5595,9 +5590,9 @@
                }                                                       \
        }                                                               \
 
-DEF_MIX_FUNC(8, int8_t);
-DEF_MIX_FUNC(16, int16_t);
-DEF_MIX_FUNC(32, int32_t);
+DEF_MIX_FUNC(8, int8_t, INT8_MIN, INT8_MAX);
+DEF_MIX_FUNC(16, int16_t, INT16_MIN, INT16_MAX);
+DEF_MIX_FUNC(32, int32_t, INT32_MIN, INT32_MAX);
 
 void
 mix_func(struct audio_softc *sc, struct audio_ringbuffer *cb,
@@ -5619,63 +5614,6 @@
        }
 }
 
-#define DEF_SATURATE_FUNC(name, type, max_type, min_type)              \
-       static void                                             \
-       saturate_func##name(struct audio_softc *sc)                     \
-       {                                                               \
-               int blksize, m, i, resid;                               \
-               type *orig;                                             \
-                                                                       \
-               blksize = sc->sc_pr.blksize;                            \
-               resid = blksize;                                        \
-               if (sc->sc_trigger_started == false)                    \
-                       resid *= 2;                                     \
-                                                                       \
-               orig = (type *)(sc->sc_pr.s.inp);                       \
-                                                                       \
-               for (m = 0; m < (resid / (name / 8));m++) {             \
-                       i = 0;                                          \
-                       if (&orig[m] >= (type *)sc->sc_pr.s.end) {      \
-                               orig = (type *)sc->sc_pr.s.start;       \
-                               resid -= m;                             \
-                               m = 0;                                  \
-                       }                                               \
-                       if (orig[m] != 0) {                             \
-                               if (orig[m] > 0)                        \
-                                       i = max_type / orig[m];         \
-                               else                                    \
-                                       i = min_type / orig[m];         \
-                       }                                               \
-                       if (i > sc->sc_opens)                           \
-                               i = sc->sc_opens;                       \
-                       orig[m] *= i;                                   \
-               }                                                       \
-       }                                                               \
-
-
-DEF_SATURATE_FUNC(8, int8_t, INT8_MAX, INT8_MIN);
-DEF_SATURATE_FUNC(16, int16_t, INT16_MAX, INT16_MIN);
-DEF_SATURATE_FUNC(32, int32_t, INT32_MAX, INT32_MIN);
-
-void
-saturate_func(struct audio_softc *sc)
-{
-       switch (sc->sc_precision) {
-       case 8:
-               saturate_func8(sc);
-               break;
-       case 16:
-               saturate_func16(sc);
-               break;
-       case 24:
-       case 32:
-               saturate_func32(sc);
-               break;
-       default:
-               break;
-       }
-}
-
 #define DEF_RECSWVOL_FUNC(name, type, bigger_type)                     \
        static void                                             \
        recswvol_func##name(struct audio_softc *sc,                     \
diff -r 4b5b55c4d63e -r e41767e7eee3 sys/dev/audiovar.h
--- a/sys/dev/audiovar.h        Mon Apr 17 20:17:08 2017 +0000
+++ b/sys/dev/audiovar.h        Mon Apr 17 22:40:06 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: audiovar.h,v 1.52 2017/04/17 20:17:08 nat Exp $        */
+/*     $NetBSD: audiovar.h,v 1.53 2017/04/17 22:40:06 nat Exp $        */
 
 /*-
  * Copyright (c) 2002 The NetBSD Foundation, Inc.
@@ -290,7 +290,6 @@
        int             sc_channels;
        int             sc_precision;
        int             sc_iffreq;
-       int             sc_saturate;
        struct audio_info       sc_ai;          /* Recent info for  dev sound */
        bool                    sc_aivalid;
 #define VAUDIO_NFORMATS        1



Home | Main Index | Thread Index | Old Index