【问题标题】:Member function of a C++ object as a CUDA __global__ function作为 CUDA __global__ 函数的 C++ 对象的成员函数
【发布时间】:2013-07-06 08:03:19
【问题描述】:

我有一个基类:

  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 上开发。

【问题讨论】:

  • __global__ 函数不能是 CUDA 中的类静态成员。
  • 这是@talonmies 评论的documentation reference
  • 我的评论不会为 talonmies 和 Robert Crovella 已经向您指出的内容添加任何新内容。您真的需要将function2 定义为静态成员函数吗?我还在 Visual Studio 2010 下使用带有 CUDA 的模板类,并将我的所有 __global__ 函数定义为非成员函数。
  • @talonmies 我认为这足以作为答案。如果您将其发布为答案,我会赞成。
  • 最后评论。我想说您的问题与该类是否派生无关。是否可以跳过您帖子的此详细信息?

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


【解决方案1】:

第一个代码 sn-p 中的模板类定义是非法的,因为它包含一个 __global__ 函数(CUDA 内核)。根据language documentation,__global__ 函数不能是静态类成员函数。出于同样的原因,第二个模板类成员函数是非法的。

【讨论】:

    猜你喜欢
    • 2011-01-11
    • 1970-01-01
    • 2015-10-20
    • 1970-01-01
    • 2014-03-26
    • 2018-04-24
    • 2015-09-12
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多