内存寻址xlanchen@2006.
6.
7在intelx86处理器下,有三种不同的地址逻辑地址:每个逻辑地址由一个段(segment)和偏移量(offset)组成线性地址:32位无符号整数,可以表示4G的地址空间物理地址:用于芯片级内存单元寻址.
它们与从CPU的地址引脚发送到内存总线上的电信号相对应地址转换过程物理地址线性地址分段单元分页单元逻辑地址为什么需要内存寻址机制保护内核不受恶意或者无意的破坏隔离各个用户进程方便程序的编写,使程序员可以抛开对物理内存的考虑,而且理论上可以使用任意大小的空间硬件的分段单元(1)段寄存器(segmentregister)为了快速方便的找到段选择符,处理器提供了段寄存器,目的是存放段选择符16位的段寄存器,有六个:cs,ss,ds,es,fs和gs其中3个寄存器CPU规定了专门的用途cs代码段寄存器,指向存放程序指令的段ss堆栈段寄存器,指向存放当前程序栈的段ds数据段寄存器,指向存放数据的段注意:cs寄存器还有一个很重要的功能:它含有一个两位的域,用以指明CPU当前特权级(currentprivilegelevel,CPL),值为0代表最高优先级,值为3代表最低优先级段描述符(segmentdescriptor)每个段由一个段描述符来表示,一个段描述符长度为8个字节全局描述符表(globaldescriptiontable,GDT)就用来存放段描述符GDTR寄存器用来存放GDT的起始地址(物理地址)段描述符的格式段选择子段寄存器中值称为段选择子,长度为16位13位的索引,指定GDT表中的相应的段描述符1位的TI(TableIndicator)(跟LDT表有关,Linux中基本未使用)2位RPL(requestprivilegelevel)当相应的段选择符装入到cs寄存器中时,表明了CPU的当前特权级indexTIRPL21015Segmentselector段选择子的使用逻辑地址到线性地址的转换Linux中的段基于下面两个原因,linux中只使用了几个段段和页的同时存在在一定程度上有点多余.
因为两者都可以划分进程的物理空间所有的进程希望使用同样的0-4G的逻辑空间.
这样程序员不必考虑进程地址的问题,也让内核的内存管理变得简单一些Linux下的全局描述符表(部分)__KERNEL_CS0x10=0000000000010000b内核代码段,在GDT中相应的段描述符各个域有如下值Index=2RPL=0特权级__KERNEL_DS0x18=0000000000011000b内核数据段,在GDT中相应的段描述符各个域有如下值Index=3RPL=0特权级__USER_CS用户代码段,用户态下所有进程共享__USER_DS用户数据段,用户态下所有进程共享硬件的分页单元分页单元把线性地址转换成物理地址为了效率起见,线性地址被分成以固定长度为单位的组,称为页.
页内连续的线性地址被映射到连续的物理地址中.
把线性地址映射到物理地址的数据结构叫做页表(pagetable).
页表存放在内存中,并在启用分页单元以前由内核对之进行初始化Intel处理器中,通过设置CR0寄存器的一个标志位来启用分页单元.
diyvm怎么样?diyvm商家VPS主机均2GB内存起步,三个地区机房可选,使用优惠码后每月69元起;DiyVM独立服务器开设在香港沙田电信机房,CN2线路,5M带宽,自动化开通上架,最低499元/月,配置是L5630*2/16G内存/120G SSD硬盘。DiyVM是一家成立于2009年的国人主机商,提供的产品包括VPS主机、独立服务器租用等,产品数据中心包括中国香港、日本大阪和美国洛杉矶等,...
活动方案:美国洛杉矶 E5 2696V2 2核4G20M带宽100G流量20元/月美国洛杉矶E5 2696V2 2核4G100M带宽1000G流量99元/季香港CN2 E5 2660V2 2核2G30M CN2500G流量119元/季日本CN2E5 2660 2核2G30M CN2 500G流量119元/季美国300G高防 真实防御E5 2696V2 2核2G30M...
数脉科技(shuhost)8月促销:香港独立服务器,自营BGP、CN2+BGP、阿里云线路,新客立减400港币/月,老用户按照优惠码减免!香港服务器带宽可选10Mbps、30Mbps、50Mbps、100Mbps带宽,支持中文本Windows、Linux等系统。数脉香港特价阿里云10MbpsCN2,e3-1230v2,16G内存,1T HDD 或 240G SSD,10Mbps带宽,IPv41个,...