内存管理篇-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

相关文章

详解Java如何向http/https接口发出请求

《详解Java如何向http/https接口发出请求》这篇文章主要为大家详细介绍了Java如何实现向http/https接口发出请求,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用Java发送web请求所用到的包都在java.net下,在具体使用时可以用如下代码,你可以把它封装成一

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

Java后端接口中提取请求头中的Cookie和Token的方法

《Java后端接口中提取请求头中的Cookie和Token的方法》在现代Web开发中,HTTP请求头(Header)是客户端与服务器之间传递信息的重要方式之一,本文将详细介绍如何在Java后端(以Sp... 目录引言1. 背景1.1 什么是 HTTP 请求头?1.2 为什么需要提取请求头?2. 使用 Spr

关于Java内存访问重排序的研究

《关于Java内存访问重排序的研究》文章主要介绍了重排序现象及其在多线程编程中的影响,包括内存可见性问题和Java内存模型中对重排序的规则... 目录什么是重排序重排序图解重排序实验as-if-serial语义内存访问重排序与内存可见性内存访问重排序与Java内存模型重排序示意表内存屏障内存屏障示意表Int

SpringBoot使用minio进行文件管理的流程步骤

《SpringBoot使用minio进行文件管理的流程步骤》MinIO是一个高性能的对象存储系统,兼容AmazonS3API,该软件设计用于处理非结构化数据,如图片、视频、日志文件以及备份数据等,本文... 目录一、拉取minio镜像二、创建配置文件和上传文件的目录三、启动容器四、浏览器登录 minio五、

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

IDEA中的Kafka管理神器详解

《IDEA中的Kafka管理神器详解》这款基于IDEA插件实现的Kafka管理工具,能够在本地IDE环境中直接运行,简化了设置流程,为开发者提供了更加紧密集成、高效且直观的Kafka操作体验... 目录免安装:IDEA中的Kafka管理神器!简介安装必要的插件创建 Kafka 连接第一步:创建连接第二步:选

NameNode内存生产配置

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

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

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