新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > uClinux進程調(diào)度器的實現(xiàn)分析

uClinux進程調(diào)度器的實現(xiàn)分析

作者: 時間:2012-03-24 來源:網(wǎng)絡(luò) 收藏

if (unlikely(!c)) {

/*若處于運行隊列中的進程沒有可調(diào)度的,那么得重新分配時間片*/

struct task_struct *p;

for_each_task(p)

p->counter = (p->counter >> 1) + NICE_TO_TICKS(p->nice);

goto repeat_schedule;

}

sched_data->curr = next;

task_set_cpu(next, this_cpu);www.51kaifa.com

if (unlikely(prev == next)){

/*如果選中的進程和原來運行的進程是同一個*/

prev->policy = ~SCHED_YIELD;

goto same_process;

}

kstat.context_swtch++;

/*全局統(tǒng)計進程上下文切換次數(shù)*/

prepare_to_switch();

/*準(zhǔn)備進行進程切換*/

{

……/*進程的頁表處理,代碼略*/

}

switch_to(prev, next, prev); www.51kaifa.com

/*切換到選中的進程中*/

__schedule_tail(prev);

/*考慮將當(dāng)前被切換下來的進程,放到別的CPU上運行*/

same_process:

reacquire_kernel_lock(current);www.51kaifa.com

/*重新獲得內(nèi)核鎖*/

if (current->need_resched)

goto need_resched_back;

return;

}


整個schedule()的工作流程可以概述成以下幾步:

1). 清理當(dāng)前運行中的進程

2). 選擇下一個投入運行的進程

3). 設(shè)置新進程的運行環(huán)境www.51kaifa.com

4). 執(zhí)行進程上下文切換

5). 后期整理

5 結(jié)束語

的進程調(diào)度有其獨有的特征,比如為了將三種協(xié)調(diào)一致同時不增加程序復(fù)雜度,為每一個進程設(shè)置相應(yīng)的,并設(shè)置實時進程的優(yōu)先級遠高于非實時進程,使得在調(diào)度過程中不必去區(qū)分實時進程和非實時進程,從而獲得最佳響應(yīng)時間。同時,操作系統(tǒng)采用底半部分處理策略,將中斷處理服務(wù)程序分割成兩部分,提高了響應(yīng)時間。另外,被暫時掛起的中斷處理程序及任務(wù)隊列,都要放在schedule( )中去處理,并優(yōu)于其它進程調(diào)度,形成了uClinux獨具特色的調(diào)度風(fēng)格。

參考文獻:

[1] Claudia Salzberg Rodriguez,Gordon Fischer,Steven Smolski.The Linux Kernel Primer[M].北京:機械工業(yè)出版社,2006www.51kaifa.com

[2] 鄒治鋒,張曦煌.Linux 2.6進程調(diào)度[J].微計算機信息.2006,1-2:77-79[3] uClinux官方網(wǎng)站源碼下載. http://www.uclinux.org/pub/uClinux/dist/.2007


上一頁 1 2 3 下一頁

關(guān)鍵詞: uClinux 調(diào)度策略 進程調(diào)度器

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