aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSascha Sommer <saschasommer@freenet.de>2011-09-24 20:56:41 +0200
committerMichael Niedermayer <michaelni@gmx.at>2011-09-27 03:06:04 +0200
commit9960710b872e2d1c7d9d8730c4b6ca2c2cdf183e (patch)
tree3e4020cbbb09cd8e81dd2190936df9b7a468182c
parentb00fc80d406fef0acd54619a7c82e2a31e00c06c (diff)
downloadffmpeg-9960710b872e2d1c7d9d8730c4b6ca2c2cdf183e.tar.gz
Fix segfault in save_bits:
use put_bits_count to get the buffer fill state instead of num_saved_bits as num_saved_bits is sometimes reset when frames are lost (Ticket 495) (cherry picked from commit 780d45473c32fa356c8ce385c3ea4692567c3228) Signed-off-by: Michael Niedermayer <michaelni@gmx.at> (cherry picked from commit 4f6187c7356111540024901932294e9807061dd0)
-rw-r--r--libavcodec/wmaprodec.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/libavcodec/wmaprodec.c b/libavcodec/wmaprodec.c
index e1d942dca2..b0b98f1d98 100644
--- a/libavcodec/wmaprodec.c
+++ b/libavcodec/wmaprodec.c
@@ -1436,7 +1436,7 @@ static void save_bits(WMAProDecodeCtx *s, GetBitContext* gb, int len,
init_put_bits(&s->pb, s->frame_data, MAX_FRAMESIZE);
}
- buflen = (s->num_saved_bits + len + 8) >> 3;
+ buflen = (put_bits_count(&s->pb) + len + 8) >> 3;
if (len <= 0 || buflen > MAX_FRAMESIZE) {
av_log_ask_for_sample(s->avctx, "input buffer too small\n");