48 slab 的实现

前言

这里说的是 内核中分配小对象的一种内存分配方式 slab 

呵呵 经典程度不必多说了, 内核使用的大多数数据结构 基本上是基于 slab 进行内存分配的 

这里 我们来看一下 slab 

 

 

如何分配对象  

几个分配层级, c->free_list, c->page, c->partial, new_slab 

 

1. 先来看一下走 new_slab 的流程 

如果尝试了 c->free_list, c->page, partial 之后都没有找到可用的 page, 那么会走 new_slab 来尝试分配新的物理页面, 这里的相关代码在 slub.allocate_slab

 

如下是 分配物理页 部分, 最终调用了 alloc_page, alloc_pages

然后之后 初始化 page 的 slab_cache, 初始化 freelist 为物理页 的虚拟地址

 

4f3df7f5b4b04ada88ef8e4fd3fa9e7e.png942c14e88070401cb8b734f73f4d23be.png

 

 

更新 kmem_cache_node 对应的统计信息

 

34035d7d76344b1497e22ed9e746c55a.png

 

然后 ___slab_alloc 是回到上面 new_slab_objects, 之后 更新 c->free_list, load_freelist

然后之后是 获取 free_list 返回, 并更新 c->free_list 为下一个空闲元素 

 

9309ab1730e9410e9a937aaf0661d268.pnga878cd5ff52d4546b23bef59bed8befe.png 

 

然后是走 后面的 slab_alloc_node 统一的一部分流程

8cd899b7b95c417987cc516105151bd0.png

 

 

2. 再来看一下走 partial 的流程 

取 partial 有几条路径, 如下这里是 取的 kmem_cache_cpu 中暂存的 partial, 然后之后 进行重试 

8e075bd190cb414dba3576d4076540fa.png

 

获取当前 kmem_cache_cpu 对应的 kmem_cache_node 维护的 partial 链表中获取一个可用的 page, 然后更新为 c->page, 返回 分配的对象

如果是 没有获取到空间, 则从所有的 kmem_cache_node 中尝试分配对象, 更新 c->page

56a1434d834f4d3eb49a7212f54d01f6.png

 

 

3. 再来看一下走 c->page 的流程 

这里是从 c->page 获取 free_list 的流程, 拿到 free_list 之后, 获取到空闲区间 分配对象, 然后走后面的 slab_alloc_node 统一的一部分流程

2eb5de7473dd45e5999746703fb88fb0.png

dc1d66ee1ee448f0865ab20d38e87111.png

 

根据 page 获取 free_list 的实现如下, cas 更新 page->free_list 为 null

获取的是 page 中暂存的 free_list

ae9977dc8d954ce98b667367f54ee27e.png

 

 

4. 再来看一下走 c->free_list 的流程, 这是 最 common 的场景 

取得是 c->free_list, 然后之后更新 c->free_list 为 next, next 是存在 next的s->offset偏移处 

687205ffecc746429517761b3e65e0a9.png

 

 

如何释放对象 

如果待释放的物理页和 kmem_cache_cpu 持有的物理页一致, 最 common 的场景 

cas 将 待释放对象添加到 c->free_list 所处的链表, 并更新 c->free_list 为 x 

5dda99bb5dfa4e329da0683723b030de.png

 

如果待释放的物理页和 kmem_cache_cpu 持有的物理页不一致 

cas 将 待释放对象添加到 c->free_list 所处的链表, 并更新 c->free_list 为 x 

如果当前页没有对象了, 并且 partial 的数量大于 kmem_cache 中约束的最小 partial 数量, 则从 partial, full 列表中移除当前页, 并且 更新 kmem_cache_node 的相关统计, free_pages 给定的物理页 

如果当前页 还有对象, 或者当前页需要保留

如果 当前物理页在释放对象之前已经占满, 则将当前 物理页添加到 partial 列表中

否则 直接返回 

 

9c0f316e49074091b29bdb0efb6a0190.png7d25523e372747a98838ad83481f98b0.png

0074ad3b8ef44724a52f1063bdc44564.png

d02e6fe8eba547e9aff81eb33e251a32.png

 

 

完 

 

 

 

 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/688799.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

查看 PyCharm 代码文件目录位置

查看 PyCharm 代码文件目录位置 1. Show in Files2. Copy PathReferences 1. Show in Files right click -> Show in Files / Show in Explorer 即可打开目录 2. Copy Path right click -> Copy Path 即可复制目录或文件路径 References [1] Yongqiang Cheng, http…

目标检测YOLO系列从入门到精通技术详解100篇-【目标检测】机器视觉(基础篇)(十七)

目录 几个高频面试题目 如何选择合适的面扫相机 算法原理 分辨率与视野 像素尺寸与景深 像素尺寸

通过Linux终端搭建基于HTTP隧道的文件传输系统

嘿,Linux小侠们,准备好挑战一项酷炫的任务了吗?今天我们要一起通过Linux终端搭建一个基于HTTP隧道的文件传输系统,让我们的文件在网络的海洋中畅游无阻! 在开始之前,让我们先来想象一下这个场景&#xff1…

自建AWS S3存储服务

unsetunset前言unsetunset AWS S3(Amazon S3,全名为亚马逊简易存储服务),是亚马逊公司利用其亚马逊网络服务系统所提供的网络在线存储服务。我常用的很多SaaS服务中提供的文件存储功能,底层也都是AWS S3,比…

线代:认识行列式、矩阵和向量

