http://www.51kaifa.com/html/jswz/200806/read-10147.htm
摘要:本文首先讲述了Windows CE注册表的重要性,它对整个嵌入式系统的正常运行起着关键性作用。然后又介绍了两种注册表存储方式,并着重讲述了基于HIVE的注册表。详细阐述了基于HIVE的注册表的保存数据方式及实现HIVE注册表的方法。最后给出了系统成功修改注册表的实现方法。本文的研究对其它操作系统的注册表修改也具有着借鉴意义。
关键词:Windows CE;注册表;HIVE;信息存储
0 引言
嵌入式操作系统Windows CE和桌面操作系统一样使用注册表(Registry)来保存应用程序、驱动程序和用户的设定以及其他一些配置信息,通常还存储着操作系统调用程序的状态信息,所以注册表起着非常重要的作用,它是Windows CE操作系统的核心。在没有注册表的情况下,操作系统将不能获得必需的信息来运行和控制附属的设备和应用程序及正确响应用户的输入[1][2]。
1 Windows CE注册表简介
Windows CE的注册表结构和其他版本的Windows操作系统的注册表结构是类似的。注册表是一个包括主关键字子树的集合,它和文件目录树一样具有层次结构。每个子树又由更低层的子树、键以及键值组成。键相当于文件系统的目录,每个键包含若干键值项。而键值项相当于文件系统末端的文件,它由键值名、数据类型和键值组成。键值就是注册表存储的数据。
Windows CE对注册表的值有一些限制:键或者键值项的名字最多为255个字符,数据最大为4K,键嵌套层次最多为16层。所以在使用注册表编程时,要尽量使键和键值项占用最小的空间。另外,需要注意的是,在注册表中,键值项比键值占用更大的存储空间。
Windows CE注册表包括4个根键[2],如表1所示。
根键名 | 键值内容 |
HKEY_LOCAL_MACHINE | 硬件及驱动程序配置数据 |
HKEY_CURRENT_USER | 用户配置数据 |
HKEY_CLASSES_ROOT | OLE和文件类型匹配配置数据 |
HKEY_USERS | 适用于所有用户的存储数据 |
表1 Windows CE注册表根键
Table1 The root key of Windows CE register
2 Windows CE注册表类型
由于嵌入式系统的特点,一些嵌入式设备是没有外存的。因此Windows CE的注册表提供了两种实现方式:基于对象存储的注册表(RAM-Based Registry)和基于Hive的注册表(Hive-Based Registry)[3]。我们可以在Windows CE中使用任何一种注册表,注册表类型对于用户和应用程序来说都是透明的。基于RAM的注册表在经常热启动的设备上是非常高效的,而在经常冷启动的设备上,性能却很令人失望,最适合有电池后备的个人电子消费类产品。对于经常冷启动或者不怎么使用热启动方式的设备来说,基于hive的注册表是非常高效的,最适合永久性的存储器和多用户环境下使用。
2.1 基于RAM的注册表
顾名思义,基于RAM的注册表把整个注册表作为一个对象存储堆放在RAM中。这就意味着如果系统中断对RAM的电池供电,对注册表的所有改动都会丢失。也就是说,它们的有效性和RAM中数据的有效性是一致的。但是使用RAM注册表,对注册表的读写访问操作非常的快速高效。在旧版本的Windows CE中,大量应用了基于RAM的注册表。如果有外存且需要经常冷启动的设备采用基于RAM的注册表,则需要在系统断电的时候对注册表进行保存,等系统再次启动时对保存的注册表进行还原。
2.2 基于HIVE的注册表
HIVE系统包含了不属于任何用户信息的系统设置。HIVE系统由OEM层调用。通常hive文件为System.hv,但是它的存储位置可能随着平台而变化。这种存储方式使系统在断电前后无须备份和恢复注册表数据,这使得系统冷启动时速度更快。
基于HIVE结构的注册表被分为两部分存储:系统HIVE,存储所有的系统数据;用户HIVE,存储对特定用户的所有相关数据。一个多用户系统将包括几个用户HIVE。当一个用户登录时,相应的用户HIVE就会被激活,当用户退出时,相应的用户HIVE也会被撤销。所有的用户HIVE都用USER.hv来命名,并且被放在不同的用户目录中,每个目录都是以它属于的用户的用户名来命名的。
注册表中的HKEY_LOCAL_MACHINE/init/BootVars下的键值项ProfileDir存储着所有用户目录的位置。HKEY_LOCAL_MACHINE/init/BootVars下的键值项SystemHive存储着系统HIVE的文件路径和文件名。
BOOT HIVE存储只用于系统启动时的系统设置。BOOT HIVE从ROM中读出并用于启动驱动程序和相关的文件系统。这个文件系统用于启动系统HIVE文件。当系统HIVE启动后,BOOT HIVE将被终止。当系统HIVE有效时,启动过程中被修改的注册表数据将被存放于系统HIVE中。但是BOOT HIVE在ROM中的数据还保持不变。
3 HIVE注册表的实现
HIVE注册表是通过修改系统的平台文件来实现的,在工程目录下的PLATFORM.REG文件中包含了系统的启动信息,HIVE注册表的启动方式不同于普通注册表的启动方式,它需要在系统加载设备管理器前加载系统存储媒介的驱动程序,只有这样才能在加载设备管理器当中提取设备在注册表中的保存信息,达到HIVE存储的目的。下面介绍如何让系统支持HIVE
注册表中的HIVE | 文件 | 描述 |
BOOT HIVE | BOOT.hv存于ROM中 | 包括所有 HKEY_LOCAL_MACHINE HKEY_CLASSES_ROOT HKEY_USERS下的数据,只是在启动时使用。启动后对它的修改将影响系统HIVE |
SYSTEM HIVE | OEM-dependen | 包括所有 HKEY_LOCAL_MACHINE HKEY_CLASSES_ROOT HKEY_USERS下的数据,包括对每个用户都一样的设备的设置 |
USER HIVE | USER.hv | 包括所有HKEY_CURRENT_USER下的数据,包含用户定义的设置。每个用户具有不同的HIVE,当用户登录时会启动它,当退出时,会将它关闭 |
表2 标准HIVE及其支持的文件
Table2 Standard HIVE and support type
注册表存储:
1)修改设备管理器的启动信息值
“Start DevMgr”= dword:1
此册项代表使用HIVE注册表存储系统信息
2)把系统的存储媒介驱动程序加在
“HIVE BOOT SECTION”与“END HIVE BOOT SECTION”
的注释之间,该注释被编译器选择提取之后,在系统上电后加载在设备管理器之前
3)在系统的存储媒介驱动程序上提供一个FLAG项,该项的目的是对目标数据进行逻辑运算。
“flags”= dword:1
通过以上参数的修改,系统即可支持HIVE注册表存储,该存储方式有效存储系统保存在HIVE注册表中的信息,比如触摸屏触电校验信息,系统IP地址等。经大量试验证明,该方法有效可行。
4 系统注册表修改分析
4.1 触摸屏驱动程序注册表设置
下面是本多媒体系统触摸屏驱动程序的注册表信息设置,我们在校准的时候需要在注册表中存储一些校准坐标信息:
[HKEY_LOCAL_MACHINE/ControlPanel]
"InputConfig"= dword:3 ;3 =>键盘和触摸屏
[HKEY_LOCAL_MACHINE/HARDWARE/DEVICEMAP/TOUCH]
"DriverName"="touch:dll"
"MaxCalError"=dword:10
"CalibrationData"="500,512 762,268 758,760 244,758 241,266 "//校准信息
Landscape
"CalibrationData"="515,503 763,748 258,749 269,255 764,255 "
图1 HIVE注册表需要修改的文件
Fig.1 The file wants modified if HIVE register needs
4.2 在映像中固定IP地址
在我们自己创建的调试环境中每次启动后都需要手动修改IP后才能多人同时调试,所以要想将IP地址固定下来就要关系到注册表的修改。而关于IP地址的更改一定会反映到系统注册表中,也就是说如果能将这部分更改在定制操作系统的时候就加进去,那么当映像启动后,就具有设定好的IP地址了[4]。
经过不断摸索,得出的结论很好,修改平台文件project.reg,在文件中添加以下内容:
[HKEY_LOCAL_MACHINE/comm/vmini1/parms/tcpip]
"defaultgateway" = multi_sz:"192.168.0.1"
"subnetmask" = multi_sz:"255.255.255.0"
"IpAddress" = multi_sz:"192.168.0.5"
"enabledhcp" = dword:0
第一个是默认网关,第二个是子网掩码,第三个是IP地址,最后一个也必须加,就是禁用DHCP,只有这样自己的设定才能生效。
注意:注册表键值类型一定要设置好,像上面的multi_sz,dword一定要添加在前面,否则仍然没有效果。
4.3 SD卡驱动注册表信息
SD卡是车载多媒体系统的重要外围存储设备,为灵活实现SD卡热插拔功能,使用流接口驱动模型。SD卡驱动程序以及它所使用的文件系统都是由存储管理器负责的。在存储管理器的启动过程中,很多配置信息都是从系统的注册表得到的。因此必须先创建如下SD卡注册表信息:
[HKEY_LOCAL_MACHINE/Drivers/BuiltIn/sdcard]
"D11"="sdcard.d11"
"Prefix"="SDC"
"Index"=dword:1
"Order"=dword:l
"FSD"="fatfs.d11"
[HKEY_LOCAL_MACHINE/System/StorageManager/Profiles/SDCARD]
"Name"="SD Card"
"Folder"= "SDCARD Storage"
5 结论
注册表是Windows CE操作系统的核心,起着至关重要的作用,车载多媒体系统的所有驱动程序和应用程序的配置信息都被保存在注册表中,如果修改或加载不当,都将使得整个系统的一些功能不能正常使用,甚至将会导致Windows CE操作系统无法启动。本文的创新点在于提出了一种实现HIVE注册表的方法和修改注册表的思路,经大量试验证明此种思路很有效,可以用来修改更多其它需要的配置。随着我国的汽车事业的蓬勃发展,汽车导航多媒体系统有着越来越广阔的应用前景,本项目的经济效益预计在八十万元左右。
参考文献:
[1] 林涛. 嵌入式操作系统Windows CE的研究[J].微计算机信息,2006,6-2:91-93.
[2] 张冬泉等.Windows CE实用开发技术[M].北京:电子工业出版社,2006年.
[3] [美]微软公司. Microsoft Windows CE Device Driver Kit设备驱动程序开发指南[M].北京: 北京希望电子出版社,1999.
[4] 周毓林,宁杨,付林林.Windows CE.net内核定制及应用开发[M].北京:电子工业出版社.2005年.