0
內核我有兩個結構爲傳遞一個結構包括一個指向另一個結構,在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:巷非法地址在內核代碼。什麼是錯誤的或什麼是正確的做法?任何想法?