如何解决如何使surf2Dwrite在C ++ CUDA中正确编译
忽略此问题-代码很好-问题在于共享示例中未包含C ++头文件。
我正在将Visual Studio 2019与CUDA 11.0一起使用,并且遇到了尝试使用cudaSurfaceObject_t存储计算结果的砖墙。
我收到以下编译器错误
错误C3861'surf2Dwrite':找不到标识符
错误C2059语法错误:'
我用.header填充了.cu文件的include#
部分,这是徒劳的尝试,目的是要识别surf2Dwrite。
我的代码示例版本是一次简单的尝试,以值float
的{{1}}填充表面:-
NAN
以上代码无法构建,并显示如下错误。输出中的相关行如下:-
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <cuda.h>
#include <ctype.h>
#include <string.h>
#include "cuda_runtime.h"
#include "device_launch_parameters.h"
#include "export.h"
#include"surface_functions.h"
__global__
void TestGrids(cudaSurfaceObject_t surf,int size)
{
int y = threadIdx.y + blockIdx.y * blockDim.y;
int x = threadIdx.x + blockIdx.x * blockDim.x;
if (x < size && y < size)
{
surf2Dwrite(NAN,surf,x * 4,y);//Error C3861 'surf2Dwrite': identifier not found
}
}
void TestSurfWrite( int size)
{
cudaDeviceProp prop;
cudaError_t c_err = cudaGetDeviceProperties(&prop,0);
//Set grid and block sizes
dim3 dimblock(16,16,1);
int gridDimX = prop.multiProcessorCount;
int gridDimY = 16;
while (gridDimX > 2 * gridDimY)
{
gridDimX = gridDimX / 2;
gridDimY = gridDimY * 2;
}
dim3 dimGrid(gridDimX,gridDimY,1);
cudaChannelFormatDesc nanchannelDescSurf = cudaCreateChannelDesc(32,cudaChannelFormatKindFloat);
cudaArray_t nanArray;
cudaMallocArray(&nanArray,&nanchannelDescSurf,size,0);
struct cudaResourceDesc nanDescSurf;
memset(&nanDescSurf,sizeof(cudaResourceDesc));
nanDescSurf.resType = cudaResourceTypeArray;
nanDescSurf.res.array.array = nanArray;
cudaSurfaceObject_t nanSurf;
cudaCreateSurfaceObject(&nanSurf,&nanDescSurf);
TestGrids<<<dimGrid,dimblock>>>(nanSurf,size); // Error C2059 syntax error: '<'
c_err = cudaGetLastError();
// perform work on nansurf here..
cudaDestroySurfaceObject(nanSurf);
cudaFreeArray(nanArray);
}
我是C ++和CUDA的初学者,因此我希望这里会出现一个明显的问题。
talonmies在下面的评论中确定这是一个项目设置问题-这是我没有专业知识并且真的不知道从哪里开始寻找解决方案,因此我添加了VisualStudio-2019标签希望它将吸引对这些事情了解的人...
解决方法
出现问题是因为我处理了头文件。我还没有解决所有问题,但是在将代码移入simpleSurfaceWrite.cu文件的过程中(如注释中所述),我必须添加头文件-此时,我又开始再次遇到列出的错误-这次发生在simpleSurfaceWrite.cu中。
从本质上讲,我共享的示例代码过于简化,无法真正重现我的问题。
感谢所有对此有所考虑的人。
现在我必须整理我的头文件...
更新: 标头文件已整理-代码现在可以构建并运行
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。