Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/audio Don't wait until a block is filled.
details: https://anonhg.NetBSD.org/src/rev/65333d5d5f6c
branches: trunk
changeset: 999808:65333d5d5f6c
user: isaki <isaki%NetBSD.org@localhost>
date: Wed Jun 19 12:49:49 2019 +0000
description:
Don't wait until a block is filled.
This improves that short sound breaks.
diffstat:
sys/dev/audio/audio.c | 23 +++--------------------
1 files changed, 3 insertions(+), 20 deletions(-)
diffs (65 lines):
diff -r baa1adca864e -r 65333d5d5f6c sys/dev/audio/audio.c
--- a/sys/dev/audio/audio.c Wed Jun 19 10:04:40 2019 +0000
+++ b/sys/dev/audio/audio.c Wed Jun 19 12:49:49 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: audio.c,v 1.17 2019/06/12 13:53:25 isaki Exp $ */
+/* $NetBSD: audio.c,v 1.18 2019/06/19 12:49:49 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.17 2019/06/12 13:53:25 isaki Exp $");
+__KERNEL_RCSID(0, "$NetBSD: audio.c,v 1.18 2019/06/19 12:49:49 isaki Exp $");
#ifdef _KERNEL_OPT
#include "audio.h"
@@ -4296,7 +4296,6 @@
int count;
int framesize;
int bytes;
- u_int dropcount;
KASSERT(track);
KASSERT(track->lock);
@@ -4315,7 +4314,6 @@
usrbuf = &track->usrbuf;
input = track->input;
- dropcount = 0;
/*
* framesize is always 1 byte or more since all formats supported as
@@ -4336,21 +4334,6 @@
count = uimin(usrbuf->used, track->usrbuf_blksize) / framesize;
bytes = count * framesize;
- /*
- * If bytes is less than one block,
- * if not draining, buffer is not filled so return.
- * if draining, fall through.
- */
- if (count < track->usrbuf_blksize / framesize) {
- dropcount = track->usrbuf_blksize / framesize - count;
-
- if (track->pstate != AUDIO_STATE_DRAINING) {
- /* Wait until filled. */
- TRACET(4, track, "not enough; return");
- return;
- }
- }
-
track->usrbuf_stamp += bytes;
if (usrbuf->head + bytes < usrbuf->capacity) {
@@ -4412,7 +4395,7 @@
}
}
- if (dropcount != 0) {
+ if (bytes < track->usrbuf_blksize) {
/*
* Clear all conversion buffer pointer if the conversion was
* not exactly one block. These conversion stage buffers are
Home |
Main Index |
Thread Index |
Old Index