From 6888db2820dfcf260a1269b5bad4cd55fd189bf5 Mon Sep 17 00:00:00 2001 From: cinap_lenrek Date: Sun, 3 Jul 2011 06:33:13 +0200 Subject: [PATCH] audio: fill up last buffer with silence on close --- sys/src/9/pc/audioac97.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/sys/src/9/pc/audioac97.c b/sys/src/9/pc/audioac97.c index 193d31e8a..e0732dd6b 100644 --- a/sys/src/9/pc/audioac97.c +++ b/sys/src/9/pc/audioac97.c @@ -326,6 +326,20 @@ ac97write(Audio *adev, void *vp, long n, vlong) return p - (uchar*)vp; } +static void +ac97close(Audio *adev) +{ + Ctlr *ctlr; + Ring *ring; + uchar z[1]; + + z[0] = 0; + ctlr = adev->ctlr; + ring = &ctlr->outring; + while(ring->wi % Blocksize) + ac97write(adev, z, sizeof(z), 0); +} + static Pcidev* ac97match(Pcidev *p) { @@ -499,6 +513,7 @@ Found: ac97mixreset(adev, ac97mixw, ac97mixr); adev->write = ac97write; + adev->close = ac97close; adev->buffered = ac97buffered; adev->status = ac97status;