1. idle是什麼
簡單的說idle是一個進程,其pid號爲 0。其前身是系統建立的第一個進程,也是惟一一個沒有經過fork()產生的進程。在smp系統中,每一個處理器單元有獨立的一個運行隊列,而每一個運行隊列上又有一個idle進程,即有多少處理器單元,就有多少idle進程。系統的空閒時間,其實就是指idle進程的"運行時間"。既然是idle是進程,那咱們來看看idle是如何被建立,又具體作了哪些事情?
2. idle的建立
咱們知道系統是從BIOS加電自檢,載入MBR中的引導程序(LILO/GRUB),再加載linux內核開始運行的,一直到指定shell開始運行告一段落,這時用戶開始操做Linux。而大體是在vmlinux的入口startup_32(head.S)中爲pid號爲0的原始進程設置了執行環境,而後原是進程開始執行start_kernel()完成Linux內核的初始化工做。包括初始化頁表,初始化中斷向量表,初始化系統時間等。繼而調用 fork(),建立第一個用戶進程:
kernel_thread(kernel_init, NULL, CLONE_FS | CLONE_SIGHAND);
這個進程就是着名的pid爲1的init進程,它會繼續完成剩下的初始化工做,而後execve(/sbin/init), 成爲系統中的其餘全部進程的祖先。關於init咱們此次先不研究,回過頭來看pid=0的進程,在建立了init進程後,pid=0的進程調用 cpu_idle()演變成了idle進程。
current_thread_info()->status |= TS_POLLING;
在 smp系統中,除了上面剛纔咱們講的主處理器(執行初始化工做的處理器)上idle進程的建立,還有從處理器(被主處理器activate的處理器)上的idle進程,他們又是怎麼建立的呢?接着看init進程,init在演變成/sbin/init以前,會執行一部分初始化工做,其中一個就是 smp_prepare_cpus(),初始化SMP處理器,在這過程當中會在處理每一個從處理器時調用
task = copy_process(CLONE_VM, 0, idle_regs(®s), 0, NULL, NULL, 0);
init_idle(task, cpu);
即從init中複製出一個進程,並把它初始化爲idle進程(pid仍然爲0)。從處理器上的idle進程會進行一些Activate工做,而後執行cpu_idle()。
整個過程簡單的說就是,原始進程(pid=0)建立init進程(pid=1),而後演化成idle進程(pid=0)。init進程爲每一個從處理器(運行隊列)建立出一個idle進程(pid=0),而後演化成/sbin/init。
3. idle的運行時機
idle 進程優先級爲MAX_PRIO,即最低優先級。早先版本中,idle是參與調度的,因此將其優先級設爲最低,當沒有其餘進程能夠運行時,纔會調度執行idle。而目前的版本中idle並不在運行隊列中參與調度,而是在運行隊列結構中含idle指針,指向idle進程,在調度器發現運行隊列爲空的時候運行,調入運行。
小結:
1.idle是一個進程,其pid爲0。
2.主處理器上的idle由原始進程(pid=0)演變而來。從處理器上的idle由init進程fork獲得,可是它們的pid都爲0。
3.Idle進程爲最低優先級,且不參與調度,只是在運行隊列爲空的時候才被調度。
4.Idle循環等待need_resched置位。默認使用hlt節能。
shell