Correct the logic of ready_for_new_data.
This should be set right after decoder really start to decode frame instead setting at the end. Even decoder does not have a displayable frame to show and return NULL to application, this should be set too. Change-Id: If0313a834bc64e3b0f05a84f4459d444d9eab0d8
This commit is contained in:
parent
00f1cf40ed
commit
e3bf55dedb
@ -232,6 +232,8 @@ int vp9_receive_compressed_data(VP9Decoder *pbi,
|
|||||||
cm->frame_refs[0].buf->corrupted = 1;
|
cm->frame_refs[0].buf->corrupted = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pbi->ready_for_new_data = 0;
|
||||||
|
|
||||||
// Check if the previous frame was a frame without any references to it.
|
// Check if the previous frame was a frame without any references to it.
|
||||||
if (cm->new_fb_idx >= 0 && cm->frame_bufs[cm->new_fb_idx].ref_count == 0)
|
if (cm->new_fb_idx >= 0 && cm->frame_bufs[cm->new_fb_idx].ref_count == 0)
|
||||||
cm->release_fb_cb(cm->cb_priv,
|
cm->release_fb_cb(cm->cb_priv,
|
||||||
@ -279,8 +281,6 @@ int vp9_receive_compressed_data(VP9Decoder *pbi,
|
|||||||
cm->current_video_frame++;
|
cm->current_video_frame++;
|
||||||
}
|
}
|
||||||
|
|
||||||
pbi->ready_for_new_data = 0;
|
|
||||||
|
|
||||||
cm->error.setjmp = 0;
|
cm->error.setjmp = 0;
|
||||||
return retcode;
|
return retcode;
|
||||||
}
|
}
|
||||||
@ -296,12 +296,12 @@ int vp9_get_raw_frame(VP9Decoder *pbi, YV12_BUFFER_CONFIG *sd,
|
|||||||
if (pbi->ready_for_new_data == 1)
|
if (pbi->ready_for_new_data == 1)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
pbi->ready_for_new_data = 1;
|
||||||
|
|
||||||
/* no raw frame to show!!! */
|
/* no raw frame to show!!! */
|
||||||
if (!cm->show_frame)
|
if (!cm->show_frame)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
pbi->ready_for_new_data = 1;
|
|
||||||
|
|
||||||
#if CONFIG_VP9_POSTPROC
|
#if CONFIG_VP9_POSTPROC
|
||||||
if (!cm->show_existing_frame) {
|
if (!cm->show_existing_frame) {
|
||||||
ret = vp9_post_proc_frame(cm, sd, flags);
|
ret = vp9_post_proc_frame(cm, sd, flags);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user