兼容核心

兼容核心(Linux Unified Kernel,簡稱Longene),是一個二進制兼容Windows和Linux套用軟體和設備驅動程式的計算機作業系統核心。它試圖在Linux核心的基礎上利用Linux核心材料構建MS Windows核心功能模組從而擴充Linux核心的支持能力使之同時支持Linux和Windows的應用程式和設備驅動。兼容核心主要以C語言編寫,以GNU通用公共許可證授權使用。雖然兼容核心還處在初期開發階段,但許多Windows程式已經可以在其上運行。

基本介紹

  • 中文名:兼容核心
  • 外文名:Linux Unified Kernel
  • 簡稱Longene
  • 性質:計算機作業系統核心
特性,實現Windows核心機制方案的優點,開發,開發策略和線路,歷史版本,現在和未來的開發,可利用的資源,用戶,硬體需求,架構支持,

特性

兼容核心項目在Linux核心的基礎上利用Linux核心材料構建一個Windows核心環境(包括進程管理、執行緒管理、對象管理、虛擬記憶體管理、同步、系統調用、系統註冊機制和設備驅動程式框架等Windows系統核心機制),形成一個新的核心,使Linux和Windows應用程式和設備驅動程式能夠直接在其上運行。
兼容核心不是Linux核心和Windows核心的簡單堆砌。為了防止兼容核心變得臃腫,如果一個功能可以用利用ReactOS(Windows的開源仿製品)代碼實現,也可以利用Linux核心函式通過編程實現(ReactOS、Wine、NDISwrapper代碼作為參考),兼容核心傾向採用後一種實現方法。
兼容核心有兩套系統調用(syscalls)及其相應的系統調用表(syscall table):一套為Windows系統調用,另一套為Linux系統調用。Windows應用程式通過軟中斷“int 0x2e”訪問系統調用表進行Windows系統調用。Linux套用軟體則通過軟中斷“int 0x80”訪問系統調用表進行Linux系統調用。
兼容核心項目不計畫開發Windows和Linux的在用戶空間運行的庫檔案(.dll和.o檔案)。這些庫檔案由WINE項目(或MS Windows/ReactOS項目)和Linux項目提供。

實現Windows核心機制方案的優點

開發快速。Linux核心已有成熟的CPU管理、記憶體管理磁碟管理和外圍硬體管理等功能模組及其實現函式。採用擴充Linux核心,通過嫁接(重定向)或重用Linux核心相關功能函式等方法實現Windows核心功能的方案要比從零開始編碼實現Windows核心的方案要快很多。 兼容性好,效率高。在核內空間實現Windows核心機制比在核外實現能夠達到更大的兼容性。相比在核外利用宿主作業系統的API來構建Windows的API,在核內空間可以利用細小的核心材料來實現Windows的API。因核心函式顆粒度比API小,其靈活性更大仿製能力更強因而能夠達到更好的兼容性。另外,Windows進程、執行緒系統調用等在核內運行能夠避免在核外運行帶來的用戶空間到核心切換額外的消耗,因而相比更有效率。在核內實現Windows核心機制與原生的Windows核心開發方法是一致的,能夠克服核外無法實現Windows某些功能的缺點。 能夠實現Windows驅動。 能夠使用全套MS Windows庫檔案。Linux和MS Windows庫檔案是通過軟中斷(Linux為“int 0x80”,MS Windows為“int 0x2e”)進入核內進行系統調用的。兼容核心在核心開發能夠為之設定與Linux和MS Windows中斷號相同的兩套獨立的系統調用以最大程度兼容MS Windows環境,使得MS Windows系統全套原生的用戶空間庫檔案(.dll)能夠在兼容核心上運行。這給開發調試帶來方便,也給計畫和已經轉向Linux系統的持有MS Windows使用許可證的機構和個人帶來好處。 兼容核心主要是在Linux的核心模組(LKMs)中實現的,這使它像應用程式的外掛程式一樣很容易載入和卸載。 裁剪方便。實現Windows的API和驅動機制後,可以在不影響系統正常運行的情況下裁剪去除與Windows無關的Linux部分而只保留Windows功能,縮減體積以適應某些記憶體較小的設備。

開發

