• Lab 2 内存管理


    常见的操作系统 只使用了 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 对应的章节

  • 相关阅读:
    Spring Boot
    Linux入门
    synchronized(一)
    避免XSS攻击
    MySql概述及入门(五)
    MySQL概述及入门(四)
    上传漏洞总结-upload-labs
    文件类型解析漏洞防御与攻击(PHP)
    Dvna for Owasp top 10 2017
    XSS 漏洞介绍
  • 原文地址:https://www.cnblogs.com/sfzyk/p/8992870.html
Copyright © 2020-2023  润新知