У меня есть два, какпропускание-структуры, включая указатель на другую структуру, ядро в CUDA
структурstruct collapsed {
char **seq;
int num;
};
struct data {
collapsed *x;
int num;
int numblocks;
int *blocksizes;
float *regmult;
float *learnmult;
};
Я передаю его в мое ядро как;
__global__ void KERNEL(data* X,...){
...
collapsed x = X->x[0]; // GIVES CUDA_EXPECTION_1:Lane Illegal Address
}
data X;
//init X
data *X_dev;
cudaMalloc((data **) & X_dev, sizeof(data));
cudaMemcpy(X_dev, &X, sizeof(data), cudaMemcpyHostToDevice);
KERNEL<<<...>>>(X_dev,...);
Этот код дает CUDA_EXPECTION_1: Lane Illegal Адрес в коде ядра. Что не так или как правильно это сделать? Есть идеи?