Have you ever encountered various problems that occur when the system is hibernating? For example, the file system is damaged, hibernation image creation fails, device suspend is abnormal, etc. These problems can be solved through Linux process freezing technology.
There are three important global variables that mark the system freeze status: pm_freezing, system_freezing_cnt and pm_nosig_freezing. If they are all 0, it means that the system has not entered freezing; system_freezing_cnt>0 means that the system has entered freezing, and pm_freezing=true means Freeze the user process. pm_nosig_freezing=true means freezing the kernel thread and workqueue. They will be set in freeze_processes and freeze_kernel_threads, and cleared in thaw_processes and thaw_kernel_threads.
The fake_signal_wake_up function cleverly makes use of the signal processing mechanism. It only sets the TIF_SIGPENDING bit of the task, but does not pass any signal, and then wakes up the task; in this way, the task will enter the signal processing process when returning to user mode, check the freeze status of the system, and handle it accordingly. .
The code for the task to actively call try_to_freeze is as follows:
``` ``` 1. static inline bool try_to_freeze_unsafe(void) 2. { 3. if (likely(!freezing(current))) //检查系统是否处于freezing状态 4. return false; 5. return __refrigerator(false); //主动进入冻结 6. } 7. 8. static inline bool freezing(struct task_struct *p) 9. { 10. if (likely(!atomic_read(&system_freezing_cnt))) //系统总体进入freezing 11. return false; 12. return freezing_slow_path(p); 13. } 14. 15. bool freezing_slow_path(struct task_struct *p) 16. { 17. if (p->flags & PF_NOFREEZE) //当前进程是否允许冻结 18. return false; 19. 20. if (pm_nosig_freezing || cgroup_freezing(p)) //系统冻结kernel threads 21. return true; 22. 23. if (pm_freezing && !(p->flags & PF_KTHREAD)) //系统冻结用户进程 24. return true; 25. 26. return false; 27. }
The main function to enter the frozen state until recovery: bool __refrigerator(bool check_kthr_stop)
1. { 2. ... 3. for (;;) { 4. set_current_state(TASK_UNINTERRUPTIBLE); //设置进程为UNINTERRUPTIBLE状态 5. 6. spin_lock_irq(&freezer_lock); 7. current->flags |= PF_FROZEN; //设置已冻结状态 8. if (!freezing(current) || 9. (check_kthr_stop && kthread_should_stop())) //判断系统是否还处于冻结 10. current->flags &= ~PF_FROZEN; //如果系统已解冻,则取消冻结状态 11. spin_unlock_irq(&freezer_lock); 12. 13. if (!(current->flags & PF_FROZEN)) //如果已取消冻结,跳出循环,恢复执行 14. break; 15. was_frozen = true; 16. schedule(); 17. } 18. ...... 19. }
In short, Linux process freezing technology is a very useful technology that can help you avoid some potential problems and make your system more stable. If you want to learn more about this technology, check out the resources provided in this article.
The above is the detailed content of :Linux process freezing technology: Make your system more stable. For more information, please follow other related articles on the PHP Chinese website!