]> git.sesse.net Git - ffmpeg/commitdiff
nvenc: only support HW frames when CUDA is enabled
authorAnton Khirnov <anton@khirnov.net>
Fri, 13 May 2016 07:05:25 +0000 (09:05 +0200)
committerAnton Khirnov <anton@khirnov.net>
Thu, 19 May 2016 12:17:03 +0000 (14:17 +0200)
hwcontext_cuda.h includes cuda.h, so this will allow building nvenc
without depending on cuda.h

libavcodec/nvenc.c

index ff852b10bb7e8e2d55429103b6850f6d02fbd339..7564985964a50592ffa831d4a5b78274d3c20313 100644 (file)
 
 #include "libavutil/common.h"
 #include "libavutil/hwcontext.h"
-#include "libavutil/hwcontext_cuda.h"
 #include "libavutil/imgutils.h"
 #include "libavutil/mem.h"
 #include "avcodec.h"
 #include "internal.h"
 #include "nvenc.h"
 
+#if CONFIG_CUDA
+#include "libavutil/hwcontext_cuda.h"
+#endif
+
 #define NVENC_CAP 0x30
 #define BITSTREAM_BUFFER_SIZE 1024 * 1024
 #define IS_CBR(rc) (rc == NV_ENC_PARAMS_RC_CBR ||               \
@@ -85,7 +88,9 @@ const enum AVPixelFormat ff_nvenc_pix_fmts[] = {
     AV_PIX_FMT_NV12,
     AV_PIX_FMT_YUV420P,
     AV_PIX_FMT_YUV444P,
+#if CONFIG_CUDA
     AV_PIX_FMT_CUDA,
+#endif
     AV_PIX_FMT_NONE
 };
 
@@ -395,6 +400,7 @@ static int nvenc_setup_device(AVCodecContext *avctx)
     }
 
     if (avctx->pix_fmt == AV_PIX_FMT_CUDA) {
+#if CONFIG_CUDA
         AVHWFramesContext   *frames_ctx;
         AVCUDADeviceContext *device_hwctx;
         int ret;
@@ -414,6 +420,9 @@ static int nvenc_setup_device(AVCodecContext *avctx)
         ret = nvenc_check_capabilities(avctx);
         if (ret < 0)
             return ret;
+#else
+        return AVERROR_BUG;
+#endif
     } else {
         int i, nb_devices = 0;