5驱动中的内存分配.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第五章 驱动中的内存分配1、kmalloc 原型: #include linux/slab.h void *kmalloc(size_t size, int flags); 特点: 速度快; 不清零, 分配的区仍然持有它原来的内容; 物理内存中连续 用于分配的小内存,不能用于分配大内存 使用kfree释放分配的内存 flags 参数 GFP_KERNEL:最常用的内核内存分配选项,代表运行在内核空间的进程而进行分配内存,内部最终通过调用 __get_free_pages 来进行,能够使当前进程在少内存的情况下睡眠来等待一页。 GFP_ATOMIC :用于中断处理, tasklet, 和内核定时器(关于中断处理, tasklet, 和内核定时器参见后文),不睡眠。 可以与上述标志或操作的标志 __GFP_DMA:在DMA区内分配内存 __GFP_HIGHMEM:分配的内存可以位于高端内存. 内存区分为3类: 可用于DMA的内存:位于特别地址范围的内存, 外设可以在这里进行 DMA 存取. 在 x86, DMA 区用在 RAM 的前 16 MB 普通内存 高端内存:用于存取大量内存 size参数 内核使用面向页的分配技术来最好地利用系统 RAM 创建一套固定大小的内存对象池. 处理分配请求时, 进入一个持有足够大的对象的池子并且将整个内存块递交给请求者 分配小于128 KB 的内存 2、get_free_page 一个模块需要分配大块的内存, 它最好是使用一个面向页的技术。为分配页, 下列函数可用: get_zeroed_page(unsigned int flags):返回一个指向新页的指针并且用零填充了该页. __get_free_page(unsigned int flags):类似于 get_zeroed_page, 但是没有清零该页. __get_free_pages(unsigned int flags, unsigned int order):分配并返回一个指向一个内存区第一个字节的指针, 内存区可能是几个(物理上连续)页长,但是没有清零 flags 参数同 kmalloc order 是你在请求的或释放的页数的以 2 为底的对数(即, log2N),如果你要一个页 order 为 0, 如果你请求 8 页就是 3 当一个程序用完这些页, 它可以使用下列函数之一来释放它们: void free_page(unsigned long addr); void free_pages(unsigned long addr, unsigned long order); 3、vmalloc 它在虚拟内存空间分配一块连续的内存区. 尽管这些页在物理内存中不连续 (使用一个单独的对 alloc_page 的调用来获得每个页), 内核看它们作为一个一个连续的地址范围 #include linux/vmalloc.h void *vmalloc(unsigned long size); void vfree(void * addr);

文档评论(0)

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档