aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/videotoolboxenc.c
diff options
context:
space:
mode:
authorRick Kern <kernrj@gmail.com>2016-04-27 10:53:11 -0400
committerwm4 <nfxjfg@googlemail.com>2016-05-04 18:40:40 +0200
commitca429e725353f9a4a05e3faa1faa22ebbc673c34 (patch)
tree93716912ebbf7388d7a943801920b7d883c4044c /libavcodec/videotoolboxenc.c
parent272dd437bc6b663200bc6d2c013b02c9eaf64a49 (diff)
downloadffmpeg-ca429e725353f9a4a05e3faa1faa22ebbc673c34.tar.gz
lavc/videotoolboxenc: Add realtime encoding property
Hint to the encoder that encoding should be done in real-time, even at the expense of quality. Signed-off-by: Rick Kern <kernrj@gmail.com>
Diffstat (limited to 'libavcodec/videotoolboxenc.c')
-rw-r--r--libavcodec/videotoolboxenc.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/libavcodec/videotoolboxenc.c b/libavcodec/videotoolboxenc.c
index f53015ac9c..45a6a3348f 100644
--- a/libavcodec/videotoolboxenc.c
+++ b/libavcodec/videotoolboxenc.c
@@ -76,6 +76,7 @@ typedef struct VTEncContext {
int64_t profile;
int64_t level;
int64_t entropy;
+ int64_t realtime;
int64_t allow_sw;
@@ -747,6 +748,16 @@ static av_cold int vtenc_init(AVCodecContext *avctx)
}
}
+ if (vtctx->realtime) {
+ status = VTSessionSetProperty(vtctx->session,
+ kVTCompressionPropertyKey_RealTime,
+ kCFBooleanTrue);
+
+ if (status) {
+ av_log(avctx, AV_LOG_ERROR, "Error setting realtime property: %d\n", status);
+ }
+ }
+
status = VTCompressionSessionPrepareToEncodeFrames(vtctx->session);
if (status) {
av_log(avctx, AV_LOG_ERROR, "Error: cannot prepare encoder: %d\n", status);
@@ -1520,6 +1531,9 @@ static const AVOption options[] = {
{ "cabac", "CABAC entropy coding", 0, AV_OPT_TYPE_CONST, { .i64 = VT_CABAC }, INT_MIN, INT_MAX, VE, "coder" },
{ "ac", "CABAC entropy coding", 0, AV_OPT_TYPE_CONST, { .i64 = VT_CABAC }, INT_MIN, INT_MAX, VE, "coder" },
+ { "realtime", "Hint that encoding should happen in real-time if not faster (e.g. capturing from camera).",
+ OFFSET(realtime), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, VE },
+
{ NULL },
};