[FFmpeg-cvslog] avcodec/siren: don't reduce getbitcontext size by checksum_bits at initialisation
Peter Ross
git at videolan.org
Tue Sep 28 14:39:50 EEST 2021
ffmpeg | branch: master | Peter Ross <pross at xvid.org> | Sat Sep 18 19:55:22 2021 +1000| [e40593c0505a3ee143b8ac949af1bb70becafb21] | committer: Peter Ross
avcodec/siren: don't reduce getbitcontext size by checksum_bits at initialisation
this allows the checksum calculation routine to also use getbitcontext
Signed-off-by: Peter Ross <pross at xvid.org>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=e40593c0505a3ee143b8ac949af1bb70becafb21
---
libavcodec/siren.c | 16 ++++++++--------
1 file changed, 8 insertions(+), 8 deletions(-)
diff --git a/libavcodec/siren.c b/libavcodec/siren.c
index 27ee356c44..0ecf0fcafc 100644
--- a/libavcodec/siren.c
+++ b/libavcodec/siren.c
@@ -594,7 +594,7 @@ static int decode_vector(SirenContext *s, int number_of_regions,
for (i = 0; i < number_of_vectors[category]; i++) {
index = 0;
do {
- if (get_bits_left(gb) <= 0) {
+ if (get_bits_left(gb) - s->checksum_bits <= 0) {
error = 1;
break;
}
@@ -614,7 +614,7 @@ static int decode_vector(SirenContext *s, int number_of_regions,
index >>= index_table[category];
if (decoded_value) {
- if (get_bits_left(gb) <= 0) {
+ if (get_bits_left(gb) - s->checksum_bits <= 0) {
error = 1;
break;
}
@@ -697,7 +697,7 @@ static int decode_vector(SirenContext *s, int number_of_regions,
}
}
- return error == 1 ? AVERROR_INVALIDDATA : get_bits_left(gb);
+ return error == 1 ? AVERROR_INVALIDDATA : (get_bits_left(gb) - s->checksum_bits);
}
static int siren_decode(AVCodecContext *avctx, void *data,
@@ -716,7 +716,7 @@ static int siren_decode(AVCodecContext *avctx, void *data,
if (avpkt->size < bits_per_frame / 8)
return AVERROR_INVALIDDATA;
- if ((ret = init_get_bits(gb, avpkt->data, bits_per_frame - s->checksum_bits)) < 0)
+ if ((ret = init_get_bits(gb, avpkt->data, bits_per_frame)) < 0)
return ret;
} else
if ((ret = init_get_bits8(gb, avpkt->data, avpkt->size)) < 0)
@@ -730,7 +730,7 @@ static int siren_decode(AVCodecContext *avctx, void *data,
rate_control = get_bits(gb, 4);
- ret = categorize_regions(s->number_of_regions, get_bits_left(gb),
+ ret = categorize_regions(s->number_of_regions, get_bits_left(gb) - s->checksum_bits,
s->absolute_region_power_index, s->power_categories,
s->category_balance);
if (ret < 0)
@@ -745,11 +745,11 @@ static int siren_decode(AVCodecContext *avctx, void *data,
if (ret < 0 && !s->microsoft)
return ret;
- if (get_bits_left(gb) > 0) {
+ if (get_bits_left(gb) - s->checksum_bits > 0) {
do {
frame_error |= !get_bits1(gb);
- } while (get_bits_left(gb) > 0);
- } else if (get_bits_left(gb) < 0 &&
+ } while (get_bits_left(gb) - s->checksum_bits > 0);
+ } else if (get_bits_left(gb) - s->checksum_bits < 0 &&
rate_control + 1 < s->rate_control_possibilities) {
frame_error = 1;
}
More information about the ffmpeg-cvslog
mailing list