0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

一文解读Linux进程冻结技术

454398 来源:蜗窝科技 作者:itrocker 2020-09-30 15:26 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

1 什么是进程冻结

进程冻结技术(freezing of tasks)是指在系统hibernate或者suspend的时候,将用户进程和部分内核线程置于“可控”的暂停状态。

2 为什么需要冻结技术

假设没有冻结技术,进程可以在任意可调度的点暂停,而且直到cpu_down才会暂停并迁移。这会给系统带来很多问题:

(1)有可能破坏文件系统。在系统创建hibernate image到cpu down之间,如果有进程还在修改文件系统的内容,这将会导致系统恢复之后无法完全恢复文件系统;

(2)有可能导致创建hibernation image失败。创建hibernation image需要足够的内存空间,但是在这期间如果还有进程在申请内存,就可能导致创建失败;

(3)有可能干扰设备的suspend和resume。在cpu down之前,device suspend期间,如果进程还在访问设备,尤其是访问竞争资源,就有可能引起设备suspend异常;

(4)有可能导致进程感知系统休眠。系统休眠的理想状态是所有任务对休眠过程无感知,睡醒之后全部自动恢复工作,但是有些进程,比如某个进程需要所有cpu online才能正常工作,如果进程不冻结,那么在休眠过程中将会工作异常。

3 代码实现框架

冻结的对象是内核中可以被调度执行的实体,包括用户进程、内核线程和work_queue。用户进程默认是可以被冻结的,借用信号处理机制实现;内核线程和work_queue默认是不能被冻结的,少数内核线程和work_queue在创建时指定了freezable标志,这些任务需要对freeze状态进行判断,当系统进入freezing时,主动暂停运行。

kernel threads可以通过调用kthread_freezable_should_stop来判断freezing状态,并主动调用__refrigerator进入冻结;work_queue通过判断max_active属性,如果max_active=0,则不能入队新的work,所有work延后执行。

标记系统freeze状态的有三个重要的全局变量:pm_freezing、system_freezing_cnt和pm_nosig_freezing,如果全为0,表示系统未进入冻结;system_freezing_cnt》0表示系统进入冻结,pm_freezing=true表示冻结用户进程,pm_nosig_freezing=true表示冻结内核线程和workqueue。它们会在freeze_processes和freeze_kernel_threads中置位,在thaw_processes和thaw_kernel_threads中清零。

fake_signal_wake_up函数巧妙的利用了信号处理机制,只设置任务的TIF_SIGPENDING位,但不传递任何信号,然后唤醒任务;这样任务在返回用户态时会进入信号处理流程,检查系统的freeze状态,并做相应处理。

任务主动调用try_to_freeze的代码如下:

static inline bool try_to_freeze_unsafe(void)

{

if (likely(!freezing(current))) //检查系统是否处于freezing状态

return false;

return __refrigerator(false); //主动进入冻结

}

static inline bool freezing(struct task_struct *p)

{

if (likely(!atomic_read(&system_freezing_cnt))) //系统总体进入freezing

return false;

return freezing_slow_path(p);

}

bool freezing_slow_path(struct task_struct *p)

{

if (p-》flags & PF_NOFREEZE) //当前进程是否允许冻结

return false;

if (pm_nosig_freezing || cgroup_freezing(p)) //系统冻结kernel threads

return true;

if (pm_freezing && !(p-》flags & PF_KTHREAD)) //系统冻结用户进程

return true;

return false;

}

进入冻结状态直到恢复的主要函数:bool __refrigerator(bool check_kthr_stop)

{

。..

for (;;) {

set_current_state(TASK_UNINTERRUPTIBLE); //设置进程为UNINTERRUPTIBLE状态

spin_lock_irq(&freezer_lock);

current-》flags |= PF_FROZEN; //设置已冻结状态

if (!freezing(current) ||

(check_kthr_stop && kthread_should_stop())) //判断系统是否还处于冻结

current-》flags &= ~PF_FROZEN; //如果系统已解冻,则取消冻结状态

spin_unlock_irq(&freezer_lock);

if (!(current-》flags & PF_FROZEN)) //如果已取消冻结,跳出循环,恢复执行

break;

was_frozen = true;

schedule();

}

。..。..

}

4 参考文献

(1) http://www.wowotech.net/linux_kenrel/suspend_and_resume.html

(2) http://www.wowotech.net/linux_kenrel/std_str_func.html

