Merge "Prevent decoder from using uninitialized entropy context."
This commit is contained in:
commit
b60ae45f36
@ -453,6 +453,7 @@ void vp9_setup_past_independence(VP9_COMMON *cm) {
|
||||
vp9_default_coef_probs(cm);
|
||||
vp9_init_mode_probs(cm->fc);
|
||||
vp9_init_mv_probs(cm);
|
||||
cm->fc->initialized = 1;
|
||||
|
||||
if (cm->frame_type == KEY_FRAME ||
|
||||
cm->error_resilient_mode || cm->reset_frame_context == 3) {
|
||||
|
@ -50,6 +50,7 @@ typedef struct frame_contexts {
|
||||
struct tx_probs tx_probs;
|
||||
vp9_prob skip_probs[SKIP_CONTEXTS];
|
||||
nmv_context nmvc;
|
||||
int initialized;
|
||||
} FRAME_CONTEXT;
|
||||
|
||||
typedef struct {
|
||||
|
@ -1556,6 +1556,10 @@ void vp9_decode_frame(VP9Decoder *pbi,
|
||||
vp9_setup_block_planes(xd, cm->subsampling_x, cm->subsampling_y);
|
||||
|
||||
*cm->fc = cm->frame_contexts[cm->frame_context_idx];
|
||||
if (!cm->fc->initialized)
|
||||
vpx_internal_error(&cm->error, VPX_CODEC_CORRUPT_FRAME,
|
||||
"Uninitialized entropy context.");
|
||||
|
||||
vp9_zero(cm->counts);
|
||||
|
||||
xd->corrupted = 0;
|
||||
|
Loading…
x
Reference in New Issue
Block a user