私はこのコードを持っていますが、ときどき動作します(printf( "ERR:%d \ n"、id))。 私はCUDA 4.1で動作し、コンピューティング機能2.1であるGTS450を持っています。CUDAコードが動作しません、なぜですか?
コードdoesntのは、私の心はそれは右、私に言うので、IAMのはただ、そのが働いていない理由を見つけようとし、高い目的を持っている:]
あなたがそれを実行したい場合は、多分あなたは、数回実行する必要があります「エラー」が表示されたり、グリッドサイズが変更された場合
PS:here you can download exe file for win64 - you need to have cuda4.1 driver
class MAN
{
public:
int m_id;
int m_use;
__device__
MAN()
{
m_id = -1;
m_use = 0;
}
};
__device__ int* d_ids = NULL;
__device__ int d_last_ids = 0;
__device__ MAN* d_mans = NULL;
__global__ void init()
{
d_mans = new MAN[500]; //note: 500 is more than enough!
d_ids = new int[500];
for(int i=0; i < 500; i++)
d_ids[i] = 0;
}
__device__ int getMAN() //every block get unique number, so at one moment all running blocks has different id
{
while(true)
{
for(int i=0; i < 500; i++)
if(atomicCAS(&(d_mans[i].m_use), 0, 1)==0)
return i;
}
}
__device__ void returnMAN(int id)
{
int s = atomicExch(&(d_mans[id].m_use), 0);
}
__global__ void testIt()
{
if(threadIdx.x==0)
{
int man = getMAN();
int id = d_mans[man].m_id;
if(id == -1) //If It never works with this "id", its creating new
{
id = atomicAdd(&d_last_ids, 2);
d_ids[id] = 10; //set to non-zero
d_mans[man].m_id = id; //save new id for next time
printf("ADD:%d\n", id);
}
if(d_ids[id]==0)
printf("ERR:%d\n", id); //THIS SHOULD NEVER HAPPEN, BUT BECOMES !!!
returnMAN(man);
}
}
int main()
{
init<<<1, 1>>>();
printf("init() err: %d\n", cudaDeviceSynchronize());
testIt<<<20000, 512>>>();
printf("testIt() err: %d\n", cudaDeviceSynchronize());
getchar();
return 0;
}
あなたは 'init'カーネル呼び出しが失敗していると言っていますか?エラーメッセージは何ですか? – talonmies
いいえそれはcudaエラーなし。問題は、プログラムが "printf(" ERR:%d \ n "、id);"しかし、これは決して起こりえない! – Milan
達成しようとしていることは何ですか? (高いレベルで) – harrism