一 cuda
cute 之 Swizzle - 知乎 (zhihu.com)
1.1 局部性原理和Shared Memory
由于Shared Memory是为线程块服务的,所以其必须能支持线程块内的线程并行的对其进行访问(包含数据读取和写入),为了保障Shared Memory存储结构在多线程并发读写下的效率(更低的Latency和更高的Throughput),其硬件被实现为多bank的模式,每个bank都是可以独立寻址的存储空间,bank之间可以并行的读写数据,相互之间不会影响。在NVidia的架构中,shared memory包含32个bank,bank中可寻址的基本单元为4byte,如图1所示,每个bank为黑框所包含的单元,用户看到的地址空间为箭头所示的方向,即相邻的4byte占用不同的bank。如图2,当32个线程同时访问32个不同的bank时,各个bank是并行执行的,其效率是最高的,即32个线程并发的访问32个bank中不同颜色的单元,是可以并行的,值得注意的是其中的线程编号(如图2中的T0所示&#