codecs: h264picture: Count only complete complementary field pair for dpb fullness decision

Our DPB implementation was designed as such that allowing
temporary DPB overflow in the middle of field picture decoding
and incomplete field pair should not trigger DPB bumping.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/-/merge_requests/1947>
This commit is contained in:
Seungha Yang 2021-01-10 23:16:55 +09:00
parent e14bbd7f5c
commit ae7c20a6ed

View file

@ -596,7 +596,7 @@ gst_h264_dpb_has_empty_frame_buffer (GstH264Dpb * dpb)
} else { } else {
gint i; gint i;
gint count = 0; gint count = 0;
/* Count pictures without second fields */ /* Count the number of complementary field pairs */
for (i = 0; i < dpb->pic_list->len; i++) { for (i = 0; i < dpb->pic_list->len; i++) {
GstH264Picture *picture = GstH264Picture *picture =
g_array_index (dpb->pic_list, GstH264Picture *, i); g_array_index (dpb->pic_list, GstH264Picture *, i);
@ -604,6 +604,7 @@ gst_h264_dpb_has_empty_frame_buffer (GstH264Dpb * dpb)
if (picture->second_field) if (picture->second_field)
continue; continue;
if (GST_H264_PICTURE_IS_FRAME (picture) || picture->other_field)
count++; count++;
} }