Linux操作系统分析中国科学技术大学计算机系陈香兰(0512-87161312)xlanchen@ustc.
edu.
cnAutumn2009进程地址空间内核态和用户态分配内存的不同内核中的函数以直接了当的方式获得动态内存内核是操作系统中优先级最高的成分.
内核信任自己采用我们上次课介绍的页面级内存分配和小内存分配线性空间(3GB~4GB)线性空间(<3GB)物理内存:highmem物理内存:DMA物理内存:Normal内核态和用户态分配内存的不同给用户态进程分配内存时请求被认为是不紧迫的用户进程不可信任因此,当用户态进程请求动态内存时,并没有立即获得实际的物理页框,而仅仅获得对一个新的线性地址区间的使用权这个线性地址区间会成为进程地址空间的一部分,称作线性区(memoryareas)进程地址空间进程最多能访问4GB的线性地址空间但进程在访问某个线性空间之前,必须获得该线性空间的许可因此,一个进程的地址空间是由允许该进程访问的全部线性地址组成内核使用线性区资源来表示线性地址空间每个线性区由起始线性地址、长度和一些存取权限描述与进程地址空间相关的描述符线性区的开始和结束都必须4KB对齐进程获得新线性区的一些典型情况:刚刚创建的新进程使用exec系统调用装载一个新的程序运行将一个文件(或部分)映射到进程地址空间中当用户堆栈不够用的时候,扩展堆栈对应的线性区……与创建、删除线性区相关的系统调用brk()改变进程堆的大小execve()Loadsanewexecutablefile,thuschangingtheprocessaddressspace_exit()Terminatesthecurrentprocessanddestroysitsaddressspacefork()Createsanewprocess,andthusanewaddressspacemmap()Createsamemorymappingforafile,mmap2()thusenlargingtheprocessaddressspacemremap()扩大或缩小线性区remap_file_pages()Createsanon-linearmappingforafilemunmap()Destroysamemorymappingforafile,thuscontractingtheprocessaddressspaceshmat()Attachesasharedmemoryregionshmdt()Detachesasharedmemoryregion线性区(memoryarea)比如0x08048000——0x0804C000这段线性地址空间被分配给了一个进程,进程就可以访问这段地址空间进程只能访问某个有效的memoryarea.
进一步讲,这个area可以被标志为只读或者不可执行(nonexecutable)如果进程试图访问一个有效的area之外的地址或者用不正确的方式访问一个有效的area,内核将通过段异常(segmentationfault)杀死这个进程线性区中可以包含各种内容可执行文件代码段的内存映射,就是.
textsection数据段的内存映射,.
datasectionzeropage的内存映射用来包含未初始化的全局变量,.
bsssection为库函数和链接器附加的代码、数据、bss段文件的内存映射共享内存的映射匿名内存区域的映射,比如通过malloc()函数申请的内存区域进程地址空间中所有有效的线性地址都确定的存在于一个area中memoryareas不重叠进程中每个单独的area对应一个不同内存区:堆栈、二进制代码、全局变量、文件映射等等增加或删除一个线性区task_struct中的内存描述符参见include/linux/mm_types.
h主要数据项的说明参见ULK3中文版354页Include/linux/sched.
h:task_struct分配一个内存描述符copy_mm函数用来在fork()调用中从父进程拷贝内存描述符其中间接调用mm_alloc_pgd来分配一个新的页表而mm_struct数据结构本身的空间是从mm_cachep指向的slab缓存中通过allocate_mm()宏分配得到的如果父进程在fork()创建子进程时,通过一些标志指明要和子进程共享地址空间.
那么,只需要kernel/fork.
c:copy_mmdo_forkcopy_processcopy_mmmm_alloc_pgd释放一个内存描述符在进程退出时,exit_mm()函数被调用首先做一些清除工作,更新一些内核全局统计数据接着调用mmput(),这个函数减内存描述符的mm_users域如果mm_users域变成了0,就调用mmdrop()函数来减mm_count域如果mm_count域变成了0,就由free_mm()宏调用kmem_cache_free()函数把mm_struct返还给mm_cachp指向slab缓存kernel/exit.
c:exit_mmdo_exitexit_mmKernel/fork.
c线性区(memoryareas)每个线性区由一个vm_area_struct结构来表示这个结构描述了一段给定的内存区间区间中的地址都有同样的属性,比如同样的存取权限和相关的操作函数用这个结构可以表示各种线性区,比如映射可执行的二进制代码的线形区、用作用户态堆栈的线形区等等include/linux/mm_types.
h线性区的存取权限vm_flags域描述有关这个线性区全部页的信息.
例如,进程访问每个页的权限是什么.
还有一些标志描述线性区自身,例如它应该如何增长VM_READ,VM_WRITE,VM_EXECVM_SHAREDVM_RESERVEDVM_GROWSUPinclude/linux/mm.
h线性区的链表和红黑树通过内存描述符中的两个域mmap和mm_rb都可以访问线性区.
事实上,它们都指向了同一个vm_area_struct结构,只是链接的方式不同mmap指向的线性区链表用来遍历整个进程的地址空间红黑树mm_rb用来定位一个给定的线性地址落在进程地址空间中的哪一个线性区中mmap_cache用来缓存最近用过的线性区处理线性区内核进程需要对一个线性区进行处理,比如确定一个给定线性地址是否存在于一个线性地址空间中find_vma(),查找一个线性地址两个参数:进程内存描述符的地址mm和线性地址addrfind_vma_intersection(),查找一个与给定地址区间重叠的线性区get_unmapped_area(),查找一个空闲的地址区间arch_get_unmapped_areashm_get_unmapped_areainsert_vm_struct(),向内存描述符链表中插入一个线性区mm/mmap.
cinclude/linux/mm.
hmm/mmap.
cmm/mmap.
c创建一个线性区间mmap()和do_mmap(),创建一个线性区根据file参数映射指定的文件中偏移量为offset,长度为len的一段内容addr参数指明从何处开始查找一段可用的空闲线性地址区间Prot参数指定这个区间所包含的页的存取权限flags参数指定这个创建的线性区本身的一些标志staticinlineunsignedlongdo_mmap(structfile*file,unsignedlongaddr,unsignedlonglen,unsignedlongprot,unsignedlongflag,unsignedlongoffset)include/linux/mm.
h删除一个线性区间munmap()和do_munmap()do_munmap()函数从进程地址空间中删除一段线性空间mm参数指向了当前进程的内存描述符addr参数为线性区的起始地址len参数指明要删除的区间大小intdo_munmap(structmm_struct*mm,unsignedlongaddr,size_tlen)mm/mmap.
c缺页异常(i386中14号异常)如前所述,内核只是通过mmap()等调用分配了一些线性地址空间给进程,并没有真正的把实际的物理页框分配给进程当进程试图访问这些分配给它的地址空间时,比如一段线性地址空间映射的是二进制代码,则进程被调度执行的时候会跳转到这个地址上去执行.
此时,并没有物理页框对应于这些线性地址,从而会引发一个缺页异常缺页异常处理程序do_page_fault缺页异常处理程序处理缺页异常.
它可以判断出这是不是一个合法的缺页异常,如果是,则负责给这段线性地址分配一些物理页框并把磁盘中对应的文件写入这些物理页框这样进程得以正常运行.
Thanks!
Theend.
tmthosting怎么样?tmthosting家本站也分享过多次,之前也是不温不火的商家,加上商家的价格略贵,之到斯巴达商家出现,这个商家才被中国用户熟知,原因就是斯巴达家的机器是三网回程AS4837线路,而且也没有多余的加价,斯巴达家断货后,有朋友发现TMTHosting竟然也在同一机房,所以大家就都入手了TMTHosting家的机器。目前,TMTHosting商家放出了夏季优惠,针对VPS推...
wordpress简洁英文主题,wordpress简洁通用大气的网站风格设计 + 更适于欧美国外用户操作体验,完善的外贸企业建站功能模块 + 更好的移动设备特色模块支持,更高效实用的后台自定义设置 + 标准高效的代码程序功能结构,更利于Goolge等国际搜索引擎的SEO搜索优化和站点收录排名。点击进入:wordpress简洁通用型高级外贸主题主题价格:¥3980 特 惠 价:¥1280安装环境:运...
搬瓦工vps(bandwagonhost)现在面向中国大陆有3条顶级线路:美国 cn2 gia,香港 cn2 gia,日本软银(softbank)。详细带宽是:美国cn2 gia、日本软银,都是2.5Gbps~10Gbps带宽,香港 cn2 gia为1Gbps带宽,搬瓦工是目前为止,全球所有提供这三种带宽的VPS(云服务器)商家里面带宽最大的,成本最高的,没有第二家了! 官方网站:https...
linux查看进程为你推荐
缓冲区溢出教程如何防止高手使用缓冲区溢出?免费qq空间装扮有办法免费装扮QQ空间吗??idc前线钢铁雄心2修改器商标注册查询官网如何在网上查询商标是否注册?二层交换机集线器和二层交换机,三层交换机的区别电子商务网站模板我想开发一个电子商务网站,但是想加入自己设计的模板,可以吗?小米手柄小米蓝牙游戏手柄怎么连接游戏怎么上传音乐怎样可以上传本地音乐到网上?三星s8什么时候上市大约什么时候买S8合适怎么在图片上写文字怎么才能在图片上写字呢
什么是域名 singlehop 美国翻墙 安云加速器 视频存储服务器 68.168.16.150 国外空间服务商 天猫双十一秒杀 typecho 好看qq空间 有奖调查 工信部icp备案号 赞助 太原网通测速平台 创建邮箱 smtp服务器地址 谷歌台湾 申请免费空间 登陆qq空间 广州服务器托管 更多