[FFmpeg-cvslog] lavc/h264_sei: reduce scope of parameters for green meta decode
Clément Bœsch
git at videolan.org
Tue Jun 14 08:24:33 CEST 2016
ffmpeg | branch: master | Clément Bœsch <u at pkh.me> | Mon Jun 13 22:54:23 2016 +0200| [b0ec36c9b168af131621cbde3e5ab9d9efd5337c] | committer: Clément Bœsch
lavc/h264_sei: reduce scope of parameters for green meta decode
This is again will help the merge as ff_h264_decode_sei will not have
access to H264Context anymore.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=b0ec36c9b168af131621cbde3e5ab9d9efd5337c
---
libavcodec/h264_sei.c | 32 ++++++++++++++++----------------
1 file changed, 16 insertions(+), 16 deletions(-)
diff --git a/libavcodec/h264_sei.c b/libavcodec/h264_sei.c
index b23878c..46d1814 100644
--- a/libavcodec/h264_sei.c
+++ b/libavcodec/h264_sei.c
@@ -363,28 +363,28 @@ static int decode_display_orientation(H264Context *h)
return 0;
}
-static int decode_GreenMetadata(H264Context *h)
+static int decode_GreenMetadata(GreenMetaData *h, GetBitContext *gb)
{
- h->sei_green_metadata.green_metadata_type=get_bits(&h->gb, 8);
+ h->green_metadata_type=get_bits(gb, 8);
- if (h->sei_green_metadata.green_metadata_type==0){
- h->sei_green_metadata.period_type=get_bits(&h->gb, 8);
+ if (h->green_metadata_type==0){
+ h->period_type=get_bits(gb, 8);
- if (h->sei_green_metadata.period_type==2){
- h->sei_green_metadata.num_seconds = get_bits(&h->gb, 16);
+ if (h->period_type==2){
+ h->num_seconds = get_bits(gb, 16);
}
- else if (h->sei_green_metadata.period_type==3){
- h->sei_green_metadata.num_pictures = get_bits(&h->gb, 16);
+ else if (h->period_type==3){
+ h->num_pictures = get_bits(gb, 16);
}
- h->sei_green_metadata.percent_non_zero_macroblocks=get_bits(&h->gb, 8);
- h->sei_green_metadata.percent_intra_coded_macroblocks=get_bits(&h->gb, 8);
- h->sei_green_metadata.percent_six_tap_filtering=get_bits(&h->gb, 8);
- h->sei_green_metadata.percent_alpha_point_deblocking_instance=get_bits(&h->gb, 8);
+ h->percent_non_zero_macroblocks=get_bits(gb, 8);
+ h->percent_intra_coded_macroblocks=get_bits(gb, 8);
+ h->percent_six_tap_filtering=get_bits(gb, 8);
+ h->percent_alpha_point_deblocking_instance=get_bits(gb, 8);
- }else if( h->sei_green_metadata.green_metadata_type==1){
- h->sei_green_metadata.xsd_metric_type=get_bits(&h->gb, 8);
- h->sei_green_metadata.xsd_metric_value=get_bits(&h->gb, 16);
+ }else if( h->green_metadata_type==1){
+ h->xsd_metric_type=get_bits(gb, 8);
+ h->xsd_metric_value=get_bits(gb, 16);
}
return 0;
@@ -443,7 +443,7 @@ int ff_h264_decode_sei(H264Context *h)
ret = decode_display_orientation(h);
break;
case SEI_TYPE_GREEN_METADATA:
- ret = decode_GreenMetadata(h);
+ ret = decode_GreenMetadata(&h->sei_green_metadata, &h->gb);
break;
default:
av_log(h->avctx, AV_LOG_DEBUG, "unknown SEI type %d\n", type);
More information about the ffmpeg-cvslog
mailing list