内存管理篇-07页分配器接口-alloc_page

2024-08-25 01:52

本文主要是介绍内存管理篇-07页分配器接口-alloc_page,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

-----终于到了编码实战阶段了,前面都是在将思想和实现机制,即使看了源代码还是模模糊糊,不够清晰。

        本节通过内核接口从伙伴系统进行申请和释放内存。free_page && alloc_page。其实很多缓存机制最终都是通过伙伴系统申请一大片内存,然后内部再进行对这些页处理优化。

        伙伴系统提供了free_page和alloc_pages两个函数进行申请和释放内存,至于函数内部的实现机制,这里还没开始讲,主要讲了如何使用。

1.页分配器接口alloc_pages / __get_free_pages

  • 头文件:include/linux/gfp.h 
  • 编程实例:使用页分配器接口申请内存

alloc_pages(gfp_t gfp_mask, unsigned int order)参数gfp_mask指定分配页面时使用的内存标志。这些标志控制着内核如何选择用于分配的页面,例如是否可以睡眠等待更多空闲页面,是否可以使用交换空间等。函数用于从空闲页面池中分配一组连续的物理页面。它通常用于需要连续物理内存的情况,例如设备驱动程序中的 DMA 操作。

  • alloc_pages 是一个更高级别的函数,通常用于应用程序级别的内存分配。
  • __get_free_pages 是一个内部函数,主要用于内核内部,不推荐直接在用户级代码中使用。
  • 这两个函数都接受相同的参数,即 gfp_mask 和 order,用于控制分配的页面数量和分配标志。

2.使用示例

#include <linux/init.h>
#include <linux/module.h>
#include <linux/fs.h>
#include <linux/mm.h>
#include <linux/gfp.h>#define PAGE_ORDER 1struct page *my_page;
struct page *you_page;
unsigned long int vir_addr;static int __init hello_init(void)
{my_page = alloc_pages(GFP_KERNEL, PAGE_ORDER);you_page = __get_free_pages(GFP_KERNEL, PAGE_ORDER);printk("page frame no: %lx\n", page_to_pfn(my_page));printk("physical addr: %x\n",  page_to_phys(my_page));printk("physical addr: %x\n", (unsigned int)page_address(my_page));vir_addr = (unsigned int)page_address(my_page);return 0;
}static void __exit hello_exit(void)
{free_pages(vir_addr, PAGE_ORDER);__free_pages(you_page, PAGE_ORDER);
}module_init(hello_init);
module_exit(hello_exit);
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Your Name");
MODULE_DESCRIPTION("A simple Hello World kernel module");

3.alloc_pages的实现

get_page_from_freelist 函数是 Linux 内核内存管理中的关键组件,用于从空闲页面列表中分配一个或多个连续的物理页面。它通过遍历可能的内存区域,并根据分配标志和上下文来选择最合适的页面进行分配。该函数还考虑了 NUMA 环境、水位线、页面回收等因素,以尽可能高效地分配内存。

get_page_from_freelist 函数是 Linux 内核内存管理中的关键组件,用于从空闲页面列表中分配一个或多个连续的物理页面。它通过遍历可能的内存区域,并根据分配标志和上下文来选择最合适的页面进行分配。该函数还考虑了 NUMA 环境、水位线、页面回收等因素,以尽可能高效地分配内存

 __alloc_pages_slowpath 函数是 Linux 内核内存管理中的关键组件之一,用于处理快速路径分配失败的情况。它通过一系列的尝试来分配物理页面,包括直接压缩、直接回收和 OOM 处理等。该函数还考虑了 NUMA 环境、页面回收、压缩等因素,以尽可能高效地分配内

这篇关于内存管理篇-07页分配器接口-alloc_page的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1104213

相关文章

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Java 后端接口入参 - 联合前端VUE 使用AES完成入参出参加密解密

加密效果: 解密后的数据就是正常数据: 后端:使用的是spring-cloud框架,在gateway模块进行操作 <dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>30.0-jre</version></dependency> 编写一个AES加密

Sentinel 高可用流量管理框架

Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 Sentinel 具有以下特性: 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应

JVM内存调优原则及几种JVM内存调优方法

JVM内存调优原则及几种JVM内存调优方法 1、堆大小设置。 2、回收器选择。   1、在对JVM内存调优的时候不能只看操作系统级别Java进程所占用的内存,这个数值不能准确的反应堆内存的真实占用情况,因为GC过后这个值是不会变化的,因此内存调优的时候要更多地使用JDK提供的内存查看工具,比如JConsole和Java VisualVM。   2、对JVM内存的系统级的调优主要的目的是减少

JVM 常见异常及内存诊断

栈内存溢出 栈内存大小设置:-Xss size 默认除了window以外的所有操作系统默认情况大小为 1MB,window 的默认大小依赖于虚拟机内存。 栈帧过多导致栈内存溢出 下述示例代码,由于递归深度没有限制且没有设置出口,每次方法的调用都会产生一个栈帧导致了创建的栈帧过多,而导致内存溢出(StackOverflowError)。 示例代码: 运行结果: 栈帧过大导致栈内存

理解java虚拟机内存收集

学习《深入理解Java虚拟机》时个人的理解笔记 1、为什么要去了解垃圾收集和内存回收技术? 当需要排查各种内存溢出、内存泄漏问题时,当垃圾收集成为系统达到更高并发量的瓶颈时,我们就必须对这些“自动化”的技术实施必要的监控和调节。 2、“哲学三问”内存收集 what?when?how? 那些内存需要回收?什么时候回收?如何回收? 这是一个整体的问题,确定了什么状态的内存可以