Wince5恢復(fù)默認(rèn)(注冊表)
對于WinCE5.0:
本文引用地址:http://m.butianyuan.cn/article/148292.htm1. pbxmlutils.exe
在 “Windows CE Platform. Builder5.00CEPBBIN”下面可以找到,這個命令可以從PB的文檔中查到。主要作用是通過解析你的工程文件
pbxmlutils /getbuildenv /workspace %_WINCEROOT%PBWorkspaces
看著可能有點暈,我來舉個例子:
pbxmlutils /getbuildenv /workspace %_WINCEROOT%PBWorkspacesMyWorkspaceMyWorkspace.pbxml /config CEPC: x86_Release > SetEnv.bat
其實就兩個參數(shù),第一個參數(shù)很多人都知道如何設(shè)置,第二個參數(shù)config可能有些人不太了解,你可以打開你的工程,然后查環(huán)境變量PBCONFIG的值,用這個值就可以了。
2. Blddemo.exe
這個應(yīng)該比較熟悉。編譯WinCE的時候,實際上就是調(diào)用Blddemo -q,不多說了。
3. buildsdk.exe
這個是用來編譯SDK的。格式如下;
buildsdk [MyOSDesign.pbxml]
很簡單,不過還是給個例子:
buildsdk %_WINCEROOT%PBWorkspacesMyWorkspaceMyWorkspace.pbxml
在某些應(yīng)用場合需要將注冊表還原成為出廠的默認(rèn)設(shè)置。以前當(dāng)Wince使用了HIVE注冊表后,每次用戶的注冊表改動將得到保存,而不會恢復(fù)默認(rèn)注冊表。通常要求能夠在AP中通過點擊一個按鈕來實現(xiàn)這種clean boot。當(dāng)Wince使用了HIVE注冊表后,每次用戶的注冊表改動將得到保存,但是在某些應(yīng)用場合需要將注冊表還原成為出廠的默認(rèn)設(shè)置,通常要求能夠在AP中通過點擊一個按鈕來實現(xiàn)這種clean boot。
方法一:
使用HIVE注冊表,系統(tǒng)在完成了第一階段也就是加載完了boot.hv+binfs之后和加載系統(tǒng)HIVE注冊表之前,filesys.exe都會調(diào)用OEMIoControl來查詢是否需要清除保存在block設(shè)備上的hv文件,其CODE代碼為IOCTL_HAL_GET_HIVE_CLEAN_FLAG,它的輸入?yún)?shù)lpInBuf固定為HIVECLEANFLAG_system或HIVECLEANFLAG_USERS,filesys.exe會分別用這兩種參數(shù)調(diào)用兩次IOCTL_HAL_GET_HIVE_CLEAN_FLAG,第一次用HIVECLEANFLAG_SYSTEM來問OEM是否需要清除system.hv,第二次用HIVECLEANFLAG_USERS做參數(shù)來查詢是否要清除user.hv,如果返回的lpOutBuf中的值為TRUE則做清除操作,如果為False則保留block設(shè)備上的注冊表文件。
默認(rèn)WINCE并沒有實現(xiàn)這個IOCTL,所以O(shè)EM要刪除注冊表文件就必須先編寫這個IOCTL代碼。代碼的例子可參考標(biāo)題為“IOCTL_HAL_GET_HIVE_CLEAN_FLAG”的幫助文檔。另外 必須在ioctl.h和ioctl.c兩個文件中編寫該代碼。
要進(jìn)一步了解這個全局?jǐn)?shù)組,參見標(biāo)題為“IOCTL Library”的幫助文檔。
可以使用共享內(nèi)存空間來實現(xiàn),我們可以在物理內(nèi)存中保留出一塊不會被其他模塊占用的空間,在這個空間放置兩個BOOL變量分別來保存system和user的hv清除的標(biāo)志符,缺省它們都為False,OALIoCtlBGetHiveCleanFlag()讀到Flase則認(rèn)為不清注冊表,AP在需要的時候?qū)⑦@兩個標(biāo)志符置為True,接下來就是要重新啟動到OALIoCtlBGetHiveCleanFlag()函數(shù)被調(diào)用的地方,由于標(biāo)志符號是保存在RAM中的,斷電會丟失,還好有個方法可以讓系統(tǒng)復(fù)位而又能保存RAM中的內(nèi)容,那就是Reset,所以讓AP在設(shè)置完標(biāo)志符后馬上調(diào)用Reset指令就可以完美實現(xiàn)Clean boot了。
1 在ioctl.c文件中找到 const OAL_IOCTL_HANDLER g_oalIoCtlTable[],添加IOCTL和對應(yīng)的處理函數(shù)OALIoCtlBGetHiveCleanFlag
{ IOCTL_HAL_GET_HIVE_CLEAN_FLAG, 0, OALIoCtlBGetHiveCleanFlag },
2 在ioctl.c文件中實現(xiàn)該函數(shù)
//added by aulyp for 恢復(fù)出廠設(shè)置
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(pArgs->bClearSystemHive) //判斷是否清除system.hv
{
RETAILMSG(1, (TEXT(OEM: cleaning system hivern)));
}
else
{
RETAILMSG(1, (TEXT(OEM: Not cleaning system hivern)));
}
*pfClean = pArgs->bClearSystemHive;
pArgs->bClearSystemHive=FALSE; //一定在執(zhí)行完后設(shè)置為默認(rèn)的false否則常規(guī)reset都會清空注冊表
}
else if (*pdwFlags == HIVECLEANFLAG_USERS)
{
if(pArgs->bClearUserHive) //判斷是否清除user.hv
{
RETAILMSG(1, (TEXT(OEM: cleaning user hivern)));
}
else
{
RETAILMSG(1, (TEXT(OEM: Not cleaning user hivern)));
}
*pfClean = pArgs->bClearUserHive
pArgs->bClearUserHive=FALSE; //restore to default
}
}
return TRUE;
}
3 Args.h文件中,找到BSP_ARGS結(jié)構(gòu)體定義
加入如下:
BOOL bClearSystemHive=FALSE; //TRUE ? clear system.hv
BOOL bClearUserHive=FALSE; //TRUE ? clear user.hv
4 在Oal_ioctl.h中加入函數(shù)聲明
BOOL OALIoCtlBGetHiveCleanFlag(UINT32 code, VOID *lpInBuf , UINT32 nInBufSize,
評論