新聞中心

wince5.0 注冊(cè)表還原

作者: 時(shí)間:2011-02-24 來源:網(wǎng)絡(luò) 收藏
當(dāng)Wince使用了HIVE注冊(cè)表后,每次用戶的注冊(cè)表改動(dòng)將得到保存,但是在某些應(yīng)用場(chǎng)合需要將注冊(cè)表還原成為出廠的默認(rèn)設(shè)置,通常要求能夠在AP中通過點(diǎn)擊一個(gè)按鈕來實(shí)現(xiàn)這種clean boot。使用我前面的文章的方法配置的HIVE系統(tǒng)注冊(cè)表和HIVE用戶注冊(cè)表分別保存在/HDD/Document and Setting/system.hv 中和 /HDD/Document and Setting/default/user.hv中,每次系統(tǒng)在啟動(dòng)到加載HIVE系統(tǒng)注冊(cè)表之前都會(huì)先檢查保存在/HDD中的文件的存在和合法性,如果不滿足要求系統(tǒng)將會(huì)用binfs中的缺省文件創(chuàng)建新的system.hv和user.hv文件于/HDD中,根據(jù)這個(gè)特性我先試圖在WinCE運(yùn)行起來后刪除這兩個(gè)hv文件,但是由于WinCE已經(jīng)事先加載了它們,刪除被禁止,只有采用其他的方法。

重新研究了基于HIVE注冊(cè)表的WinCE的啟動(dòng)過程發(fā)現(xiàn),系統(tǒng)在完成了第一階段也就是加載完了boot.hv+binfs之后和加載系統(tǒng)HIVE注冊(cè)表之前,filesys.exe都會(huì)調(diào)用OEMIoControl來查詢是否需要清除保存在block設(shè)備上的hv文件,其CODE代碼為IOCTL_HAL_GET_HIVE_CLEAN_FLAG,它的輸入?yún)?shù)lpInBuf固定為HIVECLEANFLAG_SYSTEM或HIVECLEANFLAG_USERS,filesys.exe會(huì)分別用這兩種參數(shù)調(diào)用兩次IOCTL_HAL_GET_HIVE_CLEAN_FLAG,第一次用HIVECLEANFLAG_SYSTEM來問OEM是否需要清除system.hv,第二次用HIVECLEANFLAG_USERS做參數(shù)來查詢是否要清除user.hv,如果返回的lpOutBuf中的值為TRUE則做清除操作,如果為False則保留block設(shè)備上的注冊(cè)表文件。

所以我們要做的就是實(shí)現(xiàn)和IOCTL_HAL_GET_HIVE_CLEAN_FLAG相對(duì)應(yīng)的OEMIoControl源碼(假設(shè)由OALIoCtlBGetHiveCleanFlag()這個(gè)function來實(shí)現(xiàn)),加入對(duì)是否需要清除注冊(cè)表的判定條件并告知filesys.exe即可。現(xiàn)在棘手的問題是如何讓AP通知OALIoCtlBGetHiveCleanFlag()該不該清除注冊(cè)表,因?yàn)镺ALIoCtlBGetHiveCleanFlag()只能在指定的時(shí)候由filesys.exe去調(diào)用,AP的運(yùn)行只能在OALIoCtlBGetHiveCleanFlag()運(yùn)行完之后。

后來終于想到可以使用共享內(nèi)存空間來實(shí)現(xiàn),我們可以在物理內(nèi)存中保留出一塊不會(huì)被其他模塊占用的空間,在這個(gè)空間放置兩個(gè)BOOL變量分別來保存system和user的hv清除的標(biāo)志符,缺省它們都為False,OALIoCtlBGetHiveCleanFlag()讀到Flase則認(rèn)為不清注冊(cè)表,AP在需要的時(shí)候?qū)⑦@兩個(gè)標(biāo)志符置為True,接下來就是要重新啟動(dòng)到OALIoCtlBGetHiveCleanFlag()函數(shù)被調(diào)用的地方,由于標(biāo)志符號(hào)是保存在RAM中的,斷電會(huì)丟失,還好有個(gè)方法可以讓系統(tǒng)復(fù)位而又能保存RAM中的內(nèi)容,那就是Reset,所以讓AP在設(shè)置完標(biāo)志符后馬上調(diào)用Reset指令就可以完美實(shí)現(xiàn)Clean boot了。

提供相關(guān)代碼作為參考:

BOOL OALIoCtlBGetHiveCleanFlag( // 一般在IOCTL.C中實(shí)現(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í)行完后設(shè)置為默認(rèn)的false否則常規(guī)reset都會(huì)清空注冊(cè)表

} 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中的實(shí)現(xiàn)代碼如下:

Void On_CleanBoot()

{

BSP_ARGS* pArgs = (BSP_ARGS*)IMAGE_SHARE_ARGS_UA_START; //保留的共享RAM空間的虛擬地址

pArgs->bcleansystemhive=TRUE; //設(shè)置system.hv清空標(biāo)志符

pArgs->bcleanuserhive=TRUE; //設(shè)置user.hv清空標(biāo)志符

ReSet();

linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)


評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