summaryrefslogtreecommitdiff
path: root/libavfilter/video.c
diff options
context:
space:
mode:
authorMatthieu Bouron <matthieu.bouron@gmail.com>2017-03-29 23:11:10 +0200
committerMatthieu Bouron <matthieu.bouron@gmail.com>2017-03-29 23:12:00 +0200
commitb265e5ba50b86f2ca640e3a565bd54f7e4292bb0 (patch)
tree02dd8a622bd4188366bab4d587897d95a73aab81 /libavfilter/video.c
parent247d0339ca5ddab692aee49baf43cd1324466028 (diff)
parent7433feb82f75827884d909de34d341a1c4401d4a (diff)
downloadffmpeg-b265e5ba50b86f2ca640e3a565bd54f7e4292bb0.tar.gz
Merge commit '7433feb82f75827884d909de34d341a1c4401d4a'
* commit '7433feb82f75827884d909de34d341a1c4401d4a': lavfi: Make default get_video_buffer work with hardware frames Merged-by: Matthieu Bouron <matthieu.bouron@gmail.com>
Diffstat (limited to 'libavfilter/video.c')
-rw-r--r--libavfilter/video.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/libavfilter/video.c b/libavfilter/video.c
index fabdafd0d9..6f9020b9fe 100644
--- a/libavfilter/video.c
+++ b/libavfilter/video.c
@@ -25,6 +25,7 @@
#include "libavutil/avassert.h"
#include "libavutil/buffer.h"
+#include "libavutil/hwcontext.h"
#include "libavutil/imgutils.h"
#include "libavutil/mem.h"
@@ -47,6 +48,21 @@ AVFrame *ff_default_get_video_buffer(AVFilterLink *link, int w, int h)
int pool_align = 0;
enum AVPixelFormat pool_format = AV_PIX_FMT_NONE;
+ if (link->hw_frames_ctx &&
+ ((AVHWFramesContext*)link->hw_frames_ctx->data)->format == link->format) {
+ int ret;
+ AVFrame *frame = av_frame_alloc();
+
+ if (!frame)
+ return NULL;
+
+ ret = av_hwframe_get_buffer(link->hw_frames_ctx, frame, 0);
+ if (ret < 0)
+ av_frame_free(&frame);
+
+ return frame;
+ }
+
if (!link->frame_pool) {
link->frame_pool = ff_frame_pool_video_init(av_buffer_allocz, w, h,
link->format, BUFFER_ALIGN);