[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

CN101292228B - 转换后备缓冲器的锁定指示符 - Google Patents

转换后备缓冲器的锁定指示符 Download PDF

Info

Publication number
CN101292228B
CN101292228B CN2006800388152A CN200680038815A CN101292228B CN 101292228 B CN101292228 B CN 101292228B CN 2006800388152 A CN2006800388152 A CN 2006800388152A CN 200680038815 A CN200680038815 A CN 200680038815A CN 101292228 B CN101292228 B CN 101292228B
Authority
CN
China
Prior art keywords
tlb
layer
subclauses
clauses
processor
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN2006800388152A
Other languages
English (en)
Other versions
CN101292228A (zh
Inventor
维克托·罗伯茨·奥格斯堡
詹姆斯·诺里斯·迪芬德尔费尔
杰弗里·托德·布里奇斯
托马斯·安德鲁·萨托里乌斯
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Qualcomm Inc
Original Assignee
Qualcomm Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Qualcomm Inc filed Critical Qualcomm Inc
Publication of CN101292228A publication Critical patent/CN101292228A/zh
Application granted granted Critical
Publication of CN101292228B publication Critical patent/CN101292228B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/10Address translation
    • G06F12/1027Address translation using associative or pseudo-associative address translation means, e.g. translation look-aside buffer [TLB]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/12Replacement control
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/06Addressing a physical block of locations, e.g. base addressing, module addressing, memory dedication
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/10Address translation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/12Replacement control
    • G06F12/121Replacement control using replacement algorithms
    • G06F12/126Replacement control using replacement algorithms with special data handling, e.g. priority of data or instructions, handling errors or pinning
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/68Details of translation look-aside buffer [TLB]
    • G06F2212/681Multi-level TLB, e.g. microTLB and main TLB

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Memory System Of A Hierarchy Structure (AREA)

Abstract

本发明涉及一种包括分层转换后备缓冲器(TLB)的处理器,所述分层转换后备缓冲器包含层1 TLB和小且高速的层0 TLB。所述L0 TLB中的条目复制所述L1 TLB中的条目。所述处理器在地址转换中首先存取所述L0 TLB,且如果虚拟地址在所述L0TLB中未命中,那么存取所述L1 TLB。当所述虚拟地址在所述L1 TLB中命中时,将所述虚拟地址、物理地址以及页属性写入到所述L0 TLB,如果所述L0 TLB已满,那么替换现有条目。可响应于所述L1 TLB条目中的L0锁定(L0L)指示符,而在所述L0TLB中锁定所述条目以防替换。类似地,在硬件管理的L1 TLB中,可响应于在对应页表条目中的L1锁定(L1L)指示符来锁定条目以防替换。

Description

转换后备缓冲器的锁定指示符
技术领域
本发明一般涉及处理器领域,且明确地说涉及一种锁定一个或一个以上转换后备缓冲器中的条目以防替换的系统和方法。
背景技术
微处理器在各种应用(包括便携式电子装置)中执行计算任务。在大多数情况中,将处理器性能最大化是主要的设计目标,以准许在便携式电子装置和其它应用中实施额外的功能和特征。同样,在许多应用中,一些计算任务具有优先其它任务的优先级,且对于系统来说保证将计算资源保留用于高优先级任务将是有利的。
许多程序的写入都仿佛执行程序的计算机具有极大量的(理想的,无限的)快速存储器。大多数的现代处理器通过采用存储器类型的层次结构来模拟这种理想条件,每个存储器类型具有不同的速度和成本特性。所述层次结构中的存储器类型从位于顶部处的极快且极贵的存储类型变化为位于低层中的逐渐减慢但是更为经济的存储类型典型的处理器存储器层次结构可包含:位于顶层处的处理器中的寄存器(门);辅之以一个或一个以上芯片上高速缓存器(SRAM);可能有芯片外高速缓存器(SRAM);主存储器(DRAM);磁盘存储装置(带电磁存取的磁媒体);及位于最低层的磁带或CD(磁媒体或光学媒体)。大多数便携式电子装置具有有限的(如果有)磁盘存储装置,且因此主存储器(通常大小有限)在存储器层次结构中的最低层。
在计算机存储器层次结构中,每个低层均维持驻留在高层级中的数据的完整(但可能失效)拷贝。即,存储在高层中的数据复制低层中的数据。由于较小的高层存储装置可映射到较大的低层存储器中的多个位置,因此需要映射方案,以在层次结构的层级之间转换地址。大多数处理器在极大的、概念上连续的虚拟地址空间中操作。主存储器的存取在由硬件和系统参数约束的物理地址空间中进行。置于处理器核心与主存储器之间的高速缓存器(高速存储器)可完全通过虚拟地址、完全通过物理地址或组合方式(例如通过使用虚拟索引和物理标签)来存取。然而,无论高速缓存器的配置如何,必须将地址由虚拟地址空间转换到物理地址空间。
许多大的虚拟地址空间(每个正在运行的程序或上下文一个空间)映射和转换到一个有限的物理存储器地址空间被称为存储器管理。由操作系统进行的存储器管理通过防止程序盖写彼此的数据来确保适当的性能;通过禁止一个用户存取另一个用户的数据来提供安全性;及通过禁止用户层程序存取管理程序层数据结构(例如操作系统分配表和参数)来提升可靠性。
可以称为页的固定大小段为单位来管理存储器,所述页可(例如)包含4K字节。一个地址的上部、或最高有效部分称为页号,其识别特定的存储器页。所述页号从虚拟地址空间转换到物理地址空间。所述地址的较低或最低有效部分称为页偏移,是页内偏移,对于虚拟地址和物理地址都是相同的;页偏移位不进行转换。作为实例,对于4K页的32位地址,页号将包含地址位[31:12]和页偏移位[11:0]:
Figure S2006800388152D00021
                      表1:地址的页字段
在一个或一个以上称为页表的数据结构中由操作系统软件控制虚拟页号到物理页号的映射。页表可以是单个表,或分层或树状的系列表,每一表将虚拟页号的一部分或段映射到物理存储器的对应范围。另外,页表还存储所述物理页的属性,例如读取、写入及执行许可,所述页是共享还是由单个过程专用,等等。最初,处理器必须“漫步”,或遍历页表来将新的虚拟地址转换到对应的物理地址,以存取主存储器(或高速缓存存储器,如果其进行了物理索引或标记)。通过将虚拟页号和物理页号以及页属性存储在TLB中,可加速后续地址转换。TLB可存储用于数据页和指令页两者的地址转换和页属性。另外,可包含一子组统一TLB的指令TLB(ITLB)可单独地存储用于指令的地址转换和页属性。
TLB可包含内容可寻址存储器(CAM)和相关联的随机存取存储器(RAM),每一者均具有固定数目的条目,例如32、64或128。CAM执行经呈现用于转换的虚拟页号与所有经存储的先前已转换虚拟页号的平行比较。CAM的输出是匹配所施加虚拟页号的经存储的虚拟页号的位置。所述位置对RAM进行索引,所述RAM提供对应于所述虚拟页号的经存储的物理页号,以及页属性。施加到高速缓存器及/或主存储器的物理地址然后是从TLB检索且并置有来自虚拟地址的页偏移的物理页号。
当呈现新的虚拟页号进行转换时,会发生TLB未命中,且处理器必须遍历页表来执行转换。当页表漫步完成时,虚拟页号和物理页号以及页属性被存储在TLB中的空位置中。如果TLB已满,那么必须用新条目替换现有条目。在所属技术领域中已熟知各种替换算法,例如随机算法、循环算法、最近未使用算法、先进先出(FIFO)算法、第二次机会FIFO算法、最近最少使用算法、不常使用算法、老化算法等等。对于与关键任务相关联的存储器页,许多TLB实施方案允许操作系统锁定一个或一个以上TLB条目以防替换,以确保所述条目始终驻留在所述TLB中以针对所述关键任务执行快速转换。当必须替换TLB条目时,已锁定的TLB条目不参与TLB替换算法。然而,并不是所有处理器指令集合均包括TLB管理指令,例如用于锁定TLB条目以防替换的指令。在这些情况中,所述TLB由硬件管理,且操作系统可能缺少直接锁定TLB条目的方式。
对于更高的性能,处理器可包括具有(例如)4、8或16个条目的较小但更快的TLB,所述TLB称为层0或L0 TLB(其中主TLB称为层1或L1 TLB)。在所属技术领域中,L0 TLB又称为微TLB。L0 TLB利用大多数程序的时间和空间局部性原理来存储较少的最近最常使用的地址转换,以便可再次提取来自最近被存取的存储器页的指令或数据。为了转换虚拟地址,处理器首先向L0 TLB呈现所述虚拟页号。如果所述虚拟页号在L0 TLB中命中,那么提供对应的物理页号和页属性。如果所述虚拟页号在L0 TLB中未命中,那么向L1 TLB呈现所述虚拟页号以进行转换。
通常,L0 TLB是硬件实施方案,其不由软件辨识或不直接受软件控制。即,软件不能直接读取和写入L0 TLB条目;L0 TLB的管理由硬件执行。这种情况的一个后果是操作系统不能将L0 TLB中的条目指定为被锁定以防替换。锁定一个或一个以上L0 TLB条目以防替换的能力将是有利的,因为其将确保最快的转换始终可用于关键任务。
发明内容
在一个实施例中,对于硬件管理的L1 TLB,页表条目包括指示符,例如L1锁定(L1L)位,所述指示符指示当对应的条目存储在L1 TLB中时是否应对其进行锁定以防替换。在另一实施例中,如果L1 TLB由操作系统管理(且包括锁定条目的能力),那么L1 TLB条目包括指示符,例如L0锁定(L0L)位,所述指示符指示当所述条目存储在L0 TLB中时是否应对其进行锁定以防替换。在此实施例中,当虚拟地址在L0 TLB中未命中而在L1 TLB中命中时,将所述虚拟地址、物理地址及页属性写入到L0 TLB。响应于L1 TLB条目中的L0L位,在L0 TLB中锁定所述条目以防替换或不锁定。
一个实施例涉及一种管理分层转换后备缓冲器(TLB)的方法。将来自上层TLB的条目复制到低层TLB。响应于上层TLB条目中的指示符,将所述低层TLB中的条目锁定以防替换。
另一实施例涉及一种处理器。所述处理器包括指令执行管线和分层转换后备缓冲器(TLB),所述分层转换后备缓冲器包含高层TLB和低层TLB。低层TLB中的条目复制高层TLB中的条目。所述处理器还包括TLB控制器,所述TLB控制器操作以便在地址转换中首先存取低层TLB,且如果在低层TLB中没有找到匹配的条目,那么存取高层TLB。所述控制器进一步操作以响应于高层TLB中对应的条目中的指示符来锁定低层TLB中的条目。
另一实施例涉及一种在处理器中将虚拟地址转换到物理地址的方法。执行存储器存取指令以产生虚拟地址。使用所述虚拟地址的一部分来存取层0转换后备缓冲器(L0TLB)。如果所述虚拟地址在L0 TLB中未命中,那么使用所述虚拟地址的一部分来存取层1TLB(L1 TLB)。如果所述虚拟地址在L1 TLB中命中,那么从L1 TLB获得物理地址的一部分和页属性,检查L1 TLB条目中的层0锁定(L0L)指示符,将所述虚拟地址的一部分、所述物理地址的一部分以及所述页属性作为条目写入L0 TLB中,并响应于L0L指示符将所述L0 TLB条目锁定以防替换。
另一实施例涉及一种管理转换后备缓冲器(TLB)的方法。当TLB未命中虚拟地址时,执行页表漫步以获得对应的物理地址和锁定指示符。将包含至少所述虚拟地址和物理地址的条目写入到所述TLB。响应于所述锁定指示符,将所述TLB中的条目锁定以防替换。
附图说明
图1是L0 TLB、L1 TLB及页表的功能框图。
图2是描绘L0 TLB中的条目锁定的功能框图。
图3是处理器的功能框图。
图4是虚拟地址到物理地址转换的流程图。
具体实施方式
图1是描绘L0 TLB 100、L1 TLB 102以及页表104的功能框图。L0 TLB 100和L1 TLB 102是处理器中的电路,而页表104是存储器中的逻辑数据结构。向L0 TLB 100呈现虚拟地址或虚拟地址的一部分(例如页号)。如果所述虚拟地址命中,那么L0 TLB100提供对应的物理地址和页属性,且高速缓存器或主存储器存取可继续。这是最快的地址转换,且因此优选用于高性能。
如果所述虚拟地址在L0 TLB 100中未命中,那么存取L1 TLB 102。由于L1 TLB102的大小较大,所以其存取花费的时间长于L0 TLB 100的存取。如果所述虚拟地址在L1 TLB 102中命中,那么提供对应的物理地址和页属性,并将所述对应的物理地址和页属性写入到L0 TLB 100,以根据L0 TLB 100操作所遵循的任何替换算法来替换L0 TLB 100中的现有条目。
如果所述虚拟地址在L1 TLB 102中未命中,那么存取页表104以断定虚拟到物理的映射。尽管在图1中描绘为单个功能方块,但页表104可包含嵌套数据结构中的多个页表,且全页表104遍历可包含若干迭代存取。当页表104遍历完成时,将物理地址和页属性写入到L1 TLB 102,如有必要,那么根据当前操作的替换算法来替换现有的L1 TLB 102条目。如果在页表104中没有找到地址转换信息,那么产生错误。
在页表104漫步和将条目写入到L1 TLB 102之后,可再执行产生地址转换的指令,且所述虚拟地址将在L0 TLB 100中未命中而在L1 TLB 102中命中。L1 TLB 102提供物理地址和页属性,所述物理地址和页属性与虚拟地址一起作为条目写入到L0TLB 100中。在一些实施方案中,可在页表漫步完成时与将条目写入到L1 TLB平行地将物理地址和页属性直接写入到L0 TLB。这在图1中由虚线来指示。
当虚拟地址在L0 TLB 100中未命中而在L1 TLB 102中命中时,将条目写入到L0TLB 100。如果L0 TLB 100已满,那么必须替换条目。能够锁定L0 TLB 100中的一个或一个以上条目以防替换将是有利于确保某些关键任务的最大性能。然而,在现有技术的处理器中,操作系统软件不能直接存取L0 TLB 100,且无法规定应将哪些或任何L0 TLB 100条目锁定以防替换。对于硬件管理的L1 TLB也发生类似的情形,其中操作系统无法锁定L1 TLB条目以防替换。
根据一实施例,将L0锁定或L0L指示符添加到L1 TLB 102条目。L0L指示符可包含(例如)1个位。L0L位的状态向处理器传达是否应在L0 TLB 100中锁定所述条目以防替换。可将L0L位与页属性一起维持在页表104中。或者,在操作系统将条目直接写入到L1 TLB 102的实施方案中,软件可在创建和存储TLB 102条目时设置或不设置L0L位。当虚拟地址在L0 TLB 100中未命中而在L1 TLB 102中命中时(包括在由页表104遍历导致的L1 TLB 102更新之后),检查L0L位以确定是否应在L0 TLB100中锁定所述条目。如果设置了L0L位,那么将条目写入到L0 TLB 100并进行锁定以防替换。
类似地,在具有硬件管理的L1 TLB 102的处理器中,L1锁定或L1L指示符维持在页表中且指示是否应在L1 TLB 102中锁定对应的条目。通常,本文关于锁定L0 TLB100条目以防替换的所有论述适用于在硬件管理的L1 TLB 102的情况中锁定L1 TLB102条目以防替换。
图2是功能框图,其根据一实施例描绘一种在由L1 TLB 102条目中的L0L位指示时对L0 TLB 100条目进行锁定的方式。L0 TLB 100包括n个条目,编号为0到n-1。FLOOR寄存器101保持表示L0 TLB 100的“基底”的条目号,或可用于正常分配的最低L0 TLB 100条目。低于基底的L0 TLB 100条目不可进行替换,并因此“被锁定”。如果没有条目被锁定,那么FLOOR寄存器101含有0,并在整个L0 TLB 100上操作替换算法。如图2中所描绘,如果响应于对应的L1 TLB 102条目中的L0L位将底部的两个条目锁定,那么处理器将会使FLOOR寄存器101递增到2,第一L0 TLB 100条目可用于重新分配。正常的高速缓存器重新分配算法在此种情况下在L0 TLB 100的从“基底”或2到L0 TLB 100的顶部(n-1)的那部分中操作。可通过使FLOOR寄存器101递减将条目解锁。
将锁定的L0 TLB 100条目聚集到一个地方可简化替换算法。举例来说,如果在循环基础上替换L0 TLB 100条目,那么只有“翻转”点受到经锁定条目的影响(即,当递增超出n-1时,下一个条目是由FLOOR寄存器101指向的条目,而不是0)。不存在循环分配必须“跳过”的分散在L0 TLB 100空间上的非连续的经锁定条目。注意,聚集和锁定L0 TLB 100条目的FLOOR方法仅仅是代表性的,而不是限制性的。可根据各种方法来锁定L0 TLB 100条目以防重新分配。类似地,可在软件控制下或如页表104中所述使用FLOOR寄存器或以所属技术领域中所已知的其它方式来在L1 TLB102中锁定条目。
图3描绘采用管线式架构和分层存储器结构的代表性处理器10的功能框图。处理器10根据控制逻辑14执行指令执行管线12中的指令。所述管线包括组织成管道阶段的各种寄存器或锁存器16,以及一个或一个以上算术逻辑单元(ALU)18。通用寄存器(GPR)堆20提供构成存储器层次结构的顶部的寄存器。
管线从指令高速缓存器(I-高速缓存器)22提取指令,其中存储器寻址和许可由层0指令侧转换后备缓冲器(L0 ITLB)24和L1 ITLB 25来管理。从数据高速缓存器(D-高速缓存器)26存取数据,其中存储器寻址和许可由主L0 TLB 100和L1 TLB 102来管理。在各种实施例中,L1 ITLB 24可包含L1 TLB 102的一部分的拷贝。或者,可集成L1 ITLB 24和L1 TLB 102。类似地,在处理器10的各种实施例中,可集成或统一I-高速缓存器22和D-高速缓存器26。在存储器接口30的控制下,I-高速缓存器22及/或D-高速缓存器26中的未命中导致对主(芯片外)存储器32的存取。页表104存储在存储器32中。
处理器10可包括输入/输出(I/O)接口34,从而控制对各外围装置36的存取。所属技术领域的技术人员将认识到,可能对处理器10进行多种变化。举例来说,处理器10可包括第二层(L2)高速缓存器以用于I-高速缓存器和D-高速缓存器22、26中的一者或两者。另外,可从特定实施例中省去处理器10中所描绘的功能方块中的一者或多者。
图4是流程图,其根据一个实施例描绘大致以200指示的存储器地址转换过程。执行存储器存取指令(方块202),并向L0 TLB 100呈现虚拟地址或其一部分(方块204)。如果所述虚拟地址在L0 TLB 100中命中(方块206),那么L0 TLB 100提供物理地址或其一部分以及页属性(方块208),且高速缓存器22、26或主存储器32存取继续(未示出)。如果所述虚拟地址在L0 TLB 100中未命中(方块206),那么向L1 TLB102呈现所述虚拟地址以进行转换。
如果所述虚拟地址在L1 TLB 102中命中(方块212),那么核查L1 TLB 102条目中的L0L位(方块214)。如果未设置L0L位,那么将所述条目添加到L0 TLB 100(方块216),并提供物理地址和页属性(方块208)。如果设置了L0L位,那么将所述条目添加到L0 TLB 100,且在L0 TLB 100中锁定以防替换(方块218),并提供物理地址和页属性(方块208)。
如果所述虚拟地址在L1 TLB 102中未命中(方块212),那么对页表104进行存取(方块220)以获得地址转换。如果在页表104中没有找到转换(方块222),那么产生错误(方块224)。如果从页表104获得了转换(方块222),那么将所述转换作为条目写入到L1 TLB 102(方块226),包括指示是否应在L0 TLB 100中锁定所述条目以防替换的L0L位。然后再执行存储器存取指令202(方块202)以重新开始地址转换过程。此时,所述虚拟地址将在L0 TLB 100中未命中(方块206)而在L1 TLB 102中命中(方块212)。然后,将所述条目写入到L0 TLB 100,并视L1T LB 102条目中的L0L位的状态而定锁定或不锁定(方块214、216、218)。尽管图4的流程图按顺序描绘步骤,但在一个实施例中,L0 TLB 100和L1 TLB 102存取可平行发生。
定义L1 TLB 102条目中的一个或一个以上L0L位为操作系统提供一种用于指定应在L0 TLB 100中锁定哪些条目以防替换的方式。这允许操作系统能够在无法直接存取L0 TLB 100的情况下确保针对某些关键任务的最快的可能存储器地址转换。类似地,在硬件管理的L1 TLB 102的情况下,可在页表104中维持指示是否应锁定对应的L1 TLB 102条目以防替换的L1L位。
尽管本文中已针对本发明的特定特征、方面和实施例对本发明进行了描述,但显而易见的是,在本发明的广泛范围内可实现大量的变化、修改和其它实施例,且因此,所有的变化、修改和实施例均视为在本发明的范围内。因此,应以所有说明性而非限制性的方面来解释本发明的实施例,且所有属于随附权利要求书的含义及等效范围内的改变均打算包含于本权利要求书的范围中。

Claims (18)

1.一种管理分层转换后备缓冲器(TLB)的方法,其包含:
将条目从上层TLB复制到低层TLB;及
响应于所述上层TLB条目中的指示符,锁定所述低层TLB中的所述条目以防替换。
2.如权利要求1所述的方法,其中所述指示符是所述上层TLB条目中的位。
3.如权利要求1所述的方法,其中由软件对包括所述指示符的所述上层TLB条目进行设置。
4.如权利要求1所述的方法,其中由软件将所述指示符设置在存储器页表中,且其中在硬件页表扩展操作期间将所述指示符设置在所述上层TLB条目中。
5.如权利要求1所述的方法,其中所述低层TLB是指令TLB。
6.如权利要求1所述的方法,其中所述低层TLB是数据TLB。
7.如权利要求5所述的方法,其进一步包含将所述上层TLB条目复制到低层指令TLB,并响应于所述指示符锁定所述低层指令TLB条目以防替换。
8.一种处理器,其包含:
指令执行管线;
分层转换后备缓冲器(TLB),其包含高层TLB和低层TLB,所述低层TLB中的条目复制所述高层TLB中的条目;及
TLB控制器,其操作以在地址转换中首先存取所述低层TLB,且如果在所述低层TLB中没有找到匹配的条目,那么存取所述高层TLB,所述控制器进一步操作以响应于所述高层TLB中的所述对应条目中的指示符来锁定所述低层TLB中的条目。
9.如权利要求8所述的处理器,其进一步包含:
层0指令侧转换后备缓冲器(L0ITLB);
层1指令侧转换后备缓冲器(L1ITLB);及
指令高速缓存器(I-高速缓存器),其中所述指令执行管线可操作以通过由所述层0指令侧转换后备缓冲器和层1指令侧转换后备缓冲器管理的存储器寻址和许可从所述指令高速缓存器存取指令。
10.如权利要求9所述的处理器,其中所述层1指令侧转换后备缓冲器和所述高层TLB是集成的。
11.如权利要求9所述的处理器,其进一步包含:
数据高速缓存器(D-高速缓存器),其中所述指令执行管线可操作以通过由所述低层TLB和所述高层TLB管理的存储器寻址和许可从所述数据高速缓存器存取数据。
12.如权利要求11所述的处理器,其中所述指令高速缓存器和所述数据高速缓存器是集成的。
13.如权利要求11所述的处理器,其进一步包含第二层(L2)高速缓存器。
14.如权利要求13所述的处理器,其中所述第二层高速缓存器包括所述指令高速缓存器。
15.如权利要求13所述的处理器,其中所述第二层高速缓存器包括所述数据高速缓存器。
16.如权利要求8所述的处理器,其进一步包含可操作以控制对至少一个外围装置的存取的输入/输出(I/O)接口。
17.一种在处理器中将虚拟地址转换到物理地址的方法,其包含:
执行存储器存取指令以产生虚拟地址;
使用所述虚拟地址的一部分来存取层0转换后备缓冲器(L0TLB);
如果所述虚拟地址在所述层0转换后备缓冲器中未命中,那么使用所述虚拟地址的一部分来存取层1TLB(L1TLB);及
如果所述虚拟地址在所述层1TLB中命中,那么
从所述层1TLB获得物理地址的一部分和页属性,
检查所述层1TLB条目中的层0锁定(L0L)指示符,
将所述虚拟地址的一部分、所述物理地址的一部分以及所述页属性作为条目写入到所述层0转换后备缓冲器中,及
响应于所述层0锁定指示符锁定所述层0转换后备缓冲器条目以防替换。
18.如权利要求17所述的方法,其进一步包含如果所述虚拟地址在所述层1TLB中未命中,那么:
执行页表遍历以获得与所述虚拟地址相关联的物理地址和页属性;及
将所述虚拟地址的一部分、所述物理地址的一部分、所述页属性以及层0锁定指示符作为条目写入到所述层1TLB中。
CN2006800388152A 2005-08-23 2006-08-22 转换后备缓冲器的锁定指示符 Active CN101292228B (zh)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US11/210,526 2005-08-23
US11/210,526 US7426626B2 (en) 2005-08-23 2005-08-23 TLB lock indicator
PCT/US2006/032902 WO2007024937A1 (en) 2005-08-23 2006-08-22 Tlb lock indicator

Publications (2)

Publication Number Publication Date
CN101292228A CN101292228A (zh) 2008-10-22
CN101292228B true CN101292228B (zh) 2012-02-08

Family

ID=37497978

Family Applications (1)

Application Number Title Priority Date Filing Date
CN2006800388152A Active CN101292228B (zh) 2005-08-23 2006-08-22 转换后备缓冲器的锁定指示符

Country Status (6)

Country Link
US (1) US7426626B2 (zh)
EP (1) EP1934753B1 (zh)
JP (1) JP4567789B2 (zh)
KR (1) KR100959014B1 (zh)
CN (1) CN101292228B (zh)
WO (1) WO2007024937A1 (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107533513A (zh) * 2015-04-15 2018-01-02 高通股份有限公司 突发转换后备缓冲器

Families Citing this family (76)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070094476A1 (en) * 2005-10-20 2007-04-26 Augsburg Victor R Updating multiple levels of translation lookaside buffers (TLBs) field
US8195886B2 (en) * 2007-03-16 2012-06-05 Arm Limited Data processing apparatus and method for implementing a replacement scheme for entries of a storage unit
US8799620B2 (en) 2007-06-01 2014-08-05 Intel Corporation Linear to physical address translation with support for page attributes
US7908439B2 (en) * 2007-06-25 2011-03-15 International Business Machines Corporation Method and apparatus for efficient replacement algorithm for pre-fetcher oriented data cache
US20090049272A1 (en) * 2007-08-13 2009-02-19 International Business Machines Corporation Method for improving the performance of software-managed tlb
US8156309B2 (en) * 2007-10-18 2012-04-10 Cisco Technology, Inc. Translation look-aside buffer with variable page sizes
US7949851B2 (en) * 2007-12-28 2011-05-24 Spansion Llc Translation management of logical block addresses and physical block addresses
US8464021B2 (en) * 2008-05-28 2013-06-11 Spansion Llc Address caching stored translation
US9239799B2 (en) * 2008-06-26 2016-01-19 Qualcomm Incorporated Memory management unit directed access to system interfaces
EP2148279A1 (fr) * 2008-07-24 2010-01-27 Nagravision S.A. Méthode de mise à jour de données dans des mémoires utilisant une unité de gestion mémoire
US9569349B2 (en) * 2008-12-19 2017-02-14 Ati Technologies Ulc Method and apparatus for reallocating memory content
US8275598B2 (en) * 2009-03-02 2012-09-25 International Business Machines Corporation Software table walk during test verification of a simulated densely threaded network on a chip
US9535849B2 (en) * 2009-07-24 2017-01-03 Advanced Micro Devices, Inc. IOMMU using two-level address translation for I/O and computation offload devices on a peripheral interconnect
KR101393992B1 (ko) * 2010-03-09 2014-05-12 후지쯔 가부시끼가이샤 정보 처리 장치, 정보 처리 방법, 및 프로그램을 기록한 컴퓨터 판독가능한 기록 매체
US8615636B2 (en) 2011-03-03 2013-12-24 International Business Machines Corporation Multiple-class priority-based replacement policy for cache memory
US9465751B2 (en) 2012-03-30 2016-10-11 Intel Corporation Efficient locking of memory pages
US20140189333A1 (en) * 2012-12-28 2014-07-03 Oren Ben-Kiki Apparatus and method for task-switchable synchronous hardware accelerators
US10140129B2 (en) 2012-12-28 2018-11-27 Intel Corporation Processing core having shared front end unit
US9417873B2 (en) 2012-12-28 2016-08-16 Intel Corporation Apparatus and method for a hybrid latency-throughput processor
US9361116B2 (en) 2012-12-28 2016-06-07 Intel Corporation Apparatus and method for low-latency invocation of accelerators
US10346195B2 (en) 2012-12-29 2019-07-09 Intel Corporation Apparatus and method for invocation of a multi threaded accelerator
US9292453B2 (en) * 2013-02-01 2016-03-22 International Business Machines Corporation Storing a system-absolute address (SAA) in a first level translation look-aside buffer (TLB)
CN103116556B (zh) * 2013-03-11 2015-05-06 无锡江南计算技术研究所 内存静态划分虚拟化方法
US10454714B2 (en) 2013-07-10 2019-10-22 Nicira, Inc. Method and system of overlay flow control
US10135789B2 (en) 2015-04-13 2018-11-20 Nicira, Inc. Method and system of establishing a virtual private network in a cloud service for branch networking
CN106326150B (zh) * 2015-06-26 2020-09-15 中兴通讯股份有限公司 内存访问处理方法及装置
US11403099B2 (en) 2015-07-27 2022-08-02 Sony Interactive Entertainment LLC Backward compatibility by restriction of hardware resources
CN106649149A (zh) * 2015-10-28 2017-05-10 福州瑞芯微电子股份有限公司 实现地址映射的内存管理系统及方法
US10915333B2 (en) 2016-03-30 2021-02-09 Sony Interactive Entertainment Inc. Deriving application-specific operating parameters for backwards compatiblity
US10061712B2 (en) 2016-05-10 2018-08-28 Oracle International Corporation Virtual memory page mapping overlays
US10176111B2 (en) 2016-07-18 2019-01-08 International Business Machines Corporation Host page management using active guest page table indicators
US10180909B2 (en) 2016-07-18 2019-01-15 International Business Machines Corporation Host-based resetting of active use of guest page table indicators
US10248573B2 (en) 2016-07-18 2019-04-02 International Business Machines Corporation Managing memory used to back address translation structures
US10241924B2 (en) 2016-07-18 2019-03-26 International Business Machines Corporation Reducing over-purging of structures associated with address translation using an array of tags
US10282305B2 (en) 2016-07-18 2019-05-07 International Business Machines Corporation Selective purging of entries of structures associated with address translation in a virtualized environment
US10169243B2 (en) 2016-07-18 2019-01-01 International Business Machines Corporation Reducing over-purging of structures associated with address translation
US10168902B2 (en) 2016-07-18 2019-01-01 International Business Machines Corporation Reducing purging of structures associated with address translation
US10176006B2 (en) 2016-07-18 2019-01-08 International Business Machines Corporation Delaying purging of structures associated with address translation
US10176110B2 (en) * 2016-07-18 2019-01-08 International Business Machines Corporation Marking storage keys to indicate memory used to back address translation structures
US10223281B2 (en) 2016-07-18 2019-03-05 International Business Machines Corporation Increasing the scope of local purges of structures associated with address translation
US10802986B2 (en) 2016-07-18 2020-10-13 International Business Machines Corporation Marking to indicate memory used to back address translation structures
US10162764B2 (en) * 2016-07-18 2018-12-25 International Business Machines Corporation Marking page table/page status table entries to indicate memory used to back address translation structures
US10037283B2 (en) * 2016-08-12 2018-07-31 Advanced Micro Devices, Inc. Updating least-recently-used data for greater persistence of higher generality cache entries
US10515671B2 (en) 2016-09-22 2019-12-24 Advanced Micro Devices, Inc. Method and apparatus for reducing memory access latency
US11706127B2 (en) 2017-01-31 2023-07-18 Vmware, Inc. High performance software-defined core network
US10992568B2 (en) 2017-01-31 2021-04-27 Vmware, Inc. High performance software-defined core network
US20180219765A1 (en) 2017-01-31 2018-08-02 Waltz Networks Method and Apparatus for Network Traffic Control Optimization
US20200036624A1 (en) 2017-01-31 2020-01-30 The Mode Group High performance software-defined core network
US10778528B2 (en) 2017-02-11 2020-09-15 Nicira, Inc. Method and system of connecting to a multipath hub in a cluster
US10127159B1 (en) * 2017-07-13 2018-11-13 International Business Machines Corporation Link consistency in a hierarchical TLB with concurrent table walks
US10608844B2 (en) 2017-10-02 2020-03-31 Vmware, Inc. Graph based routing through multiple public clouds
US10999100B2 (en) 2017-10-02 2021-05-04 Vmware, Inc. Identifying multiple nodes in a virtual network defined over a set of public clouds to connect to an external SAAS provider
US11115480B2 (en) 2017-10-02 2021-09-07 Vmware, Inc. Layer four optimization for a virtual network defined over public cloud
US11223514B2 (en) 2017-11-09 2022-01-11 Nicira, Inc. Method and system of a dynamic high-availability mode based on current wide area network connectivity
US11321240B2 (en) * 2018-06-08 2022-05-03 International Business Machines Corporation MMIO addressing using a translation lookaside buffer
US11243891B2 (en) * 2018-09-25 2022-02-08 Ati Technologies Ulc External memory based translation lookaside buffer
US11153230B2 (en) 2019-08-27 2021-10-19 Vmware, Inc. Having a remote device use a shared virtual network to access a dedicated virtual network defined over public clouds
KR102355374B1 (ko) 2019-09-27 2022-01-25 에스케이하이닉스 주식회사 이종 메모리를 이용하여 메모리 주소 변환 테이블을 관리하는 메모리 관리 유닛 및 이의 메모리 주소 관리 방법
US11489783B2 (en) 2019-12-12 2022-11-01 Vmware, Inc. Performing deep packet inspection in a software defined wide area network
US11418997B2 (en) 2020-01-24 2022-08-16 Vmware, Inc. Using heart beats to monitor operational state of service classes of a QoS aware network link
US11363124B2 (en) * 2020-07-30 2022-06-14 Vmware, Inc. Zero copy socket splicing
US11575591B2 (en) 2020-11-17 2023-02-07 Vmware, Inc. Autonomous distributed forwarding plane traceability based anomaly detection in application traffic for hyper-scale SD-WAN
US11601356B2 (en) 2020-12-29 2023-03-07 Vmware, Inc. Emulating packet flows to assess network links for SD-WAN
US11792127B2 (en) 2021-01-18 2023-10-17 Vmware, Inc. Network-aware load balancing
US11979325B2 (en) 2021-01-28 2024-05-07 VMware LLC Dynamic SD-WAN hub cluster scaling with machine learning
US12009987B2 (en) 2021-05-03 2024-06-11 VMware LLC Methods to support dynamic transit paths through hub clustering across branches in SD-WAN
US11637768B2 (en) 2021-05-03 2023-04-25 Vmware, Inc. On demand routing mesh for routing packets through SD-WAN edge forwarding nodes in an SD-WAN
US11729065B2 (en) 2021-05-06 2023-08-15 Vmware, Inc. Methods for application defined virtual network service among multiple transport in SD-WAN
US12015536B2 (en) 2021-06-18 2024-06-18 VMware LLC Method and apparatus for deploying tenant deployable elements across public clouds based on harvested performance metrics of types of resource elements in the public clouds
US12047282B2 (en) 2021-07-22 2024-07-23 VMware LLC Methods for smart bandwidth aggregation based dynamic overlay selection among preferred exits in SD-WAN
US11943146B2 (en) 2021-10-01 2024-03-26 VMware LLC Traffic prioritization in SD-WAN
CN114510889B (zh) * 2022-02-15 2024-07-30 中电科申泰信息科技有限公司 一种基于申威处理器芯片架构的tlb模拟器及调试方法
US11909815B2 (en) 2022-06-06 2024-02-20 VMware LLC Routing based on geolocation costs
CN115794681B (zh) * 2022-10-12 2023-05-23 中国人民解放军军事科学院国防科技创新研究院 适用于risc-v的多级可扩展tlb系统及其地址转换方法
US12034587B1 (en) 2023-03-27 2024-07-09 VMware LLC Identifying and remediating anomalies in a self-healing network
US12057993B1 (en) 2023-03-27 2024-08-06 VMware LLC Identifying and remediating anomalies in a self-healing network

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4727485A (en) * 1986-01-02 1988-02-23 Motorola, Inc. Paged memory management unit which locks translators in translation cache if lock specified in translation table
EP1204029A2 (en) * 2000-11-06 2002-05-08 Fujitsu Limited Microprocessor and address translation method for microprocessor

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0746325B2 (ja) * 1985-12-23 1995-05-17 モトロ−ラ・インコ−ポレ−テツド データ処理システム
US6223263B1 (en) * 1998-09-09 2001-04-24 Intel Corporation Method and apparatus for locking and unlocking a memory region
GB2388447B (en) * 2002-05-09 2005-07-27 Sun Microsystems Inc A computer system method and program product for performing a data access from low-level code
US6941442B2 (en) * 2002-08-02 2005-09-06 Arm Limited Entry lockdown within a translation lookaside buffer mechanism
JP3936672B2 (ja) * 2003-04-30 2007-06-27 富士通株式会社 マイクロプロセッサ

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4727485A (en) * 1986-01-02 1988-02-23 Motorola, Inc. Paged memory management unit which locks translators in translation cache if lock specified in translation table
EP1204029A2 (en) * 2000-11-06 2002-05-08 Fujitsu Limited Microprocessor and address translation method for microprocessor

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107533513A (zh) * 2015-04-15 2018-01-02 高通股份有限公司 突发转换后备缓冲器
CN107533513B (zh) * 2015-04-15 2021-06-04 高通股份有限公司 突发转换后备缓冲器

Also Published As

Publication number Publication date
JP4567789B2 (ja) 2010-10-20
KR100959014B1 (ko) 2010-05-24
US20070050594A1 (en) 2007-03-01
EP1934753A1 (en) 2008-06-25
JP2009506434A (ja) 2009-02-12
CN101292228A (zh) 2008-10-22
WO2007024937A1 (en) 2007-03-01
US7426626B2 (en) 2008-09-16
EP1934753B1 (en) 2018-08-08
KR20080041707A (ko) 2008-05-13

Similar Documents

Publication Publication Date Title
CN101292228B (zh) 转换后备缓冲器的锁定指示符
US10282122B2 (en) Methods and systems of a memory controller for hierarchical immutable content-addressable memory processor
US7287140B1 (en) System and technique for fine-grained computer memory protection
CN101331466B (zh) 同经高速缓存的存储器数据一起高速缓存存储器属性指示符
US6457104B1 (en) System and method for recycling stale memory content in compressed memory systems
CN100394407C (zh) 低等待时间存储器系统访问
US7797509B2 (en) Systems and methods for utilizing an extended translation look-aside buffer having a hybrid memory structure
US8495286B2 (en) Write buffer for improved DRAM write access patterns
CN102792285A (zh) 层级转换表控制
CN101111819B (zh) 用于页内程序计数器相对或绝对地址转移指令的转换后备缓冲器(tlb)访问抑制
JPH05509189A (ja) コンピュータシステムを動作する方法及びコンピュータシステムにおけるメモリ管理装置
Puglia et al. Non-volatile memory file systems: A survey
KR102710342B1 (ko) 캐시 스토리지
Luan et al. Prefetching j+-tree: a cache-optimized main memory database index structure
Zhang et al. Fast persistent heap based on non-volatile memory
Song et al. LIFM: A Persistent Learned Index for Flash Memory
Mittal et al. Cache performance improvement using software-based approach
He NV-Tree: A Consistent and Workload-adaptive Tree Structure for Non-volatile Memory
Patel Efficient data access techniques for large structured data files

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant