summaryrefslogtreecommitdiffstats
path: root/libavcodec
diff options
context:
space:
mode:
authorAnton Khirnov <anton@khirnov.net>2016-04-15 15:00:29 +0200
committerAnton Khirnov <anton@khirnov.net>2016-06-12 20:27:52 +0200
commit7b50d60442af8d9527e9da46818011fe15a5265a (patch)
tree2e6f63e7260f8dec2918756e938ee02fc74b85bf /libavcodec
parentb16e9b9ac9db449cae2242767dd3c3fc309357c4 (diff)
downloadffmpeg-streaming-7b50d60442af8d9527e9da46818011fe15a5265a.zip
ffmpeg-streaming-7b50d60442af8d9527e9da46818011fe15a5265a.tar.gz
h264: call ff_h264_fill_mbaff_ref_list() when constructing the normal ref list
There is no real reason to call it separately.
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/h264.h1
-rw-r--r--libavcodec/h264_refs.c53
-rw-r--r--libavcodec/h264_slice.c2
3 files changed, 28 insertions, 28 deletions
diff --git a/libavcodec/h264.h b/libavcodec/h264.h
index 41ff1f9..034507d 100644
--- a/libavcodec/h264.h
+++ b/libavcodec/h264.h
@@ -657,7 +657,6 @@ int ff_h264_get_slice_type(const H264SliceContext *sl);
int ff_h264_alloc_tables(H264Context *h);
int ff_h264_decode_ref_pic_list_reordering(const H264Context *h, H264SliceContext *sl);
-void ff_h264_fill_mbaff_ref_list(H264SliceContext *sl);
void ff_h264_remove_all_refs(H264Context *h);
/**
diff --git a/libavcodec/h264_refs.c b/libavcodec/h264_refs.c
index b2f255f..b4dfbbc 100644
--- a/libavcodec/h264_refs.c
+++ b/libavcodec/h264_refs.c
@@ -227,6 +227,31 @@ static int pic_num_extract(const H264Context *h, int pic_num, int *structure)
return pic_num;
}
+static void h264_fill_mbaff_ref_list(H264SliceContext *sl)
+{
+ int list, i, j;
+ for (list = 0; list < sl->list_count; list++) {
+ for (i = 0; i < sl->ref_count[list]; i++) {
+ H264Ref *frame = &sl->ref_list[list][i];
+ H264Ref *field = &sl->ref_list[list][16 + 2 * i];
+
+ field[0] = *frame;
+
+ for (j = 0; j < 3; j++)
+ field[0].linesize[j] <<= 1;
+ field[0].reference = PICT_TOP_FIELD;
+ field[0].poc = field[0].parent->field_poc[0];
+
+ field[1] = field[0];
+
+ for (j = 0; j < 3; j++)
+ field[1].data[j] += frame->parent->f->linesize[j];
+ field[1].reference = PICT_BOTTOM_FIELD;
+ field[1].poc = field[1].parent->field_poc[1];
+ }
+ }
+}
+
int ff_h264_decode_ref_pic_list_reordering(const H264Context *h, H264SliceContext *sl)
{
int list, index, pic_structure;
@@ -349,32 +374,10 @@ int ff_h264_decode_ref_pic_list_reordering(const H264Context *h, H264SliceContex
}
}
- return 0;
-}
-
-void ff_h264_fill_mbaff_ref_list(H264SliceContext *sl)
-{
- int list, i, j;
- for (list = 0; list < sl->list_count; list++) {
- for (i = 0; i < sl->ref_count[list]; i++) {
- H264Ref *frame = &sl->ref_list[list][i];
- H264Ref *field = &sl->ref_list[list][16 + 2 * i];
-
- field[0] = *frame;
-
- for (j = 0; j < 3; j++)
- field[0].linesize[j] <<= 1;
- field[0].reference = PICT_TOP_FIELD;
- field[0].poc = field[0].parent->field_poc[0];
+ if (FRAME_MBAFF(h))
+ h264_fill_mbaff_ref_list(sl);
- field[1] = field[0];
-
- for (j = 0; j < 3; j++)
- field[1].data[j] += frame->parent->f->linesize[j];
- field[1].reference = PICT_BOTTOM_FIELD;
- field[1].poc = field[1].parent->field_poc[1];
- }
- }
+ return 0;
}
/**
diff --git a/libavcodec/h264_slice.c b/libavcodec/h264_slice.c
index aefb375..33f9f57 100644
--- a/libavcodec/h264_slice.c
+++ b/libavcodec/h264_slice.c
@@ -1379,8 +1379,6 @@ static int h264_slice_header_parse(H264Context *h, H264SliceContext *sl)
}
if (FRAME_MBAFF(h)) {
- ff_h264_fill_mbaff_ref_list(sl);
-
if (pps->weighted_bipred_idc == 2 && sl->slice_type_nos == AV_PICTURE_TYPE_B) {
implicit_weight_table(h, sl, 0);
implicit_weight_table(h, sl, 1);
OpenPOWER on IntegriCloud