兼容核心是由中國的浙大網新有限公司在2005年9月發起的自由軟體項目。作為項目負責人,毛德操先生提出了項目的構想和和開發路線。他寫了一系列闡述具體實現兼容核心的文章,這些文章的彙編為兼容核心白皮書。根據的兼容核心白皮書,兼容核心開發的主要工作是在Linux核心中實現“一個框架和兩個界面”:
一個符合Windows設備驅動程式的特徵和要求的框架,即Windows設備驅動框架,使得可以把多個Windows設備驅動模組裝入核心,並使這些模組間的關係和運行條件跟它們在Windows核心中時相同。 一組由Windows核心導出(Export)函式界面(見Windows DDK)定義的導出函式。對於設備驅動程式而言,這些函式就相當於由核心提供的庫函式。 Windows的系統調用界面。微軟並沒有公開它的系統調用界面,但是在“Windows NT/2000 Native API Reference”和其他資料中已經揭開了這個秘密。在Linux核心中實現Windows的系統調用界面,就相當於用彙編語言來實現另一種高級語言。這是因為,在核心裡面,可以使用的“磚塊”就不再是巨觀的Linux系統調用,而是Linux的許多微觀的核心函式了。 兼容核心項目的成果為Linux核心補丁。兼容核心的開發者期望這些補丁最終融入Linux標準核心成為Linux核心標準的一部分。那樣擅長開發Windows應用程式和設備驅動的開發者就可以很方便地為linux平台開發軟體或把他們的產品移植到linux平台。對於Windows軟體開發公司來說,只需要開發維護一個代碼庫就可以實現跨平台,這將降低軟體跨平台所帶來的成本,增加這些公司把產品移植到Linux平台的意願。這些公司與Linux用戶都將從兼容核心項目直接受益。

開發策略和線路

兼容核心採用漸進方式進行開發,它以已經能正常運行的Wine和NDISWrapper為開發始點,通過開發自身的Windows核心功能模組替換Wine中相應的功能模組來實現Windows系統調用相關功能;通過改造和擴充NDISWrapper來實現Windows設備驅動框架;通過利用嫁接(重定向)等方法實現Windows核心導出函式。具體開發策略和線路如下:
Windows系統調用 兼容核心以Wine為開發始點,兼容核心開發在核內運行的核心功能模組來替代Wine中在用戶空間運行的功能模組,並通過對Wine打補丁使Windows套用軟體轉而使用兼容核心功能模組。即是:如果兼容核心已經實現了該功能,則使用兼容核心提供的功能;否則使用Wine提供的功能。每替換了一些Wine的功能模組,經調試測試穩定後就可以發行一個兼容核心版本。這個發行版本又是下一個版本的開發始點,周而復始直到把Wine的所有功能模組被兼容核心模組替代。兼容核心開發不限於替代Wine功能模組,Wine在用戶空間受技術限制不能實現的功能兼容核心也要加以實現。 Windows設備驅動框架 NDISWrapper已經在Linux核心中實現了一個WDM的雛形,而ReactOS則已有一個基本可以運行的Windows設備驅動框架。兼容核心將以NdisWrapper為開發始點,借鑑ReactOS的代碼對NdisWrapper進行改造和擴充以實現Windows設備驅動框架。 Windows核心導出函式 ReactOS和NdisWrapper已經有一個基本的Windows核心導出函式集合。兼容核心在這個基本集合的基礎上逐步實現的自身的Windows核心導出函式。具體實現方法是如果Linux核心中有對應物的可以通過映射(重定向)/嫁接(適配)的方法連線到Linux核心中的對應物上,小部分在Linux核心中沒有對應物則需要利用Linux核心材料加以實現。

歷史版本

