diff options
author | Clément Bœsch <clement@stupeflix.com> | 2016-06-29 12:03:20 +0200 |
---|---|---|
committer | Clément Bœsch <clement@stupeflix.com> | 2016-06-29 12:03:20 +0200 |
commit | 19fe328f12f6658f7e3feb521ee81a8b13e76e49 (patch) | |
tree | 68f662df03c9f853749c970b8957fa7493023563 | |
parent | 3e71e34333c7cd1225de4807bf86fff01ba8fd01 (diff) | |
parent | 19d7667a81499d4357ec8e0851701e17c238e584 (diff) | |
download | ffmpeg-19fe328f12f6658f7e3feb521ee81a8b13e76e49.tar.gz |
Merge commit '19d7667a81499d4357ec8e0851701e17c238e584'
* commit '19d7667a81499d4357ec8e0851701e17c238e584':
vaapi_encode: Add support for writing arbitrary additional packed headers
Merged-by: Clément Bœsch <clement@stupeflix.com>
-rw-r--r-- | libavcodec/vaapi_encode.c | 21 | ||||
-rw-r--r-- | libavcodec/vaapi_encode.h | 4 |
2 files changed, 25 insertions, 0 deletions
diff --git a/libavcodec/vaapi_encode.c b/libavcodec/vaapi_encode.c index 949051660c..c55a78361c 100644 --- a/libavcodec/vaapi_encode.c +++ b/libavcodec/vaapi_encode.c @@ -293,6 +293,27 @@ static int vaapi_encode_issue(AVCodecContext *avctx, } } + if (ctx->codec->write_extra_header) { + for (i = 0;; i++) { + int type; + bit_len = 8 * sizeof(data); + err = ctx->codec->write_extra_header(avctx, pic, i, &type, + data, &bit_len); + if (err == AVERROR_EOF) + break; + if (err < 0) { + av_log(avctx, AV_LOG_ERROR, "Failed to write extra " + "header %d: %d.\n", i, err); + goto fail; + } + + err = vaapi_encode_make_packed_header(avctx, pic, type, + data, bit_len); + if (err < 0) + goto fail; + } + } + av_assert0(pic->nb_slices <= MAX_PICTURE_SLICES); for (i = 0; i < pic->nb_slices; i++) { slice = av_mallocz(sizeof(*slice)); diff --git a/libavcodec/vaapi_encode.h b/libavcodec/vaapi_encode.h index b67168b1ef..8f4f653812 100644 --- a/libavcodec/vaapi_encode.h +++ b/libavcodec/vaapi_encode.h @@ -215,6 +215,10 @@ typedef struct VAAPIEncodeType { VAAPIEncodePicture *pic, int index, int *type, char *data, size_t *data_len); + int (*write_extra_header)(AVCodecContext *avctx, + VAAPIEncodePicture *pic, + int index, int *type, + char *data, size_t *data_len); } VAAPIEncodeType; |