首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >sm_20显示错误的lmem统计数据?

sm_20显示错误的lmem统计数据?
EN

Stack Overflow用户
提问于 2011-02-24 06:52:39
回答 1查看 764关注 0票数 1

使用--ptxas-options=-v选项编译的CUDA内核似乎在指定 GPU体系结构时显示错误的sm_20 lmem(本地内存)统计信息。同样,在sm_10 / sm_11 / sm_12 / sm_13体系结构中也提供了有意义的lmem统计信息。

有人能澄清sm_20 lmem统计数据是否需要以不同的方式读取,或者它们是完全错误的?

下面是内核:

代码语言:javascript
复制
__global__ void fooKernel( int* dResult )
{
        const int num = 1000;
        int val[num]; 

        for ( int i = 0; i < num; ++i )
        val[i] = i * i; 

        int result = 0; 

        for ( int i = 0; i < num; ++i )
        result += val[i]; 

        *dResult = result;

        return;
}

--ptxas-options=-vsm_20报告:

代码语言:javascript
复制
1>ptxas info    : Compiling entry function '_Z9fooKernelPi' for 'sm_20'
1>ptxas info    : Used 5 registers, 4+0 bytes lmem, 36 bytes cmem[0]

--ptxas-options=-vsm_10 / sm_11 / sm_12 / sm_13报告:

代码语言:javascript
复制
1>ptxas info    : Compiling entry function '_Z9fooKernelPi' for 'sm_10'
1>ptxas info    : Used 3 registers, 4000+0 bytes lmem, 4+16 bytes smem, 4 bytes cmem[1]

sm_20报告了一个lmem的4字节,如果您看到内核中使用的4x1000字节数组,这是完全不可能的。旧的GPU体系结构报告正确的4000字节 lmem统计量。

这是在CUDA 3.2上进行的。我已经提到了打印代码生成统计信息部分( NVCC手动 (v3.2) ),但它无助于解释这种异常。

EN

回答 1

Stack Overflow用户

发布于 2011-02-24 12:39:28

编译器是正确的。通过巧妙的优化,不需要存储数组。实际上,您所做的是计算result += i * i,而不将临时代码存储到val

查看生成的ptx代码不会显示sm_10与sm_20之间的任何区别,用decuda对生成的cubins进行反编译将显示优化。

顺便说一句:尽量避免本地记忆!它和全球记忆一样慢。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5101355

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档