Linux内核38-内核同步实际例子

简介: Linux内核38-内核同步实际例子

要想一个系统不崩溃,性能还得好,同步技术是非常关键的。但是,完全避免竞态条件几乎是难于上青天。因为它要求对内核各个功能模块之间的交互得有一个清晰深刻的理解。下面我们看一下Linux内核中一些具体保护数据访问的示例,加深对其理解,甚至可以在自己的内核设计上借鉴一下。


1 引用计数器


引用计数器是内核中保护某个资源或者模块的一种有效手段,比如分配内存,使用某个内核模块,或者打开某个文件的时候。它是一个atomic_t类型的原子变量。当内核中某个程序访问该资源的时候,计数器加1,当内核程序释放资源,计数器减1。当计数器的值为0时,它就可以被释放了。


2 大内核锁


关于这部分请参阅网友universus写的这篇文章-大内核锁将何去何从。我觉得写得还是非常详细的。


3 内存描述符读写信号量


每个内存描述符都可以使用数据结构mm_struct进行表达,它有一个成员mmap_sem,专门用来保护该描述符避免竞态条件的发生。因为每个内存描述符可以被几个轻量级进程共享。这是用户态多线程共享内存的硬件基础。

假设内核需要为某个进程创建或扩展一段内存区域。为此,调用do_mmap()函数,分配一个新的类型为vm_area_struct虚拟内存给进程。在这个过程中,如果已经没有内存可用,且每段内存都有一个信号量保护,所以,当前进程挂起,其它进程还可以正常访问他们的共享内存继续运行。但是,如果没有信号量保护,当前进程申请内存就会成功(其实可能占用了其它进程的内存)。而与当前进程共享内存的进程就会请求访问内存描述符(比如,写时复制(Copy on Write)导致的页错误),从而导致严重的数据损坏。

此处一般使用的是读/写信号量,因为大部分的内核函数,比如页错误异常处理程序只需要查看内存描述符,不会修改它。这样可以提高系统的并发性能。


4 Slab Cache列表信号量


slab是一种Linux内核内存分配算法,slab分配算法采用cache存储内核对象。这些对象的描述符使用一个列表进行管理。这个列表使用一个称为cache_chain_sem的信号量进行保护,从而对列表进行独占访问。

因为往这个列表中插入新对象的同时,kmem_cache_shrink()和kmem_cache_reap()会扫描这个列表,这就带来了竞态条件的发生。当然了,中断不会调用这些函数,所以不需要信号量。所以,主要是在支持内核抢占的多核和单核系统中起作用。所以选择信号量而不是自旋锁。


相关文章
|
4月前
|
安全 网络协议 Linux
深入理解Linux内核模块:加载机制、参数传递与实战开发
本文深入解析了Linux内核模块的加载机制、参数传递方式及实战开发技巧。内容涵盖模块基础概念、加载与卸载流程、生命周期管理、参数配置方法,并通过“Hello World”模块和字符设备驱动实例,带领读者逐步掌握模块开发技能。同时,介绍了调试手段、常见问题排查、开发规范及高级特性,如内核线程、模块间通信与性能优化策略。适合希望深入理解Linux内核机制、提升系统编程能力的技术人员阅读与实践。
448 1
|
4月前
|
Ubuntu Linux
Ubuntu 23.04 用上 Linux 6.2 内核,预计下放到 22.04 LTS 版本
Linux 6.2 带来了多项内容更新,修复了 AMD 锐龙处理器设备在启用 fTPM 后的运行卡顿问题,还增强了文件系统。
|
4月前
|
Ubuntu Linux
Ubuntu 23.10 现在由Linux内核6.3提供支持
如果你想在你的个人电脑上测试一下Ubuntu 23.10的最新开发快照,你可以从官方下载服务器下载最新的每日构建ISO。然而,请记住,这是一个预发布版本,所以不要在生产机器上使用或安装它。
|
4月前
|
传感器 监控 Ubuntu
10 月发布,Ubuntu 23.10 已升级到 Linux Kernel 6.3 内核
硬件方面,Linux 6.3 引入了在 HID 中引入了原生的 Steam Deck 控制器接口,允许罗技 G923 Xbox 版赛车方向盘在 Linux 上运行;改善 8BitDo Pro 2 有线控制器的行为;并为一系列华硕 Ryzen 主板添加传感器监控。
|
4月前
|
Ubuntu Linux
Ubuntu24.04LTS默认采用Linux 6.8内核,实验性版本可通过PPA获得
IT之家提醒,当下的 Ubuntu 23.10 也是一个“短期支持版本”,该版本将在今年 7 月终止支持,而今年 4 月推出的 Ubuntu 24.04 LTS 长期支持版本将获得 5 年的更新支持。
|
4月前
|
监控 Ubuntu Linux
什么Linux,Linux内核及Linux操作系统
上面只是简单的介绍了一下Linux操作系统的几个核心组件,其实Linux的整体架构要复杂的多。单纯从Linux内核的角度,它要管理CPU、内存、网卡、硬盘和输入输出等设备,因此内核本身分为进程调度,内存管理,虚拟文件系统,网络接口等4个核心子系统。
342 0
|
4月前
|
Web App开发 缓存 Rust
|
4月前
|
Ubuntu 安全 Linux
Ubuntu 发行版更新 Linux 内核,修复 17 个安全漏洞
本地攻击者可以利用上述漏洞,攻击 Ubuntu 22.10、Ubuntu 22.04、Ubuntu 20.04 LTS 发行版,导致拒绝服务(系统崩溃)或执行任意代码。
|
4月前
|
Ubuntu 机器人 物联网
Linux Ubuntu 22.04 LTS 测试版实时内核已可申请
请注意,在启用实时内核后您需要手动配置 grub 以恢复到原始内核。更多内容请参考: