先编写一个 hello world 和 C 没有什么区别
我们将 CPU 以及系统的内存称为主机,将 GPU 及其内存称为设备,hello world 示例程序不考虑主机之外的任何计算设备
核函数的调用
__global__ void kernel ( void ) {
}
int main(){
kernel<<1,1>>();
}
kernel() 函数,并且带有修饰符 __global__,这个修饰符告诉编译器,函数应该在设备上而不是主机上运行,而 main 函数交给主机编译器
kernel() 的调用为什么需要尖括号和数值
CUDA C需要通过某种语法将一个函数标记为“设备代码”,表示将主机代码送到一个编译器,将设别代码送到另一个编译器。CUDA编译器负责运行时从主机代码调用设备代码
所以这个函数调用实际上表示调用设备代码,尖括号表示将一些参数传递给运行时系统,这些参数并不是传递给设备代码的参数,而是告诉运行时如何启动设备代码,传递给设备代码的参数是放在圆括号中的
参数传递给核函数的过程中没有任何特别之处,除了尖括号语法,核函数外表和标准 C 中任何的函数调用一个样,运行时,系统负责处理将参数从主机传递给设备的所有过程