Merge "Validate encoder buffer writes for single token partition"
This commit is contained in:
commit
640ddcabcc
@ -221,6 +221,11 @@ static void pack_tokens_c(vp8_writer *w, const TOKENEXTRA *p, int xcount)
|
|||||||
w->buffer[x] += 1;
|
w->buffer[x] += 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
validate_buffer(w->buffer + w->pos,
|
||||||
|
1,
|
||||||
|
w->buffer_end,
|
||||||
|
w->error);
|
||||||
|
|
||||||
w->buffer[w->pos++] = (lowvalue >> (24 - offset));
|
w->buffer[w->pos++] = (lowvalue >> (24 - offset));
|
||||||
lowvalue <<= offset;
|
lowvalue <<= offset;
|
||||||
shift = count;
|
shift = count;
|
||||||
@ -281,6 +286,11 @@ static void pack_tokens_c(vp8_writer *w, const TOKENEXTRA *p, int xcount)
|
|||||||
w->buffer[x] += 1;
|
w->buffer[x] += 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
validate_buffer(w->buffer + w->pos,
|
||||||
|
1,
|
||||||
|
w->buffer_end,
|
||||||
|
w->error);
|
||||||
|
|
||||||
w->buffer[w->pos++] = (lowvalue >> (24 - offset));
|
w->buffer[w->pos++] = (lowvalue >> (24 - offset));
|
||||||
lowvalue <<= offset;
|
lowvalue <<= offset;
|
||||||
shift = count;
|
shift = count;
|
||||||
@ -329,6 +339,12 @@ static void pack_tokens_c(vp8_writer *w, const TOKENEXTRA *p, int xcount)
|
|||||||
if (!++count)
|
if (!++count)
|
||||||
{
|
{
|
||||||
count = -8;
|
count = -8;
|
||||||
|
|
||||||
|
validate_buffer(w->buffer + w->pos,
|
||||||
|
1,
|
||||||
|
w->buffer_end,
|
||||||
|
w->error);
|
||||||
|
|
||||||
w->buffer[w->pos++] = (lowvalue >> 24);
|
w->buffer[w->pos++] = (lowvalue >> 24);
|
||||||
lowvalue &= 0xffffff;
|
lowvalue &= 0xffffff;
|
||||||
}
|
}
|
||||||
@ -664,6 +680,11 @@ static void pack_mb_row_tokens_c(VP8_COMP *cpi, vp8_writer *w)
|
|||||||
w->buffer[x] += 1;
|
w->buffer[x] += 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
validate_buffer(w->buffer + w->pos,
|
||||||
|
1,
|
||||||
|
w->buffer_end,
|
||||||
|
w->error);
|
||||||
|
|
||||||
w->buffer[w->pos++] = (lowvalue >> (24 - offset));
|
w->buffer[w->pos++] = (lowvalue >> (24 - offset));
|
||||||
lowvalue <<= offset;
|
lowvalue <<= offset;
|
||||||
shift = count;
|
shift = count;
|
||||||
@ -724,6 +745,11 @@ static void pack_mb_row_tokens_c(VP8_COMP *cpi, vp8_writer *w)
|
|||||||
w->buffer[x] += 1;
|
w->buffer[x] += 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
validate_buffer(w->buffer + w->pos,
|
||||||
|
1,
|
||||||
|
w->buffer_end,
|
||||||
|
w->error);
|
||||||
|
|
||||||
w->buffer[w->pos++] = (lowvalue >> (24 - offset));
|
w->buffer[w->pos++] = (lowvalue >> (24 - offset));
|
||||||
lowvalue <<= offset;
|
lowvalue <<= offset;
|
||||||
shift = count;
|
shift = count;
|
||||||
@ -770,6 +796,12 @@ static void pack_mb_row_tokens_c(VP8_COMP *cpi, vp8_writer *w)
|
|||||||
if (!++count)
|
if (!++count)
|
||||||
{
|
{
|
||||||
count = -8;
|
count = -8;
|
||||||
|
|
||||||
|
validate_buffer(w->buffer + w->pos,
|
||||||
|
1,
|
||||||
|
w->buffer_end,
|
||||||
|
w->error);
|
||||||
|
|
||||||
w->buffer[w->pos++] = (lowvalue >> 24);
|
w->buffer[w->pos++] = (lowvalue >> 24);
|
||||||
lowvalue &= 0xffffff;
|
lowvalue &= 0xffffff;
|
||||||
}
|
}
|
||||||
@ -1566,6 +1598,9 @@ void vp8_pack_bitstream(VP8_COMP *cpi, unsigned char *dest, unsigned char * dest
|
|||||||
|
|
||||||
mb_feature_data_bits = vp8_mb_feature_data_bits;
|
mb_feature_data_bits = vp8_mb_feature_data_bits;
|
||||||
|
|
||||||
|
cpi->bc.error = &pc->error;
|
||||||
|
cpi->bc2.error = &pc->error;
|
||||||
|
|
||||||
validate_buffer(cx_data, 3, cx_data_end, &cpi->common.error);
|
validate_buffer(cx_data, 3, cx_data_end, &cpi->common.error);
|
||||||
cx_data += 3;
|
cx_data += 3;
|
||||||
|
|
||||||
|
@ -4940,7 +4940,7 @@ int vp8_get_compressed_data(VP8_PTR ptr, unsigned int *frame_flags, unsigned lon
|
|||||||
int64_t store_reg[8];
|
int64_t store_reg[8];
|
||||||
#endif
|
#endif
|
||||||
VP8_COMP *cpi = (VP8_COMP *) ptr;
|
VP8_COMP *cpi = (VP8_COMP *) ptr;
|
||||||
VP8_COMMON *cm = &cpi->common;
|
VP8_COMMON *cm;
|
||||||
struct vpx_usec_timer tsctimer;
|
struct vpx_usec_timer tsctimer;
|
||||||
struct vpx_usec_timer ticktimer;
|
struct vpx_usec_timer ticktimer;
|
||||||
struct vpx_usec_timer cmptimer;
|
struct vpx_usec_timer cmptimer;
|
||||||
@ -4949,12 +4949,14 @@ int vp8_get_compressed_data(VP8_PTR ptr, unsigned int *frame_flags, unsigned lon
|
|||||||
if (!cpi)
|
if (!cpi)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (setjmp(cpi->common.error.jmp)){
|
cm = &cpi->common;
|
||||||
|
|
||||||
|
if (setjmp(cpi->common.error.jmp))
|
||||||
|
{
|
||||||
cpi->common.error.setjmp = 0;
|
cpi->common.error.setjmp = 0;
|
||||||
return VPX_CODEC_CORRUPT_FRAME;
|
return VPX_CODEC_CORRUPT_FRAME;
|
||||||
}
|
}
|
||||||
|
|
||||||
cpi->bc.error = &cpi->common.error;
|
|
||||||
cpi->common.error.setjmp = 1;
|
cpi->common.error.setjmp = 1;
|
||||||
|
|
||||||
#if HAVE_ARMV7
|
#if HAVE_ARMV7
|
||||||
|
Loading…
x
Reference in New Issue
Block a user