]> git.sesse.net Git - ffmpeg/commitdiff
mpegvideo_enc: export vbv_delay in side data
authorAnton Khirnov <anton@khirnov.net>
Sun, 4 Oct 2015 10:19:26 +0000 (12:19 +0200)
committerAnton Khirnov <anton@khirnov.net>
Sun, 6 Dec 2015 09:25:23 +0000 (10:25 +0100)
Deprecate AVCodecContext.vbv_delay

libavcodec/avcodec.h
libavcodec/mpegvideo_enc.c
libavcodec/version.h

index dacbcd37335b58d89ccf975b101919d2e78a577e..64328c80ea783114be151e9fbddebcd73fc8934d 100644 (file)
@@ -2914,13 +2914,18 @@ typedef struct AVCodecContext {
     int error_rate;
 #endif
 
+#if FF_API_VBV_DELAY
     /**
      * VBV delay coded in the last frame (in periods of a 27 MHz clock).
      * Used for compliant TS muxing.
      * - encoding: Set by libavcodec.
      * - decoding: unused.
+     * @deprecated this value is now exported as a part of
+     * AV_PKT_DATA_CPB_PROPERTIES packet side data
      */
+    attribute_deprecated
     uint64_t vbv_delay;
+#endif
 
 #if FF_API_SIDEDATA_ONLY_PKT
     /**
index 93360514309f99588dd0aa37b21e57cf9fb9ec0f..4e97f4d3abe420da20170b14658a44cf40d092ba 100644 (file)
@@ -1769,6 +1769,9 @@ vbv_retry:
             s->out_format == FMT_MPEG1                     &&
             90000LL * (avctx->rc_buffer_size - 1) <=
                 s->avctx->rc_max_rate * 0xFFFFLL) {
+            AVCPBProperties *props;
+            size_t props_size;
+
             int vbv_delay, min_delay;
             double inbits  = s->avctx->rc_max_rate *
                              av_q2d(s->avctx->time_base);
@@ -1795,7 +1798,17 @@ vbv_retry:
             s->vbv_delay_ptr[1]  = vbv_delay >> 5;
             s->vbv_delay_ptr[2] &= 0x07;
             s->vbv_delay_ptr[2] |= vbv_delay << 3;
+
+            props = av_cpb_properties_alloc(&props_size);
+            if (!props)
+                return AVERROR(ENOMEM);
+            props->vbv_delay = vbv_delay * 300;
+
+#if FF_API_VBV_DELAY
+FF_DISABLE_DEPRECATION_WARNINGS
             avctx->vbv_delay     = vbv_delay * 300;
+FF_ENABLE_DEPRECATION_WARNINGS
+#endif
         }
         s->total_bits     += s->frame_bits;
         avctx->frame_bits  = s->frame_bits;
index 0e42e6cbe4507d8090878a81c7dc790510afbd9b..afa76001eb37ee17e4416b8ae8527227adaca913 100644 (file)
 #ifndef FF_API_RTP_CALLBACK
 #define FF_API_RTP_CALLBACK      (LIBAVCODEC_VERSION_MAJOR < 59)
 #endif
+#ifndef FF_API_VBV_DELAY
+#define FF_API_VBV_DELAY         (LIBAVCODEC_VERSION_MAJOR < 59)
+#endif
 
 #endif /* AVCODEC_VERSION_H */