我想在CUDA C代码中使用汇编代码 为了减少昂贵的执行 我们在c编程中使用 asm 。
有可能吗?
答案 0 :(得分:18)
自CUDA 4.0以来,CUDA工具链支持内联PTX。工具箱中有一个描述它的文档:Using_Inline_PTX_Assembly_In_CUDA.pdf
下面是一些代码,演示了如何在CUDA 4.0中使用内联PTX。请注意,此代码不应用作CUDA内置__clz()函数的替代,我只是编写它来探索新的内联PTX功能的各个方面。
__device__ __forceinline__ int my_clz (unsigned int x)
{
int res;
asm ("{\n"
" .reg .pred iszero, gezero;\n"
" .reg .u32 t1, t2;\n"
" mov.b32 t1, %1;\n"
" shr.u32 %0, t1, 16;\n"
" setp.eq.b32 iszero, %0, 0;\n"
" mov.b32 %0, 0;\n"
"@iszero shl.b32 t1, t1, 16;\n"
"@iszero or.b32 %0, %0, 16;\n"
" and.b32 t2, t1, 0xff000000;\n"
" setp.eq.b32 iszero, t2, 0;\n"
"@iszero shl.b32 t1, t1, 8;\n"
"@iszero or.b32 %0, %0, 8;\n"
" and.b32 t2, t1, 0xf0000000;\n"
" setp.eq.b32 iszero, t2, 0;\n"
"@iszero shl.b32 t1, t1, 4;\n"
"@iszero or.b32 %0, %0, 4;\n"
" and.b32 t2, t1, 0xc0000000;\n"
" setp.eq.b32 iszero, t2, 0;\n"
"@iszero shl.b32 t1, t1, 2;\n"
"@iszero or.b32 %0, %0, 2;\n"
" setp.ge.s32 gezero, t1, 0;\n"
" setp.eq.b32 iszero, t1, 0;\n"
"@gezero or.b32 %0, %0, 1;\n"
"@iszero add.u32 %0, %0, 1;\n\t"
"}"
: "=r"(res)
: "r"(x));
return res;
}
答案 1 :(得分:4)
不,你不能,没有像C / C ++中的asm结构。您可以做的是调整生成的PTX程序集,然后将其与CUDA一起使用。
有关示例,请参阅this。
但是对于GPU,组件优化不是必需的,您应该首先进行其他优化,例如内存合并和占用。有关详细信息,请参阅CUDA Best Practices guide。