加入收藏 | 设为首页 | 会员中心 | 我要投稿 辽源站长网 (https://www.0437zz.com/)- 云专线、云连接、智能数据、边缘计算、数据安全!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

linux – 英特尔处理器如何访问Branch Trace Store缓冲区?

发布时间:2021-01-10 18:13:40 所属栏目:Linux 来源:网络整理
导读:英特尔处理器具有分支跟踪存储(BTS)功能,可记录分支并将其存储在用户/程序指定的缓冲区中.事实上,我想知道处理器是通过MMU单元(页面表)访问BTS缓冲区还是直接物理访问BTS缓冲区? 解决方法 从 Intel Manual Volume 3,Chapter 17.4.9 (BTS and DS Save Area)

英特尔处理器具有分支跟踪存储(BTS)功能,可记录分支并将其存储在用户/程序指定的缓冲区中.事实上,我想知道处理器是通过MMU单元(页面表)访问BTS缓冲区还是直接物理访问BTS缓冲区?

解决方法

从 Intel Manual Volume 3,Chapter 17.4.9 (BTS and DS Save Area)开始,32位版本的Debug Store区域的图像

BTS buffer base — Linear address of the first byte of the BTS buffer. This address should point to a natural doubleword boundary.

以及IA32_DS_AREA MSR

Write the base linear address of the DS buffer management area into the IA32_DS_AREA MSR.

通常,您设置到处理器的每个地址都是一个线性地址,因此它与所设置的段无关,因此只有在激活时才会进行分页.
当然,只有在不创建递归依赖的情况下才会这样,例如CR3寄存器.

直接回答你的问题:如果激活了分页,则转换给定的地址,否则按原样使用.

(编辑:辽源站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读