Wince5恢復默認(注冊表)
VOID *lpOutBuf,UINT32 nOutBufSize , UINT32 *pOutSize);
5在應用中可以如下使用:
Void On_CleanBoot()
{
BSP_ARGS* pArgs = (BSP_ARGS*)IMAGE_SHARE_ARGS_UA_START;
//保留的共享RAM空間的虛擬地址
pArgs-> bClearSystemHive =TRUE; //設置system.hv清空標志符
pArgs-> bClearUserHive =TRUE; //設置user.hv清空標志符
ReSet();
}
使用這種方法每次系統(tǒng)在啟動到加載HIVE系統(tǒng)注冊表之前都會先檢查保存在/HDD中的文件的存在和合法性,如果不滿足要求系統(tǒng)將會用binfs中的缺省文件創(chuàng)建新的system.hv和user.hv文件于/HDD中,根據(jù)這個特性我在WinCE運行起來后刪除這兩個hv文件,但是由于WinCE已經事先加載了它們,刪除被禁止,只有采用其他的方法來解決。
基于HIVE注冊表的WinCE的啟動過程我發(fā)現(xiàn),系統(tǒng)在完成了第一階段也就是加載完了boot.hv+binfs之后和加載系統(tǒng)HIVE注冊表之前,filesys.exe都會調用OEMIoControl來查詢是否需要清除保存在block設備上的hv文件,其CODE代碼為IOCTL_HAL_GET_HIVE_CLEAN_FLAG,它的輸入參數(shù)lpInBuf固定為HIVECLEANFLAG_SYSTEM或HIVECLEANFLAG_USERS,filesys.exe會分別用這兩種參數(shù)調用兩次IOCTL_HAL_GET_HIVE_CLEAN_FLAG,第一次用HIVECLEANFLAG_SYSTEM來問OEM是否需要清除system.hv,第二次用HIVECLEANFLAG_USERS做參數(shù)來查詢是否要清除user.hv,如果返回的lpOutBuf中的值為TRUE則做清除操作,如果為False則保留block設備上的注冊表文件。
所以現(xiàn)在要做的就是實現(xiàn)和IOCTL_HAL_GET_HIVE_CLEAN_FLAG相對應的OEMIoControl源碼(假設由OALIoCtlBGetHiveCleanFlag()這個function來實現(xiàn)),加入對是否需要清除注冊表的判定條件并告知filesys.exe即可。現(xiàn)在的問題是如何讓AP通知OALIoCtlBGetHiveCleanFlag()該不該清除注冊表,因為OALIoCtlBGetHiveCleanFlag()只能在指定的時候由filesys.exe去調用,AP的運行只能在OALIoCtlBGetHiveCleanFlag()運行完之后。
后來想到可以使用共享內存空間來實現(xiàn),可以在物理內存中保留出一塊不會被其他模塊占用的空間,在這個空間放置兩個BOOL變量分別來保存system和user的hv清除的標志符,缺省它們都為False,OALIoCtlBGetHiveCleanFlag()讀到Flase則認為不清注冊表,AP在需要的時候將這兩個標志符置為True,接下來就是要重新啟動到OALIoCtlBGetHiveCleanFlag()函數(shù)被調用的地方,由于標志符號是保存在RAM中的,斷電會丟失,還好有個方法可以讓系統(tǒng)復位而又能保存RAM中的內容,那就是Reset,所以讓AP在設置完標志符后馬上調用Reset指令就可以完美實現(xiàn)Clean boot了。
提供相關代碼作為參考:
BOOL OALIoCtlBGetHiveCleanFlag( // 一般在IOCTL.C中實現(xiàn)
UINT32 code, VOID *lpInBuf , UINT32 nInBufSize, VOID *lpOutBuf,
UINT32 nOutBufSize , UINT32 *pOutSize)
{
BSP_ARGS *pArgs = (BSP_ARGS*)IMAGE_SHARE_ARGS_UA_START; //保留的共享RAM空間的虛擬地址
if (!lpInBuf || (nInBufSize != sizeof(DWORD)) || !lpOutBuf || (nOutBufSize != sizeof(BOOL)))
{
SetLastError(ERROR_INVALID_PARAMETER);
return FALSE;
}
else
{
DWORD *pdwFlags = (DWORD*)lpInBuf;
BOOL *pfClean = (BOOL*)lpOutBuf;
if (*pdwFlags == HIVECLEANFLAG_SYSTEM) {
if(*pfClean = pArgs->bcleansystemhive) //判斷是否清除system.hv
RETAILMSG(1, (TEXT(OEM: cleaning system hivern)));
else
RETAILMSG(1, (TEXT(OEM: Not cleaning system hivern)));
*pfClean = pArgs->bcleansystemhive;
pArgs->bcleansystemhive=FALSE; //一定在執(zhí)行完后設置為默認的false否則常規(guī)reset都會清空注冊表
} else if (*pdwFlags == HIVECLEANFLAG_USERS) {
if(*pfClean = pArgs->bcleanuserhive) //判斷是否清除user.hv
RETAILMSG(1, (TEXT(OEM: cleaning user hivern)));
else
RETAILMSG(1, (TEXT(OEM: Not cleaning user hivern)));
*pfClean = pArgs->bcleanuserhive;
pArgs->bcleanuserhive=FALSE; //restore to default
}
}
return TRUE;
}
AP中的實現(xiàn)代碼如下:
Void On_CleanBoot()
{
BSP_ARGS* pArgs = (BSP_ARGS*)IMAGE_SHARE_ARGS_UA_START; //保留的共享RAM空間的虛擬地址
pArgs->bcleansystemhive=TRUE; //設置system.hv清空標志符
pArgs->bcleanuserhive=TRUE; //設置user.hv清空標志符
ReSet();
評論