首页 > 系统相关 >进程冻结

进程冻结

时间:2023-03-06 11:15:26浏览次数:32  
标签:冻结 return freezing 系统 freeze 进程

1 什么是进程冻结

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

为什么需要冻结技术

假设没有冻结技术,进程可以在任意可调度的点暂停,而且直到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;
}

进入冻结状态直到恢复的主要函数:

{
...
    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();
    }
......
}

标签:冻结,return,freezing,系统,freeze,进程
From: https://www.cnblogs.com/linhaostudy/p/17182995.html

相关文章

  • php 多进程编程
    第一步:$php-m命令查看php是否安装pcntl和posix扩展,若没有则安装使用场景:1.要进行大量的网络耗时的操作2.要做大量的运算,并且,系统有多个cpu,为了让用户有更快的体验,把......
  • php脚本守护进程设计
    思路:while循环,若当前没有数据要操作可以休眠;crontab脚本每隔固定时间段执行该脚本,执行时先检测是否已在执行,若无执行,有则跳过。nohup后台执行flock-xn加锁2>&1表......
  • 关于hibernate执行sql语句后,进程不关闭的问题
    写了一个简单的测试程序,就是java查询数据库的,后面发现了数据库查询结束后,进程一直不会结束,在调试的时候,发现生成了一个线程,是这个线程不关闭。/****/packagecom.test.my......
  • 进程与线程
    被选为在计算机网络课上进行分享的人,准备分享近些天在Android编程时发现不了解的知识进程:定义:进程是一个具有一定独立功能的程序关于某个数据集合的一次运行活动。它是操......
  • 多进程
    frommultiprocessingimportProcessdeftask(name):foriinrange(10000):print(f"{name}:",i)if__name__=='__main__':p=Process(target......
  • linux下进程和线程的区别和联系
    进程用fork()或者vfork()生成(vfork是专门为了加载其他程序的子程序而优化的,随着fork()的优化,vfork已经被优化)fork()生成的子进程与父进程共享代码区内存,对于其他内存fork......
  • 如何查看任务管理器中某个进程的详细命令行
    有一次追查一个进程,然后想起来任务管理器可以查看进程命令行,做下记录并提供给有需要的同学首先右键,选择"任务管理器"打开任务管理器   发现没有显示命令行那一列信......
  • 【systemctl】让程序以守护进程的方式在后台运行
    首先需要创建一个systemd unit配置文件,比如:verdaccio.service,一般放在/lib/systemd/system/下添加配置如下:[Unit]Description=Verdacciolightweightnpmproxyr......
  • Linux中的进程管理
    1.进程的基本概述进程是已启动的可执行程序的运行中实例进程是正在执行当中的程序(命令),每一个进程都是一个运行的实体,都有自己的地址空间,并占用一定的系统资源。程序被......
  • AMS监控某进程是否挂掉的方法
    File:ActivityManagerService.java原生代码中会在每个应用进程启动时,创建一个AppDeathRecipient对象来监控其是否death,进程挂掉(包括走onDestroy的、或者crash)后,执行回调方......