linux内核 重复vmalloc分配,Linux内存管理机制

本文深入探讨Linux操作系统中的内存管理机制,重点讲解物理内存管理、伙伴算法、Slab分配器及内存管理函数等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Linux操作系统精讲,大连理工大学软件学院邱铁综合楼413,Tel:0411-87571632E_mail:[email protected]:[email protected]徐子川编著.清华大学出版社.2010.5,第16章内存管理,学习本章要达到的目标:结合操作系统原理课程,深入理解Linux系统物理内存管理机制;理解伙伴算法和Slab分配器的工作原理;熟悉操作系统提供的有关内存管理的内核函数;学会在Linux内核态下申请内存空间的方法。,,16.1关于Linux的内存管理,在Linux系统中对物理内存的管理主要涉及页面管理连续内存区管理非连续存储区管理,Linux物理内存管理方式,,16.1.1动态存储管理,一部分永久地分配给系统,作为内核代码段和只读数据段的载体,用来存放内核程序代码以及静态数据,这部分称为操作系统的静态存储器(staticmemory)。其它部分,则在Linux的管理下,进行内存的动态申请和释放,称为动态存储器(dynamicmemory)。,16.1.2页面管理,Linux采用页作为内存管理的基本单位,其采用的标准的页面大小为4KB因为4KB是大多数磁盘块大小的倍数,传输效率高,管理方便,无需考虑PSE,PAE,,内核使用页描述符来跟踪管理物理内存,每个物理页面都用一个页描述符表示页描述符用structpage的结构描述,所有物理页面的描述符,组织在mem_map的数组中,page结构则是对物理页面进行描述的一个数据结构,mem_map数组与物理内存的对应关系,,,Linux采用著名的伙伴(Buddy)算法来解决内存碎片问题。伙伴算法把所有的空闲页面分为10个页块链表,每个链表中的一个块含有2的幂次个页面(叫做“页块”或简称“块”)实例具体分析参见教材《Linux应用与开发典型实例精讲》第256页,伙伴算法实例,,16.1.3slab分配模式,在Linux系统中所用到的对象如inode、task_struct等,经常会涉及到大量对象的重复生成、使用和释放问题。这些对象在生成时,所包括的成员属性值都赋成确定的数值,并且在使用完毕,释放结构前,属性又恢复为未使用前的状态。,,Linux的slab内存分配模式的基本思想能够用合适的方法使得在对象前后两次被使用时,在同一块内存,或同一类内存空间,且保留了基本的数据结构,就可以大大提高效率。,,,16.2Linux的内存管理函数,vmalloc()是内核可以用来分配连续虚存,但非连续物理内存的方法。kmalloc分配在物理上连续的内存,这些内存是实际上存在的,并且是连续的,根据slab块进行分配。,16.3实例训练与分析,在用户空间用valloc/malloc分配内存在内核空间用kmalloc/vmalloc分配内存,16.3.1在用户空间用valloc/malloc分配内存,实现用valloc申请1MB内存单元程序退出时释放。,实例源码,#defineA_MEGABYTE1024*1024intmain(){char*some_memery;intmegabyte=A_MEGABYTE;intexit_code=EXIT_FAILURE;some_memery=(char*)valloc(megabyte);/*申请内存*/if(some_memery!=NULL){sprintf(some_memery,"Helloworld!\n");/*将字符串写入some_memery所指向内存*/printf("%s",some_memery);free(some_memery);/*释放内存*/printf("memeryisfree!\n");exit_code=EXIT_SUCCESS;}exit(exit_code);},运行结果,,16.3.2在内核空间用kmalloc/vmalloc分配内存,编写mem_kv.c模块文件实现对实际内存与虚拟内存的分配:#defineMEM_MALLOC_SIZE4096//申请内存的大小#defineMEM_MAJOR252//主设备号#defineMEM_MINOR_K0//次设备号:实存#defineMEM_MINOR_V1//次设备号:虚存char*mem_spkm,*mem_spvm;//定义实存、虚存指针structcdev*mem_cdev;,,/*设备文件结构体选项*/structfile_operationsmem_fops={.open=mem_open,//打开.release=mem_release,//释放.read=mem_read,//读操作.write=mem_write,//写操作};,,将mem_spkm指向内核实际内存空间,将mem_spvm指向内核虚拟内存空间,并将其加载进内核设备文件系统中。,,删除设备结构,将mem_spkm所指向的内核实际内存空间释放掉,将mem_spvm所指向内核虚拟内存空间释放掉。,,,,,,,,,,,,,,,编写mem_test.c文件实例源码参见教材《Linux应用与开发典型实例精讲》第264页,读写的内存为用kmalloc()申请的实际内存,,读写的内存为用vmalloc()申请的虚拟内存,,思考与练习,1.在Linux操作系统中,页面管理、内存区管理、非连续存储区管理之间的关系是怎样的?2.Linux操作系统对物理内存的管理方式有哪几种,各使用了什么算法?3.动态存储管理有哪些优点?4.Linux采用页面作为内存管理的基本单位,采用的标准的页面大小为4KB,为什么取此值?,思考与练习,5.Linux解决内存碎片问题的伙伴算法的原理是什么?请举例说明。6.Linux的slab内存分配模式的基本思想是什么?7.Linux的内存管理函数kmalloc()和vmalloc()的区别有哪些?8.以模块方式向Linux内核中申请一个长度为256字节的内存设备文件,并对其时行读写,如果超过申请的长度,会发生什么现象?,

展开阅读全文

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值