常见的操作系统 只使用了 0 和3

段选择子


DPL 是段描述符的内容 段的信息


中断和陷入的 大致特权级的展现

RPL 当前要访问数据段对饮给的特权级
CPL 当前代码段的特权级

DPL 全局的

通过门区访问特权级更高的段

特权级的切换##

通过中断切换特权级
基于中断的特权级的转换
中断门


压栈信息

ring(0 to 3)
特权级的切换
内核态 跳转到 用户态
构造一个特殊的栈

内核栈中产生压栈 step1

模仿ring3 产生中断时的现场
要切换
会多存两个信息。
修改一下CPL 特权级

使用iret 指令把信息弹出栈 将信息付给其他的寄存器
然后就已经到用户态了

从ring3 调到 ring0

中断描述符 中断服务历程


在被打断的那一刻 所保存下来的信息
处理完 ISR IRET就返回了ring3
但是我们可以修改堆栈信息 ,执行完ISR 后留在 ring0就ok 了


LAb1 的changellage 的方式

x86 特权级 TSS 格式##

task state segment
保存了不同特权级所用到的信息
我们关注 不同特权级的堆栈信息

cpu 根据TSS 中的信息 设置新的堆栈 根据IDT表跳到新的地址

操作系统要设置好TSS

TSS 特殊的一个段 Task State Segment 任务状态段

有一个 TSS 的段

优化 专门有一个 Task Register 保存Tss 的位置 、
初始化的任务

特权级信息的 参考文档

段/页表

x86 内存管理单元 mmu

段机制概述

x86 mmu -段选择子(segment selector )中的隐藏部分

扩展的段选择子

x86 hardward mmu -GDT tables (kernel init)

Lab1 中的映射关系

选择页机制 更有效一些 主流的cpu 都采用的 页机制

不是很懂?

如何建立页的映射机制##


页机制概述
PDE PTE

CR3 里面是页表首地址

页表项里面村的地址是线性地址

页表项: page table entries

高20位是基址 低12位是一些属性

页表就两级

使能 页机制 (enable paging )
cro 第一位保护机制使能
cr0 最高位31 位 启动页机制

问题:练习 pmm.c 里面实现的

x86 mmu -在页表中建立页的映射关系##

给一个 虚地址一映射到 物理地址

x86 里面非常的全面 段页机制


intel 对应的章节