From 73ad2c2fa725be51215e1c021c5335f8ce65af79 Mon Sep 17 00:00:00 2001 From: Janne Grunau Date: Mon, 17 Dec 2012 21:36:05 +0100 Subject: [PATCH 1/2] h264: increase dist_scale_factor for up to 32 references Compute dist_scale_factor_field only for MBAFF since that is the only case in which it is used. --- libavcodec/h264.h | 2 +- libavcodec/h264_direct.c | 17 ++++++++++------- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/libavcodec/h264.h b/libavcodec/h264.h index 30494706a8..6691be4a94 100644 --- a/libavcodec/h264.h +++ b/libavcodec/h264.h @@ -364,7 +364,7 @@ typedef struct H264Context { int direct_spatial_mv_pred; int col_parity; int col_fieldoff; - int dist_scale_factor[16]; + int dist_scale_factor[32]; int dist_scale_factor_field[2][32]; int map_col_to_list0[2][16 + 32]; int map_col_to_list0_field[2][2][16 + 32]; diff --git a/libavcodec/h264_direct.c b/libavcodec/h264_direct.c index fc429aee80..a33efa5d6f 100644 --- a/libavcodec/h264_direct.c +++ b/libavcodec/h264_direct.c @@ -54,14 +54,17 @@ void ff_h264_direct_dist_scale_factor(H264Context * const h){ const int poc = h->s.current_picture_ptr->field_poc[ s->picture_structure == PICT_BOTTOM_FIELD ]; const int poc1 = h->ref_list[1][0].poc; int i, field; - for(field=0; field<2; field++){ - const int poc = h->s.current_picture_ptr->field_poc[field]; - const int poc1 = h->ref_list[1][0].field_poc[field]; - for(i=0; i < 2*h->ref_count[0]; i++) - h->dist_scale_factor_field[field][i^field] = get_scale_factor(h, poc, poc1, i+16); - } - for(i=0; iref_count[0]; i++){ + if (FRAME_MBAFF) + for (field = 0; field < 2; field++){ + const int poc = h->s.current_picture_ptr->field_poc[field]; + const int poc1 = h->ref_list[1][0].field_poc[field]; + for (i = 0; i < 2 * h->ref_count[0]; i++) + h->dist_scale_factor_field[field][i^field] = + get_scale_factor(h, poc, poc1, i+16); + } + + for (i = 0; i < h->ref_count[0]; i++){ h->dist_scale_factor[i] = get_scale_factor(h, poc, poc1, i); } } From ed2d7d5868a4a5d914f1e5488d63ea696a3b2937 Mon Sep 17 00:00:00 2001 From: Michael Niedermayer Date: Sun, 18 Nov 2012 18:46:05 +0100 Subject: [PATCH 2/2] ff_h264_direct_ref_list_init: fix B slice check. Fixes null pointer dereference. Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind --- libavcodec/h264_direct.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/libavcodec/h264_direct.c b/libavcodec/h264_direct.c index a33efa5d6f..bf444958bf 100644 --- a/libavcodec/h264_direct.c +++ b/libavcodec/h264_direct.c @@ -134,7 +134,7 @@ void ff_h264_direct_ref_list_init(H264Context * const h){ h->col_fieldoff = 2 * h->ref_list[1][0].f.reference - 3; } - if (cur->f.pict_type != AV_PICTURE_TYPE_B || h->direct_spatial_mv_pred) + if (h->slice_type_nos != AV_PICTURE_TYPE_B || h->direct_spatial_mv_pred) return; for(list=0; list<2; list++){