cuda从5.0版本之后开始支持dynamic parallelism,即可以在__global__函数中调用其他global函数,因此可以实现核函数中再调用核函数。
dynamic parallelism(动态并行)的软硬件条件有:
1. cuda toolKit 版本5.0或以上;
2. GPU compute capability(计算能力)3.5及以上。
此时就可以在核函数中调用另一个核函数了,也可以实现递归调用。但这时会出现如下link error:
error LNK2001: unresolved external symbol ___fatbinwrap_66_tmpxft_00000b3c_00000000_17_cuda_device_runtime_compute_52_cpp1_ii_8b1a5d37.
这是因为动态并行还需要附加另一个库:cudadevrt.lib。加入即可。