4.2.3 执行配置

[复制链接]
查看11 | 回复1 | 2010-3-1 11:08:29 | 显示全部楼层 |阅读模式
对 _global_ 函数的任何调用都必须指定该调用的执行配置。
执行配置定义将用于在该设备上执行函数的网格和块的维度,以及相关的流(有关流的内容将在第 4.5.1.5 节介绍)。可通过在函数名称和括号参数列表之间插入 >> 形式的表达式来指定,其中:
?
Dg 的类型为 dim3(参见第 4.3.1.2 节),指定网格的维度和大小,Dg.x * Dg.y 等于所启动的块数量,Dg.z 无用;
?
Db 的类型为 dim3(参见第 4.3.1.2 节),指定各块的维度和大小,Db.x * Db.y * Db.z 等于各块的线程数量;
?
Ns 的类型为 size_t,指定各块为此调用动态分配的共享存储器(除静态分配的存储器之外),这些动态分配的存储器可供声明为外部数组的其他任何变量使用(参见第 4.2.2.3 节),Ns 是一个可选参数,默认值为 0;
?
S 的类型为 cudaStream_t,指定相关流;S 是一个可选参数,默认值为 0。
举例来说,一个函数的声明如下:
__global__ void Func(float* parameter);
必须通过如下方法来调用此函数:
Func>>(parameter);
执行配置的参数将在实际函数参数之前被评估,与函数参数相同,通过共享存储器同时传递给设备。
如果 Dg 或 Db 大于设备允许的最大大小(参见附录 A.1.1),或 Ns 大于设备上可用的共享存储器最大值,或者小于静态分配、函数参数和执行配置所需的共享存储器数量,则函数将失败。
回复

使用道具 举报

千问 | 2010-3-1 11:08:29 | 显示全部楼层

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

主题

0

回帖

4882万

积分

论坛元老

Rank: 8Rank: 8

积分
48824836
热门排行