我们可以将对象传递给内核函数吗?
考虑我有一堂课
class MyClass
{
public:
int value;
float rate;
MyClass()
{
value = 0; rate = 0;
}
MyClass(int v,float r)
{
value = v; rate = r;
}
};
我的内核采用 MyClass 对象的数组
__global__ void MyKernel(MyClass * mc)
{
//Some Calculation
}
我可以传递数组吗?如何分配内存??现在我尝试使用以下代码得到 CudaMemcpy 错误
cudaError_t cudaStatus;
MyClass darr[10] ;
cudaStatus = cudaMalloc((void**)&darr, size * sizeof(MyClass));
if (cudaStatus != cudaSuccess) {
fprintf(stderr, "cudaMalloc failed!");
goto label1;
}
cudaStatus = cudaMemcpy(darr, arr, size * sizeof(MyClass), cudaMemcpyHostToDevice);
//arr is a host array