Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/audio Put the lowered mixing volume back when all pl...
details:   https://anonhg.NetBSD.org/src/rev/d11ee35886be
branches:  trunk
changeset: 457441:d11ee35886be
user:      isaki <isaki%NetBSD.org@localhost>
date:      Tue Jun 25 13:07:48 2019 +0000
description:
Put the lowered mixing volume back when all playback tracks are closed.
TODO: about long life descriptor.
diffstat:
 sys/dev/audio/audio.c    |  55 +++++++++--------------------------------------
 sys/dev/audio/audiodef.h |   8 +++++-
 2 files changed, 17 insertions(+), 46 deletions(-)
diffs (126 lines):
diff -r bf4b582c6a33 -r d11ee35886be sys/dev/audio/audio.c
--- a/sys/dev/audio/audio.c     Tue Jun 25 12:30:50 2019 +0000
+++ b/sys/dev/audio/audio.c     Tue Jun 25 13:07:48 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: audio.c,v 1.19 2019/06/23 01:46:56 isaki Exp $ */
+/*     $NetBSD: audio.c,v 1.20 2019/06/25 13:07:48 isaki Exp $ */
 
 /*-
  * Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -142,7 +142,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: audio.c,v 1.19 2019/06/23 01:46:56 isaki Exp $");
+__KERNEL_RCSID(0, "$NetBSD: audio.c,v 1.20 2019/06/25 13:07:48 isaki Exp $");
 
 #ifdef _KERNEL_OPT
 #include "audio.h"
@@ -587,7 +587,6 @@
 static int audio_mixers_set_format(struct audio_softc *,
        const struct audio_info *);
 static void audio_mixers_get_format(struct audio_softc *, struct audio_info *);
-static int audio_sysctl_volume(SYSCTLFN_PROTO);
 static int audio_sysctl_blk_ms(SYSCTLFN_PROTO);
 static int audio_sysctl_multiuser(SYSCTLFN_PROTO);
 #if defined(AUDIO_DEBUG)
@@ -1013,13 +1012,6 @@
        if (node != NULL) {
                sysctl_createv(&sc->sc_log, 0, NULL, NULL,
                    CTLFLAG_READWRITE,
-                   CTLTYPE_INT, "volume",
-                   SYSCTL_DESCR("software volume test"),
-                   audio_sysctl_volume, 0, (void *)sc, 0,
-                   CTL_HW, node->sysctl_num, CTL_CREATE, CTL_EOL);
-
-               sysctl_createv(&sc->sc_log, 0, NULL, NULL,
-                   CTLFLAG_READWRITE,
                    CTLTYPE_INT, "blk_ms",
                    SYSCTL_DESCR("blocksize in msec"),
                    audio_sysctl_blk_ms, 0, (void *)sc, 0,
@@ -2159,6 +2151,13 @@
 
                KASSERT(sc->sc_popens > 0);
                sc->sc_popens--;
+
+               /* Restore mixing volume if all tracks are gone. */
+               if (sc->sc_popens == 0) {
+                       mutex_enter(sc->sc_intr_lock);
+                       sc->sc_pmixer->volume = 256;
+                       mutex_exit(sc->sc_intr_lock);
+               }
        }
        if (file->rtrack) {
                /* Call hw halt_input if this is the last recording track. */
@@ -5016,8 +5015,8 @@
                                if (mixer->volume > 128) {
                                        mixer->volume =
                                            (mixer->volume * 95) / 100;
-                                       device_printf(sc->sc_dev,
-                                           "auto volume adjust: volume %d\n",
+                                       TRACE(2,
+                                           "auto volume adjust: volume %d",
                                            mixer->volume);
                                }
                        }
@@ -7266,38 +7265,6 @@
 }
 
 /*
- * Get or set software master volume: 0..256
- * XXX It's for debug.
- */
-static int
-audio_sysctl_volume(SYSCTLFN_ARGS)
-{
-       struct sysctlnode node;
-       struct audio_softc *sc;
-       int t, error;
-
-       node = *rnode;
-       sc = node.sysctl_data;
-
-       if (sc->sc_pmixer)
-               t = sc->sc_pmixer->volume;
-       else
-               t = -1;
-       node.sysctl_data = &t;
-       error = sysctl_lookup(SYSCTLFN_CALL(&node));
-       if (error || newp == NULL)
-               return error;
-
-       if (sc->sc_pmixer == NULL)
-               return EINVAL;
-       if (t < 0)
-               return EINVAL;
-
-       sc->sc_pmixer->volume = t;
-       return 0;
-}
-
-/*
  * Get or set hardware blocksize in msec.
  * XXX It's for debug.
  */
diff -r bf4b582c6a33 -r d11ee35886be sys/dev/audio/audiodef.h
--- a/sys/dev/audio/audiodef.h  Tue Jun 25 12:30:50 2019 +0000
+++ b/sys/dev/audio/audiodef.h  Tue Jun 25 13:07:48 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: audiodef.h,v 1.4 2019/06/10 13:49:39 isaki Exp $       */
+/*     $NetBSD: audiodef.h,v 1.5 2019/06/25 13:07:48 isaki Exp $       */
 
 /*
  * Copyright (C) 2017 Tetsuya Isaki. All rights reserved.
@@ -187,7 +187,11 @@
 
        int             frames_per_block; /* number of frames in a block */
 
-       u_int           volume;         /* software master volume (0..256) */
+       /*
+        * software master volume (0..256)
+        * Must be protected by sc_intr_lock.
+        */
+       u_int           volume;
 
        audio_format2_t mixfmt;
        void            *mixsample;     /* mixing buf in double-sized int */
Home |
Main Index |
Thread Index |
Old Index