Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/audio Fix that audio_open() didn't halt the recordin...
details: https://anonhg.NetBSD.org/src/rev/7caacff77754
branches: trunk
changeset: 978956:7caacff77754
user: isaki <isaki%NetBSD.org@localhost>
date: Wed Dec 09 04:24:08 2020 +0000
description:
Fix that audio_open() didn't halt the recording mixer correctly
if fd_allocfile() failed, since rev 1.65.
Will fix PR kern/55848.
diffstat:
sys/dev/audio/audio.c | 24 +++++++++++++++++-------
1 files changed, 17 insertions(+), 7 deletions(-)
diffs (78 lines):
diff -r 28ca3c6ae76f -r 7caacff77754 sys/dev/audio/audio.c
--- a/sys/dev/audio/audio.c Wed Dec 09 04:02:20 2020 +0000
+++ b/sys/dev/audio/audio.c Wed Dec 09 04:24:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: audio.c,v 1.79 2020/09/07 03:36:11 isaki Exp $ */
+/* $NetBSD: audio.c,v 1.80 2020/12/09 04:24:08 isaki Exp $ */
/*-
* Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -138,7 +138,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: audio.c,v 1.79 2020/09/07 03:36:11 isaki Exp $");
+__KERNEL_RCSID(0, "$NetBSD: audio.c,v 1.80 2020/12/09 04:24:08 isaki Exp $");
#ifdef _KERNEL_OPT
#include "audio.h"
@@ -2082,6 +2082,7 @@
audio_file_t *af;
audio_ring_t *hwbuf;
bool fullduplex;
+ bool rmixer_started;
int fd;
int error;
@@ -2092,6 +2093,8 @@
ISDEVSOUND(dev) ? "sound" : "audio",
flags, sc->sc_popens, sc->sc_ropens);
+ rmixer_started = false;
+
af = kmem_zalloc(sizeof(audio_file_t), KM_SLEEP);
af->sc = sc;
af->dev = dev;
@@ -2282,12 +2285,13 @@
mutex_enter(sc->sc_lock);
audio_rmixer_start(sc);
mutex_exit(sc->sc_lock);
+ rmixer_started = true;
}
if (bellfile == NULL) {
error = fd_allocfile(&fp, &fd);
if (error)
- goto bad3;
+ goto bad4;
}
/*
@@ -2314,10 +2318,12 @@
TRACEF(3, af, "done");
return error;
- /*
- * Since track here is not yet linked to sc_files,
- * you can call track_destroy() without sc_intr_lock.
- */
+bad4:
+ if (rmixer_started) {
+ mutex_enter(sc->sc_lock);
+ audio_rmixer_halt(sc);
+ mutex_exit(sc->sc_lock);
+ }
bad3:
if (sc->sc_popens + sc->sc_ropens == 0) {
if (sc->hw_if->close) {
@@ -2329,6 +2335,10 @@
}
}
bad2:
+ /*
+ * Since track here is not yet linked to sc_files,
+ * you can call track_destroy() without sc_intr_lock.
+ */
if (af->rtrack) {
audio_track_destroy(af->rtrack);
af->rtrack = NULL;
Home |
Main Index |
Thread Index |
Old Index