ASID 与 MIPS 中 TLB 相关
ASID
- 为了提高TLB的性能,将TLB分成Global和process-specific。global 是指常驻在tlb中不会被刷出的,例如内核空间的翻译,process-specific 是指每个进程独有的地址空间,当发生进程切换的时候,这部分tlb可以被刷出,为了支持process-specific的tlb,arm提出了ASID(Adress Space ID)的硬件解决方案,这样TLB就可以识别出这个 TLB 页表项是属于哪一个进程的。
- 在 MIPS 中,有两个地方会出现ASID,每一个TLB表项会有一个ASID,标识这个表项是属于哪一个进程的,CP0_EntryHI 中的ASID是当前进程的ASID,所以进程对TLB的查询操作,即使VPN命中,但若该表项不是global且ASID与CP0_EntryHi的ASID不一致,则也视作TLB缺失 -- 这样就不用每次切换进程都要 flush 所有 tlb
MIPS 中 TLB/MMU 相关寄存器
TLB 关键字域
- EntryHi 包含 VPN2 和 ASID 字段
- VPN2 就是 TLB 表项对应的虚拟页表号,在 MIPS 设计中,一个 TLB 表项存储的是两个相邻虚拟页对应的物理页框号,所以 VPN2 只有 21 位(除去页内偏移12位和第13位)
- ASID 字段,是当前进程的ASID,在对 TLB 访问查询中起到验证的作用(具体见 ASID 部分)。
- EntryLo0-1
- PFN 对应的物理页框号
- D(dirty) 标志位,置位时允许写入;0 不允许写入,若写入则发生异常
- V(valid) 有效位
- G(global) 表明该 TLB 表项是全局的还是属于特定进程的,若是全局的,则对该 TLB 表项的读取都会无视 ASID 是否匹配
- EntryHi 与 EntryLo 一道负责 TLB 的写入与读取操作,tlbr 将读到的 TLB 表项写入 EntryHi(注意这一步会覆盖原本的 ASID,执行之后需要恢复)与 EntryLo 之中。
- PageMask
- 用于支持更大的页,PageMask 寄存器值为 1 的位,在执行 TLB 表项匹配时被忽略(即 PageMask 寄存器值为 1 的位被视作页内偏移位),如: PageMask 低 12 位为 1,则表明页大小为 4KB。
- 另外,在 MIPS 体系中,页的大小在 4KB 和 16MB 之间以四倍递增。
TLB 选择寄存器
- index
- 值为 0 到 表项总数 - 1 之间的一个数,用于指出 tlbr、tlbwi 读写的是第几个 TLB 表项。
- Random
- 保存 TLB 的一个索引,CPU 每执行一条指令就向下递减计数一次,该值充当 tlbwr 的 TLB 索引,在需要更新 TLB 时,帮助实现随机替换策略。
页表存取辅助寄存器
Context 和 XContext
- 辅助处理 TLB 重填异常,其中 XContext 是 MIPS64 位中增加的
- 32位的 Context 数据域为:
31 - 23 22 - 4 3 - 0 PTEBase BADVPN2 0 - PTEBase 存储页表空间的起始地址(因为起始地址是 8M 对齐)
- BADVPN2 是 BADAddr 的 VPN2 域,BADAddr 是引起重填异常的虚拟地址
- 实际上 32 位中一个页表项只有 64 位大(VPN2 下),但是 MIPS 为了与 64 位页表兼容,预留成 2*64 位大
- 因为 PTEBase 是页表空间的起始地址,BADVPN2 标明该 BADAddr 所对应的是第 BADVNP2 个页表项,故 BADVPN << 4 就是 BADAddr 对应的页表项相对于页表空间起始地址的偏移,所以当发生重填异常的时候,Context 存储的就是对应页表项的虚拟地址,即需要加载到 EntryLo0-1中的数据项的地址。所以依靠 Context 的辅助,能够极大程度的简化重填异常处理的过程。
TLB 重填异常处理
mfc0 k1, C0_CONTEXT
lw k0, 0(k1)
lw k1, 8(k1)
mtc0 k0, C0_ENTRYLO0
mtc0 k1, C0_ENTRYLO1
ehb
tlbwr
eret
- ehb 汇编指令用于保证 ehb 之前对协处理器 0 的操作都会在执行该条指令之后指令时已完成
参考资料:See MIPS Run Linux (2nd edition)
ASID 与 MIPS 中 TLB 相关的更多相关文章
- MIPS中的异常处理和系统调用【转】
转自:http://blog.csdn.net/jasonchen_gbd/article/details/44044091 权声明:本文为博主原创文章,转载请附上原博链接. 异常入口 系统调用是用户 ...
- kernel 3.10内核源码分析--TLB相关--TLB概念、flush、TLB lazy模式 【转】
转自:http://blog.chinaunix.net/xmlrpc.php?r=blog/article&id=4808877&uid=14528823 一.概念及基本原理 TLB ...
- 理解CSV文件以及ABAP中的相关操作
在很多ABAP开发中,我们使用CSV文件,有时候,关于CSV文件本身的一些问题使人迷惑.它仅仅是一种被逗号分割的文本文档吗? 让我们先来看看接下来可能要处理的几个相关组件的词汇的语义. Separat ...
- Spring Framework------>version4.3.5.RELAESE----->Reference Documentation学习心得----->Spring Framework中web相关的知识(概述)
Spring Framework中web相关的知识 1.概述: 参考资料:官网documentation中第22小节内容 关于spring web mvc: spring framework中拥有自 ...
- storm-kafka组件中KafkaOffsetMetric相关统计指标说明
storm-kafka组件中KafkaOffsetMetric相关统计指标说明 storm-kafka是storm提供的一个读取kakfa的组件,用于从kafka队列中消费数据.KafkaOffset ...
- Linux中mod相关的命令 内核模块化 mod相关命令都是用来动态加载内核模块/驱动程序模块
Linux中mod相关的命令 内核模块化 mod相关命令都是用来动态加载内核模块/驱动程序模块 http://baike.baidu.com/link?url=lxiKxFvYm-UfJIxMjz ...
- 补充:sql server 中的相关查询、case函数
相关查询(在同一个表中) 相关查询类似子查询,但是又不同于子查询:子查询中的子条件可以单独查出数据,但是相关查询的子条件不能查处数据.(可以理解成C#中for的穷举法,第一个for走一个,第二个for ...
- c语言中数组相关问题
c语言中数组相关问题: 1.数组基本定义: 相同数据类型的元素按一定顺序排列的集合,就是把有限个类型相同的变量用一个名字命名,然后用编号区分他们的变量的集合,这个名字称为数组名,编号称为下标.组成数组 ...
- 【Socket编程】Java中网络相关API的应用
Java中网络相关API的应用 一.InetAddress类 InetAddress类用于标识网络上的硬件资源,表示互联网协议(IP)地址. InetAddress类没有构造方法,所以不能直接new出 ...
随机推荐
- ocp最新考试题库:052新考题及答案整理-36
36.Which two are true about roles? A) A role can be granted a combination of system and object privi ...
- IDEA 直接点击运行执行正常,命令行下面执行Jar包出现部分乱码的情况。
解决方案如上: 有个Springboot项目为了测试方便,模型类用中文作为字段属性,封装成Odata格式,在通过Springboot发布并打成jar包. 通过命令行启动jar包里面的Springweb ...
- python高级(一)—— python数据模型(特殊方法)
本文主要内容 collections.namedtuple __getitem__ 和 __len__ __repr__和__str__ __abs__.__add__和__mul__ __bool_ ...
- 主流服务器虚拟化技术简单使用——Hyper-V(一)
Tips:因为博客园排版的原因,图片显示不清晰,可以放大网页查看清晰图片. 如果系统使用物理机,需要在BIOS里面开启Intel VT-x(或AMD-V),如果是VMware workstation, ...
- Oracle远程数据建物化视图(materialized)创建简单记录,以及DBLINK的创建
目的:实现远程数据库访问及其相应表的定时同步 一.远程数据库dblink的创建 select * from dba_db_links; select * from user_sys_privs;--查 ...
- PIE SDK Command&&Tool工具命令一览表
PIE SDK Command&&Tool工具命令一览表 编号 模板 名称(中文) Command&Tool 程序集 备注 1 数据管理 加载栅格数据 PIE.Controls ...
- 3.nginx日志
1. 自定义日志格式为json log_format json '{"@timestamp":"$time_iso8601",' '"@version ...
- 封装通用的xhr对象(兼容各个版本)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- C++标准库类模板vector
vector是C++标准库STL中的一个重要的类模板,相当于一个更加健壮的,有很多附加能力的数组 使用vector前首先要包含头文件 #include<vector> 1.vector的 ...
- SQL基础语法select|insert|update|delete(增删改查) 简单使用
以下案列以此表举例 1.select(查询) select简单的查询分为两种 注:字段也就是表结构中的列的名称 第一种: select 字段名 from 表名 此种查询只列出你所需要查询的字段, ...