summaryrefslogtreecommitdiffstats
path: root/libmpcodecs/ad_pcm.c
diff options
context:
space:
mode:
authoruau <uau@b3059339-0415-0410-9bf9-f77b7e298cf2>2006-08-13 23:09:17 +0000
committeruau <uau@b3059339-0415-0410-9bf9-f77b7e298cf2>2006-08-13 23:09:17 +0000
commite9b1adff1747fb16d6a0806861f491cfb4254ea9 (patch)
tree0c8df591f3cce48e4c09827f38f9a81542e7b8cc /libmpcodecs/ad_pcm.c
parentd067742bb21e44c010e08bd6da674198e6d58078 (diff)
downloadmpv-e9b1adff1747fb16d6a0806861f491cfb4254ea9.tar.bz2
mpv-e9b1adff1747fb16d6a0806861f491cfb4254ea9.tar.xz
Change pcm decode_audio to return data based on minlen instead of maxlen
to avoid demuxing unnecessarily much at once. git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@19389 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpcodecs/ad_pcm.c')
-rw-r--r--libmpcodecs/ad_pcm.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/libmpcodecs/ad_pcm.c b/libmpcodecs/ad_pcm.c
index db2670cf1b..e9cbadcaef 100644
--- a/libmpcodecs/ad_pcm.c
+++ b/libmpcodecs/ad_pcm.c
@@ -120,7 +120,11 @@ static int control(sh_audio_t *sh,int cmd,void* arg, ...)
static int decode_audio(sh_audio_t *sh_audio,unsigned char *buf,int minlen,int maxlen)
{
unsigned len = sh_audio->channels*sh_audio->samplesize;
- len = maxlen - maxlen % len; // sample align
+ len = (minlen + len - 1) / len * len;
+ if (len > maxlen)
+ // if someone needs hundreds of channels adjust audio_out_minsize
+ // based on channels in preinit()
+ return -1;
len=demux_read_data(sh_audio->ds,buf,len);
return len;
}