summaryrefslogtreecommitdiff
path: root/libavcodec/cook.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2012-04-21 19:28:35 +0200
committerMichael Niedermayer <michaelni@gmx.at>2012-04-21 19:28:35 +0200
commit5a35bd92ad6b535fd5d3a7513169661de66ec247 (patch)
tree0c55d0bf531bf8205b8576c4e818e4a3142d77d0 /libavcodec/cook.c
parent93bf1aac6ab9874769d347bc9fdd14cb18f063f6 (diff)
cook: check subacket count
Fixes out of array writes. Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/cook.c')
-rw-r--r--libavcodec/cook.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/libavcodec/cook.c b/libavcodec/cook.c
index 4dcb5259db..292148a043 100644
--- a/libavcodec/cook.c
+++ b/libavcodec/cook.c
@@ -1238,6 +1238,11 @@ static av_cold int cook_decode_init(AVCodecContext *avctx)
q->subpacket[s].gains2.now = q->subpacket[s].gain_3;
q->subpacket[s].gains2.previous = q->subpacket[s].gain_4;
+ if (q->num_subpackets + q->subpacket[s].num_channels > q->nb_channels) {
+ av_log(avctx, AV_LOG_ERROR, "Too many subpackets %d for channels %d\n", q->num_subpackets, q->nb_channels);
+ return AVERROR_INVALIDDATA;
+ }
+
q->num_subpackets++;
s++;
if (s > MAX_SUBPACKETS) {