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相关寄存器相关推荐

  1. ASID 与 MIPS 中 TLB 相关

    ASID 为了提高TLB的性能,将TLB分成Global和process-specific.global 是指常驻在tlb中不会被刷出的,例如内核空间的翻译,process-specific 是指每个 ...

  2. 6410的系统时钟设置(中)---相关寄存器介绍

    上篇中已经详细分析了6410时钟系统的结构,现在就介绍下几个与时钟设置相关的寄存器. 1.APLL_LOCK.MPLL_LOCK.EPLL_LOCK 这三个寄存器的低十六位分别表示APLL.MPLL. ...

  3. MIPS中的异常处理和系统调用【转】

    转自:http://blog.csdn.net/jasonchen_gbd/article/details/44044091 权声明:本文为博主原创文章,转载请附上原博链接. 异常入口 系统调用是用户 ...

  4. Linux kernel 3.10内核源码分析--TLB相关--TLB概念、flush、TLB lazy模式

    一.概念及基本原理 TLB即Translation Lookaside Buffer,是MMU中的一种硬件cache,用于缓存页表,即缓存线性地址(虚拟地址)到物理地址的映射关系. 如果没有TLB,那 ...

  5. SD/MMC相关寄存器的介绍

    1.SD卡内部架构 在熟悉SD/MMC相关寄存器之前,我们先来看看SD卡的内部架构是怎么样的,如下图所示: 2.SD/MMC相关寄存器的介绍 从上图中总结出:SD卡内部有7个寄存器. 一.OCR,CI ...

  6. mips中的li_MIPS学习笔记(一)

    写在前面 本文是根据"MIPS Assembly Language Programming CS50 Discussion and Project Book. Daniel J. Ellar ...

  7. 用HALL 库配置GPIO以及相关寄存器

    文章目录 一 .初始化GPIO (一)定义一个结构体变量GPIO_InitStruct,该变量类型是GPIO_InitTypeDef. (二).使能时钟. (三)配置引脚的初始化电平. (四).通过结 ...

  8. 51单片机串口通信原理、相关寄存器配置与简单串口收发程序代码

    目录 1. 串口通信原理 2. 51单片机串口通信 2.1 串口简要模式图 2.2 相关寄存器 (1)PCON.SCON.SBUF (2)IE.IPH.IP (3)配置T1定时器 2.3 波特率和系统 ...

  9. 飞腾CPU相关寄存器描述(持续更新)

    飞腾CPU相关寄存器描述(持续更新) SPSel堆栈寄存器选择寄存器 EL1/2/3都可以读写 32位长度. SP, bit[0], 控制堆栈寄存器的选择. 0-->CPU无论处于什么权限级,堆 ...

最新文章

  1. asp.net mvc3 Razor引擎中@使用规则小记
  2. [转]关于形如--error LNK2005: xxx 已经在 msvcrtd.lib ( MSVCR90D.dll ) 中定义--的问题分析解决...
  3. 去年3545款恶意App遭下架
  4. android状态栏半透明灰色,Android7.0沉浸式状态栏蒙灰问题完美解决
  5. linux 修改用户组_linux小白到大神的成长之路:linux系统用户组的管理!
  6. .Net内存管理、垃圾回收
  7. python列表的内置方法_Python内置方法详解
  8. mysql把游标数据存入表中_利用Python爬股票数据并存入数据库Mysql
  9. 阻碍物联网腾飞几大难题盘点 看能想出什么对策
  10. JavaScript中的的面向对象中的一些知识
  11. android 导航 美国,变美了 Android N或用全新虚拟导航按键
  12. 实现点击按钮复制文本(Clipboard包)
  13. 趣味科普丨一文读懂云服务器的那些事儿
  14. java实验报告实验六,第六周java实验报告四
  15. write RE validation
  16. 第十一次课:Python函数(二)
  17. 全球与中国高精度漆包扁铜线市场深度研究分析报告
  18. 计算机应用技术信息管理方向,计算机应用技术专业(信息管理方向).docx
  19. 程序的依赖和引用是什么?
  20. Session 钝化机制

热门文章

  1. matlab 自由度,matlab二自由度系统振动
  2. jQuery_Ajax下载服务器文件流的方法
  3. Java的四种遍历方式
  4. 计算机sci有哪些AJCHE,最新SCI目录(大类加小类,齐全).xls
  5. 2021年2月CFA一级机考报名流程、时间及费用公布
  6. 雷赛服务器信号er020,雷赛_数字步进电机与驱动器_DM2C-RS556型号
  7. 宣传单彩页_宣传单彩页设计
  8. 从概念到底层技术,一文看懂区块链架构设计
  9. 红队笔记之杀软原理介绍与免杀技术总结
  10. android支持苹果吗,安卓手机能用苹果USB-C音频线吗?实测10款手机仅1款不支持