作为CUDA __global__函数的C ++对象的成员函数

时间:2013-07-08 21:04:33

标签: c++ visual-studio-2010 cuda

我有一个基类:

  template <class T> 
  class A{
         public:
           // some data
           T data;
           //some functions like constructs etc.
            ...
           // one virtual function
           virtual void evaluate() = 0;

   }

和派生类:

 template <class T> 
 class B:public A<T>{
          public:
          // some functions like constructors etc.
          virtual void evaluate();
          __global__ void function2();   // **** error message

 } 

另外,我有

 template <class T> void
 B<T>::evaluate()
 { 
    dim3 grid(1);dim3 block(1);  
    void function2<<<grid,block>>>();
 }

template <class T>  __global__ void B<T>::function2() // **** error message 
{
   // computation here
}

所以基本上我有一个派生类的成员函数,我希望在设备上以并行方式执行。

不幸的是,我收到错误:

error : illegal combination of memory qualifiers on the lines :

1> __global__ void function2();   // **** error message

2> template <class T>  __global__ void B<T>::function2() // **** error message

我是CUDA的新手。如果有人指出我的错误,那将是非常友好的。我正在使用Visual Studio 2010进行开发。

1 个答案:

答案 0 :(得分:3)

第一个代码段中的模板类定义是非法的,因为它包含__global__函数(CUDA内核)。根据{{​​3}},__ global__函数不能是静态类成员函数。出于同样的原因,第二个模板化的类成员函数是非法的。