data:image/s3,"s3://crabby-images/c3dda/c3ddafe59bb8505f6f87324a80dbd1872dcddacf" alt="The Linux CPU scheduler & runqueue_第1张图片"
在Linux 2.6,每個CPU有屬於自己的一個runqueue,而runqueue又分成兩個結構,active跟expired。這2個queue是根據每個process的priority來由高到低依序排列(範圍:0~139)。
active代表process的quantum尚未使用完畢的。
expire則代表quantum已經使用完畢的process。
data:image/s3,"s3://crabby-images/a1797/a1797f40a37c452d3b17052d0ccf35f55a9ca5b6" alt="The Linux CPU scheduler & runqueue_第2张图片"
現在有1、2、3三個Task在active這個結構等待被執行。
Priority: Task1>Task2=Task3
Time quantum:Task1>Task2=Task3
(Time quantum ≒ 1/Priority)
data:image/s3,"s3://crabby-images/fbf74/fbf74c591ed541f2269612b97e3db102e613bae7" alt="The Linux CPU scheduler & runqueue_第3张图片"
由Task1開始執行(因為Priority最高),當Task1將自己的Time quantum使用完畢後,就移動到expired。
data:image/s3,"s3://crabby-images/15c16/15c16579ab297865268f5991dc9dafcc17f72260" alt="The Linux CPU scheduler & runqueue_第4张图片"
Task2和Task3的priority是相同的,所以用linked list將兩個串聯起來,而兩者的執行是採用round-robin演算法。
data:image/s3,"s3://crabby-images/16688/166880eea8247640e672ad3301ae11da5218ab29" alt="The Linux CPU scheduler & runqueue_第5张图片"
每個Task有一個時間片段(time slice),因為Task2無法在time slice內執行完畢,就要移動到該linked list的最後面去排隊重新等待執行。
data:image/s3,"s3://crabby-images/04241/04241a8163ef5e8e484662f1b3742bb0559fb196" alt="The Linux CPU scheduler & runqueue_第6张图片"
Task2在經由round-robin演算法,排隊了幾次之後結束了他的執行Time quantum,也會移動到expired去。
data:image/s3,"s3://crabby-images/e4f01/e4f01615286c58f2d32ae2faca072619287e660b" alt="The Linux CPU scheduler & runqueue_第7张图片"
因為有動態優先權(dynamic priority)。動態優先權會以「上一個cycle中,該Task的averge sleep time值的大小」為依據給予該Task一個bouns值。所以Task3移動到expired時,priority比Task2高。
data:image/s3,"s3://crabby-images/b1b3b/b1b3be1d9724a821189e1a09506f193dc0292aea" alt="The Linux CPU scheduler & runqueue_第8张图片"
3個Task都到了expired
data:image/s3,"s3://crabby-images/9ae6e/9ae6e233315a903a8b759dbcf0d983e4a6293b14" alt="The Linux CPU scheduler & runqueue_第9张图片"
當active結構裡已經沒有Task在等待被執行,而expired有Task,兩者的指標就會做交換的動作