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/53cc0fd4b654
branches:  trunk
changeset: 457312:53cc0fd4b654
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 0435b61fd3e2 -r 53cc0fd4b654 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