×
研发资源 > 电子百科

兼容内核

兼容内核目录[隐藏]
特性
实现Windows内核机制方案的优点
开发
开发策略和线路历史版本
现在和未来的开发
可利用的资源
用户
硬件需求
架构支持 特性
实现Windows内核机制方案的优点
开发
开发策略和线路 历史版本
现在和未来的开发
可利用的资源
用户
硬件需求
架构支持

  兼容内核(Linux Unified Kernel,简称Longene),是一个二进制兼容Windows和Linux应用软件和设备驱动程序的计算机操作系统内核。它试图在Linux内核的基础上利用Linux内核材料构建MS Windows内核功能模块从而扩充Linux内核的支持能力使之同时支持Linux和Windows的应用程序和设备驱动。
  兼容内核主要以C语言编写,以GNU通用公共许可证授权使用。
  虽然兼容内核还处在初期开发阶段,但许多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版本。
相关数据
30次 被浏览次数
1次 编辑次数
|最新活动
|APP下载
下载电巢APP 随时随地看更多电巢视频
|专家解答
关注公众号与专家面对面