Linux操作系统分析3.ppt
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《Linux操作系统分析3.ppt》由会员分享,可在线阅读,更多相关《Linux操作系统分析3.ppt(56页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Linux操作系统分析操作系统分析中国科学技中国科学技术术大学大学计计算机系算机系陈陈香香兰兰(051287161316)Autumn 2009上次上次课课内容回内容回顾顾源代码简介启动代码简介Linux内核代码组成分析Linux的启动层次Linux的启动分析12/22/20222Linux OS Analysis内存寻址内存寻址内容提要内容提要X86微处理器的存储器寻址Linux在X86上的寻址实现12/22/20224Linux OS Analysis存存储储器地址器地址在intelx86处理器下,有三种不同的地址逻辑地址:每个逻辑地址由一个段(segment)和偏移量(offset)组成
2、线性地址:32位无符号整数,可表示4G大小的地址空间物理地址:芯片级内存单元寻址。它们与从CPU的地址引脚发送到内存总线上的电信号相对应地址转换过程物理地址线性地址分段单元分页单元逻辑地址12/22/20225Linux OS Analysis为为什么需要内存什么需要内存寻寻址机制址机制?保护内核不受恶意或者无意的破坏隔离各个用户进程方便程序的编写,使程序员可以抛开对物理内存的考虑,而且理论上可以使用任意大小的空间12/22/20226Linux OS Analysis硬件的分段硬件的分段单单元(元(1)段寄存器段寄存器(segment register)I386体系结构采用分段机制逻辑地址=
3、段:段内偏移使用16位段寄存器来指明当前所使用的段有六个:cs,ss,ds,es,fs和gsCPU规定了3个寄存器的专门的用途cs代码段寄存器,指向存放程序指令的段ss堆栈段寄存器,指向存放当前堆栈的段ds数据段寄存器,指向存放数据的段12/22/20227Linux OS Analysis从从80386开始,开始,Intel微微处处理器以两种不同的方理器以两种不同的方式式执执行地址行地址转换转换实模式(20位)16位段寄存器只记录段基址的高16位,因此段基址必须4位对齐(末4位为0)不采用虚拟地址空间,直接采用物理地址空间 物理地址=段寄存器值*16+段内偏移保护模式(32位)16位段寄存器
4、无法直接记录段的信息,因此需要与全局描述符表GDT配合使用GDT中记录了每个段的信息(段描述符),段寄存器只需记录段在GDT中的序号12/22/20228Linux OS Analysis注意:cs寄存器还有一个很重要的功能:它含有一个两位的域,用以指明CPU的当前特权级CPL(current privilege level),值为0代表最高优先级,值为3代表最低优先级线性地址=段基地址+段内偏移其中,段基地址是根据段寄存器所指明的GDT中的段描述符中的信息得到的物理地址:根据页表对线性地址进行转换而得到12/22/20229Linux OS AnalysisGDT和段描述符和段描述符(seg
5、ment descriptor)每个段由一个段描述符来表示,一个段描述符长度为8个字节全局描述符表GDT(global description table)就用来存放段描述符GDT表也存放在RAM中,并使用一个专门的寄存器GDTR来指示GDT表在RAM中的位置(物理起始地址)局部描述符表LDT(Local Description Table)根据x86,每个进程可以设置一个LDTLDT表也存放在RAM中,使用LDTR来指示当前的LDT表12/22/202210Linux OS Analysis由于段的用途不一由于段的用途不一样样,Intelx86提供下列几种提供下列几种段描述符段描述符数据段描
6、述符(Data Segment Descriptor)可以描述各种用户数据段和堆栈段代码段描述符(Code Segment Descriptor)描述一个用户代码段任务状态段描述符(Task State Segment Descriptor)描述一个任务的状态段局部描述符表描述符描述一个LDT段系统段描述符(System Segment Descriptor)12/22/202211Linux OS Analysis段描述符主要描述如下内容段描述符主要描述如下内容段的物理起始地址物理起始地址(base字段,32位)段长长度度(limit字段,20位)段长度的单单位位(粒度,G标志,1位)0:字
7、节为单位1:4KB为单位是否系统段(S标标志志,1位)0:系统段1:普通的段12/22/202212Linux OS Analysis类类型型字段(Type字段,4位)例如代码段、数据段、任务状态段、局部描述符段等等段的特特权级权级描述字段(DPL字段,2位)00b:只能被CPL=00b的内核代码段访问.11b:可以被任意代码段访问段存在存在标标志志(1位)0:该段当前不在内存中1:该段当前在内存中Descriptor Privilege Level12/22/202213Linux OS Analysis段描述符的格式段描述符的格式段基址、段长度、其他属性例如,0 x00cf9a000000
8、ffff12/22/202214Linux OS Analysis段段选择选择子(子(Segment Selector)16位段寄存器与GDT或LDT配合起来对相应的段进行寻址段寄存器中的值称为段选择子,16位13位的索引,指定GDT表中的相应的段描述符1位的TI(Table Indicator)(跟LDT表有关,Linux中基本未使用)2位RPL(request privilege level)当相应的段选择符装入到cs寄存器中时,表明了CPU的当前特权级(用户/内核)indexTIRPL 2 1 015Segment selector12/22/202215Linux OS Analysi
9、s段段选择选择子的使用和段描述符的快速子的使用和段描述符的快速访问访问段寄存器段选择子段描述符描述符表段()非编程寄存器段描述符12/22/202216Linux OS Analysis逻辑逻辑地址到地址到线线性地址的性地址的转换转换GDT或LDTGDTR或LDTR选择子偏移线性地址逻 辑 地 址12/22/202217Linux OS AnalysisLinux中的段中的段基于下面两个原因,linux中只使用了几个段段和页的同时存在在一定程度上有点多余。因为两者都可以划分进程的物理空间所有的进程希望使用同样的0-4G的逻辑空间。这样程序员不必考虑进程地址的问题,也让内核的内存管理变得简单一些
10、12/22/202218Linux OS AnalysisLinux下的全局描述符表(部分下的全局描述符表(部分)在arch/x86/kernel/head_32.S中内核数据段用户代码段用户数据段Linux中的GDT 在include/asm-x86/segment.h中12/22/202219Linux OS Analysis在arch/x86/boot/pm.c中在arch/x86/boot/pm.c中12/22/202220Linux OS Analysisarch/x86/kernel/cpu/common.c11/17/09_BOOT_CS0 x10=0000 0000 0001
11、0000b内核代码段,在GDT中相应的段描述符各个域有如下值Index=2RPL=0特权级4GB内核代码段内核数据段用户代码段用户数据段 0 x00cf9a000000ffff12/22/202223Linux OS Analysis_BOOT_DS0 x18=0000 0000 0001 1000b内核数据段,在GDT中相应的段描述符各个域有如下值Index=3RPL=0特权级内核代码段内核数据段用户代码段用户数据段4GB 0 x00cf92000000ffff12/22/202224Linux OS AnalysisLinux下下GDT表的初始化表的初始化1)在i386/boot/herd
12、er.S-i386/boot/main.c:main()-arch/x86/boot/pm.c:go_to_protected_mode-setup_gdt中GDT表中的内容GDT表基址的装载(此时还没有切换到保护模式)切换到保护模式之后,(代码)段寄存器的装载2)在i386/boot/compressed/head_32.S中各个数据段寄存器的装载3)在i386/kernel/head_32.S中boot_gdt和GDT基址的装载各段寄存器的重新装载early_gdt_descr和per_cpu_gdt_page 参见arch/x86/kernel/cpu/common.c12/22/202
13、225Linux OS Analysis硬件的分硬件的分页单页单元元分页单元:线性地址=物理地址为了效率起见,线性地址被分成以固定长度为单位的组,称为页。页内连续的线性地址被映射到连续的物理地址中。把线性地址映射到物理地址的数据结构叫做页表(page table)。页表存放在内存中,并在启用分页单元以前由内核对之进行初始化Intel处理器中,通过设置CR0寄存器的一个标志位来启用分页单元。12/22/202226Linux OS Analysis硬件的分硬件的分页单页单元元区分一下页和页框的概念一页指一系列的线性地址和包含于其中的数据页框(page frame)分页单元认为所有的RAM被分成了
14、固定长度的页框每个页框可以包含一页,也就是说一个页框的长度和一个页的长度是一样的页框是内存的一部分,是一个实际的存储区域。页只是一组数据块,可以存放在任何页框中12/22/202227Linux OS Analysis常常规规分分页页从i386起,intel处理器的分页单元处理4KB的页32位的线性地址被分成3个域目录(directory)最高的10位页表(Table)中间的10位偏移量(offset)最低的12位线性地址的转换分两步完成,每一步都基于一种转换表第一种称为页目录表(page directory)第二种称为页表(page table)正在使用的页目录表的物理地址存放在CPU的CR
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Linux 操作系统 分析
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内