È possibile passare un oggetto a una funzione del kernel?Passaggio di un oggetto di classe a un kernel
Considerate Ho una classe
class MyClass
{
public :
int value;
float rate;
MyClass()
{
value = 0; rate = 0;
}
MyClass(int v,float r)
{
value = v; rate = r;
}
};
e la mia Kernel accetta un array di oggetti di MyClass
__global__ void MyKernel(MyClass * mc)
{
//Some Calculation
}
Posso passare la matrice? Come allocare memoria ?? In questo momento ho provato con il seguente codice ha ricevuto l'errore 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
Qual è l'errore? –