理解進程調度時機跟蹤分析進程調度與進程切換的過程

實驗

準備環境


進行調試


進程上下文切換相關代碼分析

#define switch_to(prev, next, last)                   
do {                                 
  /*                             
   * Context-switching clobbers all registers, so we clobber  
   * them explicitly, via unused output variables.     
   * (EAX and EBP is not listed because EBP is saved/restored  
   * explicitly for wchan access and EAX is the return value of   
   * __switch_to())                     
   */                                
  unsigned long ebx, ecx, edx, esi, edi;                
                                  
  asm volatile("pushfl\n\t"      /* save    flags */   
           "pushl %%ebp\n\t"        /* save    EBP   */ 
           "movl %%esp,%[prev_sp]\n\t"  /* save    ESP   */ 
           "movl %[next_sp],%%esp\n\t"  /* restore ESP   */ 
           "movl $1f,%[prev_ip]\n\t"    /* save    EIP   */ 
           "pushl %[next_ip]\n\t"   /* restore EIP   */    
           __switch_canary                   
           "jmp __switch_to\n"  /* regparm call  */ 
           "1:\t"                        
           "popl %%ebp\n\t"     /* restore EBP   */    
           "popfl\n"         /* restore flags */  
                                  
           /* output parameters */                
           : [prev_sp] "=m" (prev->thread.sp),     
             [prev_ip] "=m" (prev->thread.ip),        
             "=a" (last),                 
                                  
             /* clobbered output registers: */     
             "=b" (ebx), "=c" (ecx), "=d" (edx),      
             "=S" (esi), "=D" (edi)             
                                       
             __switch_canary_oparam                
                                  
             /* input parameters: */                
           : [next_sp]  "m" (next->thread.sp),        
             [next_ip]  "m" (next->thread.ip),       
                                       
             /* regparm parameters for __switch_to(): */  
             [prev]     "a" (prev),              
             [next]     "d" (next)               
                                  
             __switch_canary_iparam                
                                  
           : /* reloaded segment registers */           
          "memory");                  
} while (0)

分析switch_to中的匯編代碼:
-保存flags
-保存esp
-重置esp
-保存eip
-重置eip
-轉跳至__switch_to
-恢復ebp
-恢復flags

為了控制進程的執行,內核必須有能力掛起正在CPU上執行的進程,并恢復以前掛起的某個進程的執行,這叫做進程切換、任務切換、上下文切換;

掛起正在CPU上執行的進程,與中斷時保存現場是不同的,中斷前后是在同一個進程上下文中,只是由用戶態轉向內核態執行;

進程上下文包含了進程執行需要的所有信息

-用戶地址空間:?包括程序代碼,數據,用戶堆棧等

-控制信息?:進程描述符,內核堆棧等

-硬件上下文(注意中斷也要保存硬件上下文只是保存的方法不同)

分析總結

不同類型的進程有不同的調度需求
-I/O-bound
--頻繁的進行I/O
--通常會花費很多時間等待I/O操作的完成
-CPU-bound
--計算密集型
--需要大量的CPU時間進行運算
需要不同的算法來使得系統運行更加高效,將CPU資源得到最大限度的使用
-批處理進程batch process
--不必與用戶交互,通常在后臺運行
--不必很快響應
--典型的批處理程序:編譯程序、科學計算
-實時進程real-time process
--有實時需求,不應被低優先級的進程阻塞
--響應時間要短、要穩定
--典型的實時進程:視頻、音頻、機械控制等
-交互式進程interactive process
--需要經常與用戶交互,因此要花很多時間等待用戶輸入操作
--響應時間要快,平均延遲要低于50~150ms
--典型交互式程序:shell、文本編輯器、圖形應用程序等
有不同的需求應用存在,就需要有不同的調度應用策略
調度策略是一組規則,決定什么時候以怎樣的方式選擇一個新進程運行
linux的調度基于分時和優先級
linux在不同版本更新,調度策略發生了不同的變化
-linux的進程根據優先級排隊,根據特定的算法計算出進程的優先級,用一個值表示把進程如何適當的分配給CPU
-linux中進程的優先級是動態的,調度程序會根據進程的行為周期性的調整進程的優先級,較長時間未分配到CPU的進程優先級通常增高,已經在CPU上運行了較長時間的進程通常優先級降低
用來配置優先級的調用
-nice
-getpriority/setpriority
-sched_getscheduler/sched_setscheduler
-sched_getparam/sched_setparam
-sched_yield
-sched_get_priority_min/sched_get_priority_max
-sched_rr_get_interval
調度策略只是一種算法,內核中的調度算法相關代碼使用了類似OOD中的策略模式
將調度算法與其他部分解耦合
理解整個系統,在于理解進程調度的時機
schedule函數用于實現調度
-目的:在運行隊列中找到一個進程,把CPU分配給它
-調用方法:-直接調用schedule();-松散調用,根據need_resched標記
進程調度的時機
-中斷處理過程(包括時鐘中斷、I/O中斷、系統調用和異常)中,直接調用schedule(),或者返回用戶態時根據need_resched標記調用schedule();用戶態進程只能被動調度
-內核線程可以直接調用schedule()進行進程切換,也可以在中斷處理過程中進行調度,也就是說內核線程作為一類的特殊的進程可以主動調度,也可以被動調度;內核線程是只有內核態沒有用戶態的特殊進程;內核現成可以主動調度可以被動調動
-用戶態進程無法實現主動調度,僅能通過陷入內核態后的某個時機點進行調度,即在中斷處理過程中進行調度。

王瀟洋
原創作品轉載請注明出處《Linux內核分析》MOOC課程[http://mooc.study.163.com/course/USTC-1000029000]

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,517評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,087評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,521評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,493評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,207評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,603評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,624評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,813評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,364評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,110評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,305評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,874評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,532評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,953評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,209評論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,033評論 3 396
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,268評論 2 375

推薦閱讀更多精彩內容