mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
dvbsubdec: pass correct input buffer size
In some places, dvbsubdec passes improper input buffer size to bitstream reading functions, not accounting for reading pointer updates. Fixed by using buffer_end - buffer pointer instead of fixed buffer length. Signed-off-by: Jindrich Makovicka <makovick@gmail.com> Signed-off-by: Mans Rullgard <mans@mansr.com>
This commit is contained in:
parent
90e8a9c34f
commit
5bea615dc3
@ -792,7 +792,7 @@ static void dvbsub_parse_pixel_data_block(AVCodecContext *avctx, DVBSubObjectDis
|
||||
map_table = NULL;
|
||||
|
||||
x_pos += dvbsub_read_2bit_string(pbuf + (y_pos * region->width) + x_pos,
|
||||
region->width - x_pos, &buf, buf_size,
|
||||
region->width - x_pos, &buf, buf_end - buf,
|
||||
non_mod, map_table);
|
||||
break;
|
||||
case 0x11:
|
||||
@ -807,7 +807,7 @@ static void dvbsub_parse_pixel_data_block(AVCodecContext *avctx, DVBSubObjectDis
|
||||
map_table = NULL;
|
||||
|
||||
x_pos += dvbsub_read_4bit_string(pbuf + (y_pos * region->width) + x_pos,
|
||||
region->width - x_pos, &buf, buf_size,
|
||||
region->width - x_pos, &buf, buf_end - buf,
|
||||
non_mod, map_table);
|
||||
break;
|
||||
case 0x12:
|
||||
@ -817,7 +817,7 @@ static void dvbsub_parse_pixel_data_block(AVCodecContext *avctx, DVBSubObjectDis
|
||||
}
|
||||
|
||||
x_pos += dvbsub_read_8bit_string(pbuf + (y_pos * region->width) + x_pos,
|
||||
region->width - x_pos, &buf, buf_size,
|
||||
region->width - x_pos, &buf, buf_end - buf,
|
||||
non_mod, NULL);
|
||||
break;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user