版本
發行時間
新增特性
可運行的軟體
0.1.0
2006.4.30
基於軟中斷“int 2e”的Windows系統調用(syscalls)機制
測試軟體
0.2.0
2006.12.31
Windows執行緒/進程機制
Windows APC機制
單執行緒套用軟體
0.2.1
2008.2.4
進程/執行緒管理
虛擬記憶體管理
同步
對象管理
內置的。exe套用軟體裝入功能
多執行緒套用軟體
0.2.2
2008.10.31
安全機制
圖形界面(GUI)的安裝程式
0.2.2-1
2008.12.17
修正上一版本的錯誤
0.2.3
2009.2.12
Windows註冊表機制
0.2.4
2009.?
檔案系統整合
unifiedkernel-2.6.132006年2月15日兼容核心項目發布了unifiedkernel-2.6.13版本,該版本實現了Windows系統調用機制。
0.1.02006年4月30日兼容核心項目開發組發布了0.1.0版本,該版本把Kernel-win32移植到上一版本的兼容核心。通過移植(部分是重新實現)kernel-win32到兼容核心,部分win32系統調用已可用。測試這些系統調用的Windows測試程式已經能在兼容核心上運行。
0.2.02006年12月31日兼容核心項目開發組發布了0.2.0版本。該版本實現了的Windows的進程/執行緒創建,包括NtCreateThread()和NtCreateProcess()在內的Windows系統調用,某些應用程式已經能在真實的核心進程和執行緒中運行。這個版本提供了一個裝入PE格式執行檔案的模組,Windows進程能夠被Linux和Windows父進程創建,而不再需要wine-preloader的支持。一些單執行緒應用程式已經可以在兼容核心上運行。
0.2.12008年2月4日兼容核心項目開發組發布了0.2.1版本。該版本實現了Windows系統的進程/執行緒管理、對象管理、虛擬記憶體管理以及進程間同步管理等Windows系統的基本機制。 一些原生Win32多執行緒應用程式 (包括Microsoft Office 2000, Securecrt 5.0, Dream Weaver 8, WinRar和Acrobat Reader 5)已經可以在兼容核心上直接運行。
0.2.22008 年10月31日兼容核心項目開發組發布了兼容核心0.2.2版本。該版本提供了一些安全機制並在0.2.1版的基礎上修正了包括進程/執行緒管理,虛擬記憶體管理等方面的錯誤,在穩定性和兼容性上有了較大的提高。另外該版本還升級了附帶的Wine的內置dll版本到1.0版,並修正了一些其中視窗管理、中文支持等的錯誤。
0.2.2-12008年12月8日兼容核心項目開發組發布了兼容核心0.2.2-1版本。該版本沒有增加新特性,它修正了0.2.2版本部分進程/執行緒創建和退出的錯誤,解決了記憶體相關的一些問題。
0.2.32009年2月12日兼容核心項目開發組發布了兼容核心0.2.3版本。該版本在0.2.2-1版的基礎上將Wine的註冊表管理機制整體移植到核心,使得應用程式運行效率有了一定的提高。

現在和未來的開發

檔案系統集成工作已經完成,兼容核心項目組正在對它進行測試。因為檔案系統集成測試仍在進行當中,0.2.3版本使用了Wine的讀寫模組進行檔案讀寫操作。由於Wine採用客戶/伺服器的方式進行檔案讀寫因而它的檔案存取效率是很低的。兼容核心項目組希望在檔案系統集成工作最終完成後Windows程式在兼容核心上存取檔案達到其在MS Windows上的相同效率。
兼容核心項目的成果產物為Linux核心補丁。兼容核心開發組希望這些補丁最終融入Linux標準核心。為此兼容核心開發組正在削減對Linux核心主體代碼的修改,儘量把兼容核心代碼放到Linux核心模組(LKMs)中以滿足Linux標準核心的可剝離性要求。
兼容核心還將進行下面的主要工作:
準備兼容核心的DEB和RPM安裝包。 修正pthread() TLS。 實現Windows設備驅動框架。 實現Windows DPC機制。 實現Windows DDK定義的核心導出函式。

可利用的資源

