diff options
author | cg <cg@FreeBSD.org> | 1999-09-04 17:08:30 +0000 |
---|---|---|
committer | cg <cg@FreeBSD.org> | 1999-09-04 17:08:30 +0000 |
commit | ff3dd28ba66e1e2e7a58911d637dd024bb4ce072 (patch) | |
tree | 2b076a5d50f25fc7bf687180451e16f0e5482f2e /sys/dev/sound/pcm/feeder.c | |
parent | 0fdfe1be025ca620e8d9bb323f23dc970f3e0bff (diff) | |
download | FreeBSD-src-ff3dd28ba66e1e2e7a58911d637dd024bb4ce072.zip FreeBSD-src-ff3dd28ba66e1e2e7a58911d637dd024bb4ce072.tar.gz |
handle uiomove better in feed_root
Diffstat (limited to 'sys/dev/sound/pcm/feeder.c')
-rw-r--r-- | sys/dev/sound/pcm/feeder.c | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/sys/dev/sound/pcm/feeder.c b/sys/dev/sound/pcm/feeder.c index 7c6ebeb..f579b29 100644 --- a/sys/dev/sound/pcm/feeder.c +++ b/sys/dev/sound/pcm/feeder.c @@ -108,12 +108,15 @@ static unsigned char u8_to_ulaw[] = { static int feed_root(pcm_feeder *feeder, u_int8_t *buffer, u_int32_t count, struct uio *stream) { - int ret, tmp; + int ret, tmp = 0, c = 0; if (!count) panic("feed_root: count == 0"); - tmp = stream->uio_resid; - ret = uiomove(buffer, count, stream); - if (ret) panic("feed_root: uiomove failed"); - tmp -= stream->uio_resid; + while ((stream->uio_resid > 0) && (c < count)) { + tmp = stream->uio_resid; + ret = uiomove(buffer + c, count - c, stream); + if (ret) panic("feed_root: uiomove failed"); + tmp -= stream->uio_resid; + c += tmp; + } if (!tmp) panic("feed_root: uiomove didn't"); return tmp; } @@ -232,7 +235,7 @@ feed_endian(pcm_feeder *f, u_int8_t *b, u_int32_t count, struct uio *stream) b[i + 1] = t; i += 2; } - return count; + return i; } static pcm_feeder feeder_endian = { "endian", NULL, NULL, feed_endian }; |