linux内核杂记(9)-进程调度(4)
1、上下文切換從一個可執行進程切換到另一個要執行進程。由定義在kernel/sched.c中的context_switch()函數負責處理。
2、每當一個新的進程被選出來準備投入運行時,schedule()就會調用該函數。完成兩項基本工作:
(1)調用聲明在<asm/mmu_context.h>中的switch_mm()。
把虛擬內存從上一個進程映射到新進程中。
(2)調用聲明在<asm/system.h>中的switch_to()。從上一進程的處理器狀態切換到新進程的處理器狀態。
3、內核必須知道在什么時候調用schedule(),不能依賴用戶程序代碼顯式調用 schedule() ,因為用戶程序可能希望永遠執行下去,不希望被替代。
4、內核提供了need_resched標志表明是否需要重新執行調度。
進程應被搶占時,scheduler_tick()會設置這個標志,優先級高的進程進入可執行狀態時,try_to_wake_up()設置這個標志
set_tsk_need_resched() 設置指定進程中的need_resched標志
clear_tsk_need_resched()清除指定進程中的need_resched標志
need_resched()檢查need_resched標志的值,如果被設置返回真,否則返回假
5、返回 用戶空間和從中斷返回時,內核會檢查need_resched標志,如果被設置,內核會在繼續招手地之前調用調度程序,每個進程包含一個need_resched標志,在2.6版中在thread_info結構城,用一個特別的標志變量中的一位來表示。
總結
以上是生活随笔為你收集整理的linux内核杂记(9)-进程调度(4)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: HashMap的底层原理
- 下一篇: linux内核杂记(10)-进程调度(5