cpu时钟预取实例代码分享

时间:2021-05-22

测试下预取的效果,利用CPU始终查看效果。根据实验发现,预取地址在地址使用之前的十行左右代码处效果比较好!

复制代码 代码如下:
#include <stdio.h>

#define MAX_LEN 1000000

static inline void prefetchnta(void *addr) //预取部分
{
__asm__("movl %0, %%eax"::"a"(addr));
__asm__(".byte 0x0f, 0x18, 0x00");
}

inline unsigned long long GetCPUTickCount()
{
unsigned long high32 = 0;
unsigned long low32 = 0;

__asm__("RDTSC" : "=a"(low32), "=d"(high32));

unsigned long long counter = high32;
counter = (counter<<32) + low32;

return counter;
}

int main(int argc, char* argv[])
{
long long start, end;
long long array[MAX_LEN];
int i;

for(i = 0; i < MAX_LEN; i++) //让cache失效
array[i]++;

start = GetCPUTickCount();
array[0]++;
end = GetCPUTickCount();
printf("don't use prefetch time:%ld\n", end - start);


for(i = 0; i < MAX_LEN; i++)
array[i]++;

prefetchnta(array);
start = GetCPUTickCount();
array[0]++;
end = GetCPUTickCount();
printf("use prefetch time:%ld\n", end - start);

return 0;
}

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章