`
insertyou
  • 浏览: 900785 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

【我所認知的BIOS】-->MTRR (MEMORY TYPE RANGE REGISTERS)

阅读更多

【我所認知的BIOS】-->MTRR

MEMORY TYPE RANGE REGISTERS

By LightSeed

2009-9-27

1MTRR的概念

内存类型范围寄存器(MTRRs,翻译过来真别扭,后面都以MTRR直接来说了)提供了一种机制,这种机制其实就是确定在系统内存中物理一段内存的类型。这个类型其实是正对CPU来说的,见图1

1 内存的类型

这些类型,其实是告訴CPU在解析或者说操作内存的时候应该用什么手段。就这么简单。为什么要这样做呢?一般情况下,内存都是应该是被设置为有cache来帮助CPU操作内存的,这样的话整个系统的效率就会比较高。但是某些设备所使用的内存却比较特殊,比如说Frame buffer就是一种很好的例子。那么软件(一般情况下是BIOS)就需要配置CPU的相关寄存来申明那些范围的内存在处理的时候需要做什么样的动作(这就是类型)。总的来说它们允许CPU优化不同类型的内存如RAMROM和帧缓冲内存(frame buffer),内存操作映射I / O设备。这种做法简化了内存控制系统的硬件设计引脚。

MTRR机制允许多达96个内存范围(memory ranges)在物理内存的定义,它定义了一系列的MSRs,这些寄存器分别去说明MSR定义中包含的那段内存的具体类型。图2MTRRs物理内存映射的示意图。

2 MTRRs物理内存映射示意

而每一段的内存可以被定义的类型有多个,见图3.

3 Memory Types That Can Be Encoded in MTRRs

硬件复位之后,P6及大多最近的处理器系列禁用所有的固定和可变MTRRs,这使得所有的物理内存的类型都成为了uncacheable。初始化软件应该依据系统定义的存储器映射设置MTRRs成特定的类型。典型的,BIOS(基本输入/输出系统)软件来配置MTRRs

在一个多处理器系统中,使用的P6系列或者较新的处理器系列,每个处理器必须使用相同的MTRR内存映射,从而使软件的内存有一致的视点。

2 MTRR Feature Identification

MTRR的功能可用性是模型具体。软件可以判定处理器上MTRRs是否支持。它只需要通过执行CPUID指令,读取的MTRR Flag的状态(EDXbit 12)状态。

如果MTRR标志被置为1(表明该处理器采用MTRRs),MTRRs的其他信息可以从64位的寄存器IA32_MTRRCAP中获得(MTRRcap MSRP6系列处理器的名字)。IA32_MTRRCAP MSR是一个只读的MSR,它可以用RDMSR指令读取。图4显示了IA32_MTRRCAP MSR的内容。

4 IA32_MTRRCAP Register

寄存器中的这些Flags和相应区域的功正如:

•VCNTvariable range registers count)区域(field),Bit0Bit7——表明的处理器的实施变量范围的数目。奔腾4,英特尔至强,和P6系列处理器有8个变量设置8 MTRRs的范围。

•FIXfixed range registers supported)标志(flag),Bit8 ——当被置1时,固定MTRRs的范围(IA32_MTRR_FIX64K_00000IA32_MTRR_FIX4K_0F8000)则支持;当被清零的时候,则表明没有固定的范围。

•WCwrite combining)标志(flag),Bit10 ——当被置1时写结合(WC)的内存类型支持;当被清零的时候,WC类型不支持清楚。IA32_MTRRCAP MSRBit9bit11~bit63是保留的。如果软件试图写入IA32_MTRRCAPMSR,一般保护异常(general-protection exception,#GP)将会发生。对于奔腾4,英特尔至强,和P6系列处理器,该IA32_MTRRCAP MSR始终是508H

3IA32_MTRR_DEF_TYPE MSR

IA32_MTRR_DEF_TYPE MSRP6系列处理器被命名为MTRRdefType MSR)设定的不被MTRRs包含的物理内存区域的默认属性。这个寄存器的标志(flag)及区域(field)的功能如下:

Type字段(field),bit0bit7——表明了,那么些没有被MTRR定义的物理内存段的默认内存类型。这些类型和MTRR定义的那些类型的种类是一模一样的。见图2。这个区域的逻辑值为01456。所有其他值都会触发一般保护异常(general-protection exception GP)。那些物理内存地址处如果没有实际内存存在的话,英特尔建议使用UDuncached)内存类型。给那些并不存在内存的地方分配UC的类型,那么我们可以指定这段内存要么是默认类型类型字段要么就是可变MTRRs分配的。

5IA32_MTRR_DEF_TYPE MSR示意图

5 IA32_MTRR_DEF_TYPE MSR

• FE (fixed MTRRs enabled)标志(flag),bit10——当置1时,固定范围MTRRs enabled,反之亦反。当固定范围MTRRs的启用时,他们较之于可变的MTRRS的有更高的优先级,所以他们的范围发生重叠的时候,那么fixed-range MTRRs则优先于variable-range MTRRs。如果在fixed-range MTRRsdisabled的,fixed-range MTRRs仍可使用,可以映射通常由固定的范围MTRRs覆盖范围。

• E (MTRRs enabled)标志(flag),bit11——当它置1时,MTRRs被启用,当被清零时,所有MTRRs被禁用,并且UC内存类型适用于所有的物理内存。当此标志被置1FE标志可以禁用固定范围MTRRsfixed-range MTRRs),当被清零时,是FE标志不会有影响。当E标志置1时,图5中“default memory type field”里包含的具体类型是指那些没有被固定的或者可变的MTRR分配的内存的类型。

IA32_MTRR_DEF_TYPE Bit8bit9bit12bit63是保留的,如果软件尝试写入非零值给他们处理器触发一个一般保护异常(general-protection exceptionGP)。

4Fixed Range MTRRs

Fixed memory ranges是由1164位的fixed memory ranges位寄存器来做到映射的。这些寄存器都是被分为8bits的区域(field)的,这个区域用来指定每个区域所控制的内存段的内存类型(memory type):

寄存器IA32_MTRR_FIX64K_00000——映射从0H7FFFFH512Kbyte的地址范围。此范围被分为864Kbyte子区间。

寄存器IA32_MTRR_FIX16K_80000,IA32_MTRR_FIX16K_A0000——映射2128Kbyte的地址范围,从80000HBFFFFH 。此范围被分为1616Kbyte的子区间,每个寄存器有8个范围。

寄存器IA32_MTRR_FIX4K_C0000IA32_MTRR_FIX4K_F8000 ——映射从C0000HFFFFFH 8 32Kbyte的地址范围。此范围分为64 4KB的子区间,每个寄存器有8个范围。

6显示了固定的物理地址范围和固定范围MTRRs相应领域的关系

6 Address Mapping for Fixed-Range MTRRs

fixed memory ranges的内存类型正是图3所示的类型。

对于六系列处理器,fixed memory ranges前缀是MTRRfix

5Variable Range MTRRs

奔腾4,英特尔至强,和P6系列处理器允许软件,用每个范围的MTRRs对来指定8 variable-size address ranges的内存类型。每对寄存器的第一项定义为基地址和范围内存类型(IA32_MTRR_PHYSBASEn),第二项包含用来确定地址范围的掩码

IA32_MTRR_PHYSMASKn)。字母“N”后缀表示,寄存器对的序号0~7 P6系列处理器,Variable Range MTRRs的前缀是MTRRphysBaseMTRRphysMask

7IA32_MTRR_PHYSBASEn and IA32_MTRR_PHYSMASKn Variable-Range Register Pair的示意图,展示了这些寄存器的标志和区域。

7 IA32_MTRR_PHYSBASEn and IA32_MTRR_PHYSMASKn Variable-Range Register Pair

这些标志(flag)和字段(field)的职能是:

•Type字段(field),bit0bit7——指定的范围内存类型(见图3所示)。

•PhysBase字段(fieldbit12到(MAXPHYADDR - 1)——地址的范围内基址。如果MAXPHYADDR36位,那么这24位值,扩展低端12位形成24位,从而形成基地址(它会自动对齐4KB的边界地址)。

PhysMask字段(field),bit12到(MAXPHYADDR - 1)——指定一个掩码(如果最大的物理地址大小为36位那么掩码就是24位,如果最大的物理地址大小为40位那么掩码就是28位)。掩码决定了该区域范围内被映射,按照下列关系:

Address_Within_Range AND PhysMask = PhysBase AND PhysMask


——掩码会被扩展到低端的12bit,从而形成掩码的值。如果想要了解更加细致点的话,参阅后面的章节。

——PhysMask的字段宽度取决于处理器能够支持的最高的物理地址的大小。 CPUID.80000008H反应了CPU能够支持的最大物理地址。如果CPUID.80000008H无效的话,那么软件可以假设CPU能够支持36 bit的物理地址。(于是PhysMask就是24bit宽,IA32_MTRR_PHYSMASKn的高28bit被保留。详细可见图7

•V (valid)标志(flag),bit11——当被置1时,上面提到的寄存器对有效,反之亦反。

所有IA32_MTRR_PHYSBASEnIA32_MTRR_PHYSMASKn寄存器的其他位均保留,如果软件试图写这些位置,处理器产生一个一般保护异常(general-protection exceptionGP)。

一些掩码值可能导致范围是不连续的。在这样的范围内,掩码值并没有映射区域,那么它将被设置为默认的内存类型。英特尔不鼓励不连续范围使用,因为它们可能要求的整个4 GByte物理内都存在,而且从头到尾被映射。如果没有提供内存,那么这个行为将是不确定的。

6Example Base and Mask Calculations

本节中的例子适用的处理器,可以支持最高36位物理地址的大小。variable-range MTRR对的基地址和掩码的值是24位值,然后处理器自动扩展(低12bit)到36位。

6.1示例1:单独确定一段内存属性

例如,要输入一个基地址为2 Mbytes200000H)到IA32_MTRR_PHYSBASE3 寄存器中去,最低12有效位会被截断,从而形成的值是000200H 作为基地址被存入PhysBase字段。掩码值也是同样的操作被存入的。例如,从200000H映射地址范围3FFFFFH2 Mbytes4 Mbytes),那么这个掩码的值是FFFE00000H。由于和base的操作是一样的,那么实际被存入到IA32_MTRR_PHYSMASK3PhysMask字段中的值是FFFE00H。当任何200000H地址3FFFFFH范围内的内存地址与掩码值AND(与操作)后,它将返回与基地址掩码值AND(与操作)相同的值(200000H)。

同理,映射从400000H 7FFFFFH地址范围(4 Mbytes8 Mbytes),应该填入的基地址值是000400H,掩码值应该是FFFC00H

6.2示例2:给系统内存配置类型

我们假设有这样一个系统,需要它的内存有以下的特征:

系统内存96 MBytes被映射为 write-back memory WB)的类型,因为这样的性能最高。

自定义4 Mbytes I / O卡被映射到内存的64兆字节的基地址处,而且它们的属性应该是uncached memory (UC)。这个限制导致了本应该是96 Mbytes的系统内存被分成了从064 Mbytes处理,和从68 Mbytes100 Mbytes,从而因为I / O卡的原因,造成了一个4 Mbytes的洞(hole)。

一个8 Mbytes的显卡映射到A0000000H开始的地址处,它的内存属性是write-combiningWC)。

•BIOS区域从15 Mbytes16 Mbytes,并且被定义为UC内存。

下面就是它们分别对应的基地址和掩码寄存器的值:

IA32_MTRR_PHYSBASE0 = 0000 0000 0000 0006H

IA32_MTRR_PHYSMASK0 = 0000 000F FC00 0800H

Caches 0-64 MByte as WB cache type.

1Mbytes = 10 0000HFC00 0800H扩展后是FC00 0000H然后再取反的3FF FFFFH= 64MByte

IA32_MTRR_PHYSBASE1 = 0000 0000 0400 0006H

IA32_MTRR_PHYSMASK1 = 0000 000F FE00 0800H

Caches 64-96 MByte as WB cache type.

基地址:将0000 0000 0400 0006H扩展后是 0400 0000H可知是64 Mbytes

掩码:将FE00 0800H扩展后是FE00 0000H然后再取反的1FF FFFFH= 32MByte

IA32_MTRR_PHYSBASE2 = 0000 0000 0600 0006H

IA32_MTRR_PHYSMASK2 = 0000 000F FFC0 0800H

Caches 96-100 MByte as WB cache type.

FFC0 0800H扩展后是FFC0 0000H然后再取反的3F FFFFH= 4MByte。后面以此类推。

IA32_MTRR_PHYSBASE3 = 0000 0000 0400 0000H

IA32_MTRR_PHYSMASK3 = 0000 000F FFC0 0800H

Caches 64-68 MByte as UC cache type.

IA32_MTRR_PHYSBASE4 = 0000 0000 00F0 0000H

IA32_MTRR_PHYSMASK4 = 0000 000F FFF0 0800H

Caches 15-16 MByte as UC cache type.

IA32_MTRR_PHYSBASE5 = 0000 0000 A000 0001H

IA32_MTRR_PHYSMASK5 = 0000 000F FF80 0800H

Caches A0000000-A0800000 as WC type.

以上就是目前我對MTRR的認知,可能會有人會問,爲什麽你要說到MTRR這個東西呢?主要還是因為系統性能的原因。(咦,這和系統的性能有何聯繫呢?)內存,不的不說它是整個系統的重要原件。因為我們的CPU再解析他的時候依據屬性的不一樣,速度和安全性會不太一樣。在我們的主板上,曾經就遇到過這樣的問題,由於AWXXX code的原因,對某些chipset的支持不夠好,所以在配置Frame buffer的時候出了點小問題,當Frrame buffer8M的時候,code會因為算法的原因把其餘一部份系統佔用的內存屬性配置成了UC(這種方式很可靠,但是效率和性能卻最差)。然而系統的內存一般為了能夠提高性能一般都是配置的WB(這種方式性能是最好的。)由於本應該是WB的內存類型,被配置成了UC,所以會直接影響整個系統的性能。如果您不信,您可以試試。(不過,算法挺複雜的。-_-~

分享到:
评论

相关推荐

    mtrr.rar_mtrr_range

    MTRR,全称为Memory Type Range Register,是CPU中一种重要的硬件特性,用于控制内存的存储类型和访问速度,进而优化系统的性能。在现代计算机系统中,尤其是在服务器和高性能计算领域,MTRR扮演着至关重要的角色。...

    Bochs - The cross platform IA-32 (x86) emulator

    [2884071] [AIX host] prefetch: EIP [00010000] > CS.limit [0000ffff] [3053542] 64 bit mode: far-jmp instruction is error [3011112] error compile vs2008/2010 with X2APIC [3002017] compile error with...

    mtrr.rar_mtrr

    内存类型范围寄存器(Memory Type Range Register,MTRR)是CPU中用于管理内存访问特性的硬件机制,尤其在处理内存的缓存策略时起着关键作用。MTRR允许系统管理员或软件工具(如这个`mtrr.rar_mtrr`程序)自定义内存...

    AMI BIOS代码详解

    **4E** - 开始处理MTRR(Memory Type Range Registers)设置,用于优化内存性能。 **50** - USB设备的初始化,确保所有USB接口上的设备都能够正常工作。 **52** - 初始化USB控制器,确保USB设备能够被系统识别。 ...

    RTLinux3.2在Redhat9上安装教程

    - MTRR (Memory type range register) - Symmetric mulit-processing support(如果你的系统支持多处理器) - General setup > Direct PCI access mode - Advanced Power Management BIOS support(如果你的硬件...

    mtrr.rar_V2

    在Linux操作系统中,MTRR(Memory Type Range Register)是一项重要的技术,它允许我们对内存区域进行类型定义,从而优化CPU对内存的访问性能。"mtrr.rar_V2"是一个包含相关函数库和文档的压缩包,用于Linux内核v...

    mtrr.rar_Scoring

    2. **mtrr.c** - "MTRR"通常代表Memory Type Range Register,这是x86架构CPU中用于管理内存性能的特性。在这个上下文中,可能是指与trellis量化相关的内存优化或特定处理。 3. **mutex.pass.c** 和 **mutex_list.c...

    性能优化技术

    MTRR(Memory Type Range Register)是Intel P6系列及后续处理器中用于控制内存区域访问特性的机制,其主要目的是提升处理器对内存的访问效率,特别是在处理基于PCI或AGP总线的视频卡(VGA)时。 MTRR的主要功能之...

    cpu-bugs64.rar_Free!_centaur

    描述中提到的"centaur get free region - Get a free MTRR for Linux v2.13.6."揭示了主要的内容是关于Centaur CPU如何在Linux操作系统中获取并利用未使用的内存地址范围(Memory Type Range Register, MTRR)。MTRR...

    电信设备-MTRR基因多态性快速检测的引物、分子信标、试剂盒及其检测方法[1].zip

    《电信设备-MTRR基因多态性快速检测的引物、分子信标、试剂盒及其检测方法》 在生物学和医学研究领域,基因多态性是生物多样性的重要表现,它影响着个体对环境和药物的反应。MTRR(Methionine Synthase Reductase)...

    电信设备-MTRR基因多态性快速检测的引物、分子信标、试剂盒及其检测方法.zip

    《电信设备-MTRR基因多态性快速检测的引物、分子信标、试剂盒及其检测方法》 本文档主要探讨的是MTRR(Methionine Synthase Reversible Homocysteine Methyltransferase)基因的多态性检测技术在电信设备领域的应用...

    BIOS POST Code Introduction.ppt

    BIOS POST Code Introduction POST(Power-On Self Test)代码是计算机启动过程中由基本输入输出系统(BIOS)生成的一种诊断工具。它在计算机加电后执行一系列自我测试,以确保硬件组件正常工作。POST代码是一种...

    DIMM SPD Definition

    文件还提到了BIOS中的一些其他概念,比如PCI(Peripheral Component Interconnect,外围组件互连)总线、SM bus(System Management Bus)、Super IO、MTRR(Memory Type Range Registers)以及SMM(System ...

    查看opensuse硬件信息

    flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 syscall nx mmxext fxsr_opt rdtscp lm 3dnowext 3dnow constant_tsc up rep_good nopl tsc_reliable...

    A functional variant in MTRR intron-1 significantly increases risk of congenital heart disease in Han Chinese population

    MTRR内含子上的基因多态性显著提高中国汉族人群的先天性心脏病易感性,赵健元,杨雪艳,同型半胱氨酸是先天性心脏病的独立风险因子。在早期胚胎发育过程中甲硫氨酸合成还原酶(MTRR)催化的同型半胱氨酸甲基化成甲...

    Linux下如何查看CPU信息__包括位数和多核信息

    MCE (Machine check exception) CX8 (CMPXCHG8 instruction supported) APIC (On-chip API Chardware supported) SEP (Fast system call) MTRR (Memory type range registers) PGE (Page global enable) MCA ...

    嵌入式linux系统的裁剪,文件系统的制作和组织引导盘,很好的东西

    - **MTRR**:MTRR (Memory Type Range Register) 支持对于PCI或AGP总线上的设备性能提升有所帮助。对于现代嵌入式设备,尤其是那些包含图形加速器的设备,推荐启用此选项。 - **对称多处理(Symmetric Multi-...

    Linux proc目录下子文件或子文件夹的作用

    - **功能**: 显示系统使用的Memory Type Range Registers (MTRRs)。 - **用途**: 用于配置内存类型的优化,特别是在老式系统中。 23. **/proc/partitions** - **功能**: 显示分区中的块分配信息。 - **用途**:...

    mtrr.rar_The Guard

    Do not use an include-guard. This file is included once to declare the locks and once in win32 to actually do the runtime initialization.

    convert_move.rar_after

    2. **mtrr.c**: MTRR(Memory Type Range Register)是x86架构中用于控制内存区域类型和性能的硬件特性。这个文件可能包含与操作系统内核交互,设置或管理MTRR相关的代码,以优化CPU对内存的访问和缓存策略。 3. **...

Global site tag (gtag.js) - Google Analytics