热门标签 | HotTags
当前位置:  开发笔记 > IOS > 正文

使用cpuid提取缓存行大小的复制功能

如何解决《使用cpuid提取缓存行大小的复制功能》经验,为你挑选了1个好方法。

我检查了cpuid文档,发现了两种不同的记录方法来获取缓存行大小:

    eax = 0x04, ecx = $cache_level

这样,缓存行的大小$cache_level将存储EBX[11:0]在位

    eax = 0x80000006

这样,缓存行大小将存储在ECX[7:0]该位置,并且叶不依赖于缓存级别。

问题:向叶子添加缓存行大小信息的原因是什么0x80000006,为什么它不取决于缓存级别?我怀疑获取缓存行大小的“正确”方法是eax = 0x04, ecx = $cache_level



1> Brendan..:

英特尔和AMD(以及威盛和...)是不同的公司;而且(遗憾的是)没有涉及供应商中立的标准化机构,没有强迫供应商之间理智合作,也没有阻止供应商大肆破坏彼此的形象。

AMD创建“ CPUID,叶子0x80000006”时,他们做了一件容易的事-假定所有缓存的缓存行大小均相同,然后将其放入字段中。

但是(至少在理论上)每个不同的高速缓存都可以具有不同的“行大小”。因此,当英特尔创建“ CPUID,叶0x00000004”时,它们的作用是(理论上)每个不同的缓存都可以报告不同的“行大小”。

正确的方法是使杂乱无章的情况能够解决供应商的混乱情况。特别; 对于AMD CPU,如果可以的话,您希望使用“ CPUID,leaf 0x80000006”;对于Intel CPU(我认为是VIA CPU),如果可以的话,您希望使用“ CPUID,leaf 0x00000004”;对于所有您无法使用的情况(例如,因为CPU太旧而无法支持供应商的方法),您都会陷入另一大麻烦(例如,使用启发式方法和/或使用“ vendor:family:model:stepping”来查找)静态数据库中的信息)。

当然,最重要的是,您必须考虑勘误。这意味着要浏览大约一百个“规范更新”和“ BIOS和内核开发人员指南”,以查找是否/在何处需要“特殊情况下的解决方法”。

注1:如果您只关心高速缓存行大小,则上述所有内容都不太难。但是,您想要的信息越多,获取的信息就越糟(例如,如果您也关心每个缓存的大小,那么您应该会遇到大约10倍的麻烦和10倍的维护负担)。

注2:理想情况下,操作系统应提供“预先清理的CPU信息”;这样一来,只需要将其更新到一个位置即可,这样普通软件就无需处理毫无意义的“供应商差异”,勘误表,丢失的信息或合并的信息;并且CPUID禁止直接使用该说明(出于方便,正确和安全的原因)。不幸的是,没有现有的操作系​​统提供此功能。


推荐阅读
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • 配置Windows操作系统以确保DAW(数字音频工作站)硬件和软件的高效运行可能是一个复杂且令人沮丧的过程。本文提供了一系列专业建议,帮助你优化Windows系统,确保录音和音频处理的流畅性。 ... [详细]
  • 当iOS设备越狱后,某些插件可能会导致系统崩溃(白苹果)。此时,可以通过进入安全模式来排查并删除有问题的插件。本文将详细介绍如何通过特定按键组合进入不加载MobileSubstrate的安全模式,并提供相关背景知识。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文深入探讨了 Redis 的两种持久化方式——RDB 快照和 AOF 日志。详细介绍了它们的工作原理、配置方法以及各自的优缺点,帮助读者根据具体需求选择合适的持久化方案。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 优化版Windows 10 LTSC 21H2企业版:适用于低内存设备
    此版本为经过优化的Windows 10 LTSC 21H2企业版,特别适合低内存配置的计算机。它基于官方版本进行了精简和性能优化,确保在资源有限的情况下依然能够稳定运行。 ... [详细]
  • 理解存储器的层次结构有助于程序员优化程序性能,通过合理安排数据在不同层级的存储位置,提升CPU的数据访问速度。本文详细探讨了静态随机访问存储器(SRAM)和动态随机访问存储器(DRAM)的工作原理及其应用场景,并介绍了存储器模块中的数据存取过程及局部性原理。 ... [详细]
author-avatar
无梗啦_671
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有