微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

超线程如何影响缓存?

如何解决超线程如何影响缓存?

我在使用Hyper-Threading的时候,出现了一个很奇怪的现象。我是用c语言来测量l2 hit的时间的。我在程序 A 中编写了测试时间。当我单独运行它时,它显示每次大约需要 26 cycles。当我写另一个程序 B. 将 BA 绑定到同一个内核并以超线程的形式运行。即使只写了一个无用的循环在 B 中,例如:

for(;;){
}

我发现,在这种情况下,当我再次运行程序 A 时,显示L2 hit 时间变成了大约 10

代码很长。测试的伪代码如下所示。

A:

    Select 16 cache lines (line 0 -16)in a set.  // l1 cache is VIPT structure
    Organize the disordered sequence of line0 to line8 into a linked list to prevent prefetching.
    Organize the disordered sequence of line9 to line15 into a linked list to prevent prefetching.
    load line 0 - 8   //Because it is a linked list,it is read serially
    fence()
    t1= rdtscp()
    load line 9 - 15  //Because it is a linked list,it is read serially
     t2 = rdtscp()
    print t2 - t1

B : for(;;){
}

只有A在运行时,输出结果平均为200。当 B 和 A 以相同的核心超线程运行时,A 的输出结果为 90。

如果超线程的效果让时间变长,我可以理解,可能是干扰,但时间变短的原因是什么?

我的服务器配置如下:

 Linux version 4.15.0-122-generic (buildd@lcy01-amd64-010) (gcc version 5.4.0 20160609 (Ubuntu 5.4.0-6ubuntu1~16.04.12)) #124~16.04.1-Ubuntu SMP

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。