Linux核心源碼學習__Linux

來源:互聯網
上載者:User
Linux 核心原始碼分析 - 進程管理及調度
http://wenku.baidu.com/link?url=yzMjiwX-ZzlnYZgb8CKG5veDdv6_uTbweFpb0_LPDDf7xYilF4fImm4QcL5-0gsk6SNu9KrFUqvrzYdbl0wLU8RHGilVFMS_mPIL0HRSB4m

進程管理的任務
.允許進程複製自己(真正作到一個應用多進程)
.確定哪個進程能夠擁有CPU
.接受中斷並將中斷導向相應的核心子系統
.向使用者進程發送訊號
.管理時鐘硬體
.當一個進程結束時,釋放其資源
.動態裝載執行模組

進程模組與其他模組的依賴關係
.對使用者進程提供了一組簡單的系統調用介面
.對核心的其他模組提供了豐富的介面功能
記憶體管理模組,當一個進程被調度的時候,為它建立記憶體映射。
所有的其他模組都依賴於進程調度模組,因為當要進行硬體訪問的時候它們需要CPU掛起使用者進程,切換到系統態進行處理。

進程的建立(FORK, copy-on-write)
Linux中,進程的建立是通過拷貝已存在進程來實現的。
在Linux核心啟動的時候,首先由start_kernel()初始化各個系統資料結構,同時產生了和系統共存亡的後台進程:init。
init進程通過拷貝自身,產生了若干核心子進程。然後這些進程就可以通過系統調用fork()產生它們的子進程,當然這些子進程的未經處理資料都是他們的父親的副本。進程的終止是通過系統調用_exit()實現的。

進程的終止
.進程運行結束時要釋放相應的資源,通過EXIT()調用實現(顯式或隱式)
.EXIT()實現時調用了do_exit()完成以下工作
    Task_struct中標誌成員設為:PF_EXITING
    調用__exit_mm()
    調用sem__exit()
    調用__exit_files(), __exit_fs(), exit__name__space, exit_sighand
    結束代碼替換為EXIT()提供的代碼
    調用Exit_notify()向父進程發訊號,(標為ZOOMBIE)
    調用shedule切換到其他進程

線程實現
Linux沒有真正的線程。
僅僅是進程之間資源直接共用的一種機制。
核心線程:獨立運行在核心的標準進程。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.