本文主要参考的视频教程如下: 8小时学完线代【中国大学MOOC*小元老师】线性代数速学_哔哩哔哩_bilibili 另外这个视频可以作为补充: 【考研数学 线性代数 基础课】—全集_哔哩哔哩_bilibili 行列式的概念和定义 一般会由方程组来引出行列式 比如一个二阶…

【Python】测量WAV文件播放时长

问题 windows播放WAV音频文件,一般使用API函数,如PlaySound。实际使用发现,从调用PlaySound到实际开始播放存在200ms以上的延时,在游戏编程中音效实时性是个需要解决的问题。 本文主要讨论,windows播放WAV文件的衍生…

后端开发怎么学?

后端开发怎么学? 后端开发可以简单地理解为与前端开发相对应的开发方向。前端开发主要负责构建用户界面、维护用户体验等方面的工作,而后端开发则主要负责处理数据、逻辑和算法等方面的工作。后端开发旨在为前端应用程序提供支持,以帮助实现可…

微信小程序之开发会议OA项目

目录 前言 本篇目标 首页 会议 投票 个人中心 会议OA项目-首页 配置 tabbar mock工具 page swiper 会议信息 会议OA项目-会议 自定义tabs组件 会议管理 会议OA项目-投票 会议OA项目-个人中心 前言 文章含源码资源,投票及个人中心详细自行查看…

Mongodb 文本检索

Mongodb支持对字符串字段的文本检索。在Mongodb atlas中, 对这种文本检索的功能进行了增强。 提到文本检索, 难免不会想到实现非常火爆的AI, 聊天服务等时髦技术。mongodb提供的这种文本检索功能适当的算法实践,似乎可以支持这些应…

【开源】SpringBoot框架开发服装店库存管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 角色管理模块2.3 服装档案模块2.4 服装入库模块2.5 服装出库模块 三、系统设计3.1 用例设计3.2 数据库设计3.2.1 角色表3.2.2 服装档案表3.2.3 服装入库表3.2.4 服装出库表 四、系统展示五、核心代码5.…

VTK Python PyQt 监听键盘 控制 Actor 移动 变色

KeyPressInteractorStyle 在vtk 中有时我们需要监听 键盘或鼠标做一些事; 1. 创建 Actor; Sphere vtk.vtkSphereSource() Sphere.SetRadius(10)mapper vtk.vtkPolyDataMapper() mapper.SetInputConnection(Sphere.GetOutputPort()) actor vtk.vtkAc…

JSON转换List<Map<String, Object>>、Map<String, Object>

废话就不说了 早上10点研究到现在 获取redis的JSON字符串 String getPalletListNew redisService.getRedis(“getPalletListNew”, abroad “” goodsLevel “” startPort “” destinationPort “” maxTon “” minTon); 转换Map<String,Object> public …

找数字

题目描述 已知两个正整数 a&#xff0c;b 。现有一个大于 1 的整数 x &#xff0c;将其作为除数分别除 a&#xff0c;b 得到的余数相同。 请问满足上述条件的 x 的最小值是多少&#xff1f;数据保证 x 有解。 输入 共一行&#xff0c;两个整数 a , b 。 输出 输出这个最小…

立创EDA专业版快速使用和一些快捷键

立创EDA专业版 介绍原理图PCB快捷键原理图PCB 介绍 器件 符号 封装 3D模型 属性 仅支持放置器件在原理图或PCB 一个Board(板&#xff09;只能有一个原理图和PCB&#xff0c;一个原理图可以有多页 原理图 网络标签 是给连接线命名 新建图页 如果一个图页上画不下&#…

第4讲 小程序首页实现

首页 create.vue <template><view class"vote_type"><view class"vote_tip_wrap"><text class"type_tip">请选择投票类型</text><!-- <text class"share">&#xe739;分享给朋友</text&g…

嵌入式开发之SQLite数据库

SQLite是一种轻量级的嵌入式关系型数据库管理系统&#xff08;RDBMS&#xff09;&#xff0c;它是一个开源项目&#xff0c;实现了自包含、零配置、无服务器的特性。以下是SQLite的详细介绍&#xff1a; SQLite特点 轻量级&#xff1a;SQLite的代码库极其精简&#xff0c;不需…

STM32中断定时器的使用

使用systimer来产生较为精确的定时&#xff0c;之前使用for循环来产生。 用示例工程时产生错误&#xff0c;原因是调用F103的3种容量器件&#xff0c;需要更换S汇编头函数。 另外在工程设置中&#xff0c;需要把HD设置为MD&#xff0c;重新编译即可成功。

二叉树基础总结

目录 树的定义&#xff1a; 深度和高度&#xff1a; 二叉树 由来 二叉树种类&#xff1a; 满二叉树&#xff1a; 完全二叉树&#xff1a; 严格二叉树&#xff08;Strict Binary Tree&#xff09;&#xff1a; 平衡二叉树&#xff08;Balanced Binary Tree&#xff09;…

DoRA(权重分解低秩适应):一种新颖的模型微调方法

来自&#xff1a;小互 DoRA&#xff08;权重分解低秩适应&#xff09;&#xff1a;一种新颖的模型微调方法 DoRA在LoRA的基础上进一步发展&#xff0c;通过将预训练权重分解为“幅度”和“方向”两个部分进行微调。 这种权重分解方法允许DoRA更精细地控制模型的学习过程&…

如何将shape数据 导入到Postgresql数据库中(单个和批量)

一. 背景 很多时候我们需要将shape数据导入到Postgresql数据库&#xff0c;将数据db化。 本文主要讲解三种方式&#xff1a; 使用QGIS工具导入&#xff08;单个&#xff09;、使用postgresql2 命令工具导入&#xff08;单个&#xff09;、使用python脚本批量导入shape数据&…