]> git.sesse.net Git - ffmpeg/commitdiff
avfilter/scale_cuda: fix pitch calculation for >8 bit formats
authorTimo Rothenpieler <timo@rothenpieler.org>
Wed, 4 Nov 2020 23:46:54 +0000 (00:46 +0100)
committerTimo Rothenpieler <timo@rothenpieler.org>
Wed, 4 Nov 2020 23:47:14 +0000 (00:47 +0100)
libavfilter/vf_scale_cuda.c

index 4de5cc29e8812cb82fc2640dd693cd10e81c4e55..99fef6b22b8fef2f43b1b79322b65541508460db 100644 (file)
@@ -406,8 +406,6 @@ static int call_resize_kernel(AVFilterContext *ctx, CUfunction func, int channel
                            &src_width, &src_height, &bit_depth, &s->param };
     int ret;
 
-    dst_pitch /= channels;
-
     CUDA_TEXTURE_DESC tex_desc = {
         .filterMode = s->interp_use_linear ?
                       CU_TR_FILTER_MODE_LINEAR :
@@ -427,6 +425,10 @@ static int call_resize_kernel(AVFilterContext *ctx, CUfunction func, int channel
         .res.pitch2D.devPtr = (CUdeviceptr)src_dptr,
     };
 
+    // Handling of channels is done via vector-types in cuda, so their size is implicitly part of the pitch
+    // Same for pixel_size, which is represented via datatypes on the cuda side of things.
+    dst_pitch /= channels * pixel_size;
+
     ret = CHECK_CU(cu->cuTexObjectCreate(&tex, &res_desc, &tex_desc, NULL));
     if (ret < 0)
         goto exit;