兼容核心不是從零開始編程的,它是在其他項目已有的代碼基礎上進行開發的。它對這些項目進行整合和再發展。兼容核心項目可利用的資源包括Linux kernel、Reactos、Wine、kernel-win32和NDISwrapper等,它們都是開源項目原始碼可以自由取得。
Linux 兼容核心是基於Linux核心的。它在Linux可載入核心模組(LKMs)中實現它的功能。與ReactOS項目從零開始編碼實現Windows核心不同,兼容核心是利用Linux核心中豐富的核心功能函式來實現Windows核心功能的。其實現Windows機制的主要途徑如下: Windows系統調用接口的實現——一些Windows的系統調用可以通過嫁接(重定向)到適當的Linux系統調用或部分重用相應的Linux核心函式來實現,,另一些在Linux核心中沒有對應物的功能則需要使用Linux低級的核內函式來實現。 Windows設備驅動框架——-基本的設備驅動框架對應著Win2k核心中的I/O管理,以及電源管理、即插即用等機制,也涉及部分對象管理、系統配置、和安全管理方面的功能。。這個框架上面與有關檔案操作的系統調用(open(),close(),read(),write(),ioctl()等)相銜接,中間實現基於“IO請求包”IRP(IO Request Packet)的設備驅動機制,下面則融入Linux核心的中斷回響/服務機制、包括“軟中斷”即bh函式的執行機制。主要包括設備驅動程式的動態裝入和連線的開發和實現、IRP的生成和傳遞、以及設備驅動程式的啟動、同步、和終結開發和實現、 將設備驅動程式的中斷服務登記嫁接到Linux的中斷機制上,將設備驅動程式所關心的Windows核心運行狀態映射到Linux核心的運行狀態上、 將設備驅動程式的DPC請求嫁接到Linux的bh函式機制上。 Windows的設備驅動模組(.sys檔案)——微軟持有著作權的.sys檔案基本上是一些標準的、基本的、常用的外部設備,包括磁碟、USB、圖形設備、網路設備等的設備驅動模組。Linux實際上已經具備相應的功能,只是需要將Linux核心(包括設備驅動模組)中的這些函式和數據結構與具體.sys的調用界面之間架起橋樑。但是也可能有一些微軟的.sys模組在Linux核心中找不到對應物,那就需要仿製了。 Windows設備驅動支撐界面——多數設備驅動界面函式(以及數據結構)在Linux核心中都有對應物,需要做的就是把所需的支撐函式和數據結構通過映射(重定向)/嫁接(適配)落實到相應的Linux核心函式和數據結構上,包括一些適配的工作。也有些函式在Linux核心中沒有較為接近的對應物,那就要用Linux核心中的各種素材加以搭建。 ReactOS ReactOS是一個MS Windows核心的開源仿製品。與兼容核心利用Linux核心材料構建Windows核心的開發路線不同,它是完全從零開始編碼製作Windows核心的。和兼容核心一樣ReactOS只是一個核心,它依賴Wine項目的用戶空間庫檔案使整個系統能夠運行。兼容核心參考ReactOS的代碼實現Windows核心的基本機制,包括進程/執行緒管理機制,記憶體管理機制,驅動系統框架等。 Wine Wine在用戶空間實現了一個把Windows程式對Windows API調用轉向Linux API調用的兼容層,這個兼容層還負有Windows核心的進程/執行緒管理等的職能。雖然Wine和兼容核心均利用核心材料構建Windows API機制,但具體的實現方法是不同的,兼容核心是在核心空間利用Linux核心的核內函式來實現的,而Wine利用的是宿主作業系統的API來實現。另外兼容核心是在核內利用核心函式實現進程管理、執行緒管理、對象管理、虛擬記憶體管理、同步、系統調用、系統註冊機制和設備驅動程式框架等Windows基本機制的,而Wine是在用戶空間實現這些功能的。雖然兼容核心採取的技術線路與Wine的不相同,但Wine的實現方法還是可以能為兼容核心提供借鑑的,而Wine對Windows核心有關數據結構的研究成果則可以直接被兼容核心利用。 Windows用戶空間庫檔案(.dll檔案)雖然不是核心的一部分,但它們是作業系統能夠運行套用軟體不可或缺的部分。Windows用戶空間庫檔案數量眾多,Wine項目花了大量的精力仿製了這些檔案。兼容核心只實現Windows核心相關功能,它依賴Wine提供Windows用戶空間庫檔案。大多數Wine的dll檔案可以直接用在兼容核心上。 兼容核心已經實現進程/執行緒管理、對象管理、虛擬記憶體管理等功能,但還有部分功能沒有實現。在過渡時期,兼容核心利用Wine來提供它還沒有實現的功能。 Kernel-win32 Kernel-Win32是一個試圖把Wine的部分模組移入Linux核心以提高Wine的運行效率的項目。兼容核心利用(部分是重實現)kernel-win32項目代碼實現了兼容核心的Windows系統調用機制。 NDISwrapper NDISWrapper在Linux核心中實現了Windows核心的一些部件,包括NTOSKRNL API(一個基本的WDM控制器)和一系列諸如把Wireless/NDIS/USB/PnP等的Windows系統調用轉向Linux系統調用的封裝。NDISWrapper不限於執行NDIS驅動,只要WDM驅動不調用它還未實現的Windows系統調用也是可以運行的。因此可以認為NDISWrapper是一個WDM的雛形。兼容核心可以參考NDISWrapper和ReactOS的WDM實現構建自己的WDM。

用戶

MagicLinux - MagicLinux是一個基於Red Hat Linux的中文Linux發行版。MagicLinux 2.1之兼容核心衍生版是第一個內置兼容核心的發行版,它包含兼容核心0.2.2版本。

硬體需求

兼容核心最低的硬體需求是:
128MB RAM IDE或SATA 硬碟 VGA兼容顯示卡 PS/2或USB鍵盤 PS/2或USB滑鼠

架構支持

x86 (可用) Loongson 3 (計畫) -- Loongson 3是一種MIPS-III 64-bit構架的通用CPU,它計畫通過包含二百多條指令來硬體來仿真x86 CPU指令,從而使得MS Windows能在其上運行。

相關詞條

熱門詞條

聯絡我們