(3) kenrel document: freezing-of-tasks.txt
编辑:hfy

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 内核
    +关注

    关注

    4

    文章

    1436

    浏览量

    42489
  • Linux
    +关注

    关注

    88

    文章

    11628

    浏览量

    217948
  • 进程
    +关注

    关注

    0

    文章

    208

    浏览量

    14478
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    Linux进程间通信(IPC)全解析:从管道到 Socket,篇讲透

    ,Inter-Process Communication) 。 今天我们就来系统梳理 Linux 中最常用的 6 种 IPC 方式,从原理到实例,从流程到适用场景,帮你彻底搞懂进程间如何 “对话”。 、管道
    的头像 发表于 11-14 21:38 1.2w次阅读
    <b class='flag-5'>Linux</b><b class='flag-5'>进程</b>间通信(IPC)全解析:从管道到 Socket,<b class='flag-5'>一</b>篇讲透

    【HZ-T536开发板免费体验】—— linux 进程创建

    Linux进程通信方式有这几种: 1。管道 2。信号量 3。消息队列 4。共享内存 在本帖子中,我会讲解fork(),exit()系统调用的实践。通过应用编程来实现系统调用。 1,进程创建 打开
    发表于 09-01 20:49

    洲明科技沉浸式光显技术如何推动旅产业发展

    8月9日,以“AI与出海”为主题的2025(第十九届)中国品牌节在深圳会展中心隆重举行,政、商、产、学、媒等各界万位嘉宾齐聚。洲明集团内容创意执行总裁刘俊受邀参加旅融合论坛,并以《沉浸式光显技术赋能视角下的旅融合案例
    的头像 发表于 08-14 14:10 704次阅读

    掌握Linux命令

    作为名运维工程师,熟练掌握Linux命令是基本功中的基本功。无论是日常工作中的系统维护,还是面试时的技术考核,Linux命令都是绕不开的核心技能。本文将从实战角度出发,系统梳理运维工
    的头像 发表于 07-22 15:23 440次阅读

    读懂:嵌入式Linux实时性进阶

    和提高确定性来改善系统的实时响应能力* 3Xenomai双核方案是什么 Xenomai是在Linux内核外增加独立的微内核的双内核方案,它基于Adeos实现双内核机制。在双内核技术下,存在个支持
    发表于 07-10 15:26

    带你深入剖析RedCap技术

    随着3GPPR17RedCap标准的冻结,业界对RedCap技术的关注持续升温。要将RedCap有效引入并服务于各行各业,亟需明确其在5G承载体系中的能力定位,并深入分析当前5G行业发展所面临的痛点
    的头像 发表于 05-14 10:53 2749次阅读
    <b class='flag-5'>一</b><b class='flag-5'>文</b>带你深入剖析RedCap<b class='flag-5'>技术</b>

    Linux系统,撑起整个芯片设计平台?CFA团队教你如何搭好EDA智算平台的技术底座

    ; Debian 系 :如 Ubuntu、Mint,更适合桌面应用和研发环境; 高级玩家 :Gentoo、Arch Linux……适合喜欢DIY的技术极客。 如果你需要的是个服务器系统,而且已经厌烦了各种
    发表于 05-07 14:44

    Linux常用命令大全

    Linux常用命令是指在Linux操作系统中广泛使用的命令工具,这些命令工具可以完成各种不同的任务,如管理文件和目录、操作进程、网络通信、软件安装等。
    的头像 发表于 05-03 18:08 1612次阅读

    Linux后台进程管理详解

    当我们在终端或控制台工作时,可能不希望由于运行个作业而占住了屏幕,因为可能还有更重要的事情要做,比如阅读电子邮件。对于密集访问磁盘的进程,我们更希望它能够在每天的非负荷高峰时间段运行(例如凌晨)。为了使这些进程能够在后台运行,
    的头像 发表于 04-25 11:04 801次阅读
    <b class='flag-5'>Linux</b>后台<b class='flag-5'>进程</b>管理详解

    华为创新技术加速汽车电动化进程

    新能源车拥有安全、舒适的操控体验”、“让有路的地方就有高质量充电,让新能源车充电像加油样便捷”,华为数字能源坚持以技术产品为核心,质量优先,通过车上车下协同发展,加速汽车电动化进程
    的头像 发表于 04-24 14:08 718次阅读

    Linux系统进程管理入门指南

    Linux 系统中,进程是正在运行的程序的实例。理解进程的管理、查看和控制对于系统管理员和开发者来说非常重要
    的头像 发表于 04-22 14:34 853次阅读
    <b class='flag-5'>Linux</b>系统<b class='flag-5'>进程</b>管理入门指南

    Linux进程状态详解

    进程状态是task_struct内的个整数;进行:进程在调度队列中,进程的状态都是running,阻塞:等待某种设备或者资源就绪。进程
    的头像 发表于 04-01 09:46 808次阅读
    <b class='flag-5'>Linux</b><b class='flag-5'>进程</b>状态详解

    进程、线程、协程傻傻分不清?带你彻底扒光它们的\"底裤\"!

    各位程序员朋友(和假装懂技术的同事):如果你在面试时被问到:\"请用奶茶店类比进程、线程和协程\",而你回答:\"进程是老板,线程是员工,协程是兼职...\"
    发表于 03-26 09:27

    福田卡汽车新能源技术战略解读

    近日,以“让每公里更美好”为主题的福田卡汽车技术战略暨全新产品发布会在福田汽车X实验室举行。行业领导、战略合作伙伴及广大媒体等300余名嘉宾出席本次活动。会上,福田卡汽车详细
    的头像 发表于 12-23 15:43 1011次阅读

    深入解析Linux程序与进程

    什么是程序 组计算机能识别和执行的指令,用于指导计算机执行特定任务或解决特定问题。程序通常由代码、数据和资源文件组成,涉及语法、算法和数据结构。为二进制文件 什么是进程个具有独立功能的程序
    的头像 发表于 12-18 11:01 835次阅读
    深入解析<b class='flag-5'>Linux</b>程序与<b class='flag-5'>进程</b>