日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
探索WindowsCE6驅(qū)動程序新特性

Windows CE 6驅(qū)動程序新特性之訪問檢查

目前成都創(chuàng)新互聯(lián)已為千余家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)頁空間、成都網(wǎng)站托管、企業(yè)網(wǎng)站設(shè)計(jì)、墾利網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

訪問檢查是用來檢查函數(shù)的調(diào)用者是否有足夠的權(quán)限去訪問傳遞給這個(gè)函數(shù)的內(nèi)存。訪問檢查是很必要的,它可以防止惡意的應(yīng)用程序利用驅(qū)動程序去完成需要特權(quán)才能訪問的資源。設(shè)備驅(qū)動程序由于在Windows Embedded CE 6.0中處于內(nèi)核空間所以是一種特權(quán)程序,可以訪問很多系統(tǒng)的資源。而工作在用戶態(tài)的應(yīng)用程序卻不是。如果一個(gè)應(yīng)用程序利用設(shè)備驅(qū)動程序去讀寫系統(tǒng)的內(nèi)存,那么設(shè)備驅(qū)動程序?qū)嶋H上就相當(dāng)于是授予了這個(gè)應(yīng)用程序高的訪問權(quán)限。所以在設(shè)備驅(qū)動程序中進(jìn)行訪問檢查可以保護(hù)操作系統(tǒng)的內(nèi)存不受惡意應(yīng)用程序的破壞。

在Windows CE 5.0中,設(shè)備驅(qū)動程序是通過MapCallerPtr API來對指針參數(shù)和嵌套的指針參數(shù)進(jìn)行訪問檢查的。

 
 
 
  1. struct MyStruct { UCHAR *pEmbedded; DWORD dwSize; };  
  2.  
  3. // Windows CE 5.0 and prior versions  
  4.  
  5. // In XXX_IOControl...  
  6.  
  7.    
  8. MyStuct *p = ( MyStruct*) pInput;  
  9.  
  10. g_pMappedEmbedded = MapCallerPtr(p->pEmbedded);  
  11.  
  12. // Fail if g_pMappedEmbedded == NULL ...  
  13.  

在Windows Embedded CE 6.0中,設(shè)備驅(qū)動程序只需要檢查嵌套的指針參數(shù)是否有效就可以了。所不同的是在Windows Embedded CE 6.0中需要使用CeOpenCallerBuffer這個(gè)API來檢查是否對于某一段內(nèi)存,調(diào)用進(jìn)程是否有訪問權(quán)限。

 
 
 
  1. // Now in the New CE Version  
  2.  
  3. // In XXX_IOControl...  
  4.  
  5. hr = CeOpenCallerBuffer((PVOID*)&g_pMappedEmbedded, pInput->pEmbedded, pInput->dwSize, ARG_I_PTR, FALSE);  
  6.  
  7. // Fail if FAILED(hr) == true  
  8.  
  9. // When done with pointer...  
  10.  
  11. hr = CeCloseCallerBuffer((PVOID)g_pMappedEmbedded, pInput->pEmbedded, pInput->dwSize, ARG_I_PTR );  
  12.  

Windows CE 6驅(qū)動程序新特性之Marshalling

處于內(nèi)核態(tài)的線程對位于用戶空間的內(nèi)存的訪問可以分為兩種方式。同步訪問(Synchronous Access)和異步訪問(Asynchronous Access)。同步訪問是指,當(dāng)訪問這塊內(nèi)存區(qū)域時(shí),處于內(nèi)核態(tài)的線程是在調(diào)用者的上下文環(huán)境內(nèi)。而異步訪問正好相反,設(shè)備驅(qū)動程序所擁有的一個(gè)線程要訪問的一塊內(nèi)存區(qū)域,而該區(qū)域正位于其他進(jìn)程的地址空間中,那么這就是異步訪問。

舉個(gè)異步訪問的例子,比如應(yīng)用程序通過WriteFile API來向設(shè)備SD卡中寫入一段數(shù)據(jù),最后寫的請求會通過操作系統(tǒng)內(nèi)核發(fā)送到SD卡的設(shè)備驅(qū)動中,由設(shè)備驅(qū)動程序來寫入數(shù)據(jù)。但是I/O操作是一個(gè)很慢的操作,為了使CPU達(dá)到高的利用率,內(nèi)核往往會在這時(shí)重新調(diào)度一個(gè)線程開始執(zhí)行,這樣用戶空間就可能發(fā)生了一次切換。這里說可能,是因?yàn)槿绻徽{(diào)度的線程和當(dāng)前的應(yīng)用程序(也就是當(dāng)前進(jìn)程)處于同一進(jìn)程空間的話,那么就不發(fā)生進(jìn)程的切換,并且要寫入的這段數(shù)據(jù)由于還是位于當(dāng)前進(jìn)程空間中,所以就是對于這塊數(shù)據(jù)的訪問就是同步的。反之,如果被調(diào)度的線程不處于當(dāng)前進(jìn)程的空間,那么就會發(fā)生一次進(jìn)程的切換,新的進(jìn)程會替換老的進(jìn)程,這時(shí)要寫入的這塊數(shù)據(jù)區(qū)域?qū)τ谠O(shè)備驅(qū)動程序中的線程來說就是無效的,這也稱為異步訪問。

對于異步訪問必須采用一種叫Marshalling的技術(shù)來處理被訪問的數(shù)據(jù)區(qū)域。

在Windows CE 5.0中,所有的用戶態(tài)進(jìn)程共享底部的虛擬地址。所以當(dāng)Slot 0中被替換為不同進(jìn)程時(shí),由于所有的進(jìn)程的虛擬地址空間對于設(shè)備驅(qū)動程序來說都可見,只需要對指向數(shù)據(jù)塊首地址的指針做一次偏移,就可以得到這塊數(shù)據(jù)。

在Windows Embedded CE 6.0中,每個(gè)用戶態(tài)的進(jìn)程都有自己獨(dú)有的虛擬地址空間,每個(gè)進(jìn)程的虛擬地址空間都是受到保護(hù)的。所以對一塊內(nèi)存做Marshall不再是簡單的將指針進(jìn)行偏移。這時(shí)可以采用兩種方法來對一塊內(nèi)存做Marshall,一種方法是將這塊內(nèi)存拷貝一份這樣就可以安全的訪問,這種方法稱為復(fù)制。另一種方法是用一個(gè)新的虛擬地址去引用所對應(yīng)的物理,這樣一來這塊數(shù)據(jù)就分別被兩個(gè)指針分別引用,這種方法稱為別名。

Marshall一塊內(nèi)存區(qū)域需要區(qū)分同步訪問和異步訪問。在Windows CE 5.0中,對于同步訪問來說,不需要做多余的工作,只需要調(diào)用MapCallerPtr API來Marshall嵌套指針?biāo)傅牡刂芳纯伞τ诋惒皆L問,線程對于每個(gè)Slot都有一定的訪問權(quán)限,所以需要通過調(diào)用SetProcPermissions來先獲得調(diào)用進(jìn)程Slot的訪問權(quán)限,然后調(diào)用MapCallerPtr來Marshall所要異步訪問的內(nèi)存。

 
 
 
  1. // Windows CE 5.0 and prior versions  
  2.  
  3.    
  4. // In XXX_IOControl...  
  5.  
  6.    SetProcPermissions(-1);  
  7.  
  8.    g_pMappedEmbedded = MapCallerPtr( p->pEmbedded );  
  9.  
  10. // Fail if g_pMappedEmbedded == NULL ...  

在Windows Embedded CE 6.0中,對于同步訪問,通過設(shè)備驅(qū)動程序通過調(diào)用CeOpenCallerBuffer來Marshall嵌套指針?biāo)傅臄?shù)據(jù)塊的首地址,當(dāng)這塊數(shù)據(jù)使用完以后,設(shè)備驅(qū)動程序調(diào)用CeFreeCallerBuffer來釋放Marshall所得資源。對于異步訪問,假設(shè)設(shè)備驅(qū)動程序可以同步的訪問一塊內(nèi)存,那么這時(shí)就可以通過調(diào)用CeAllocAsynchronousBuffer來Marshall這塊內(nèi)存用來做異步訪問之用。在使用完之后,可以通過調(diào)用CeFreeAsynchronousBuffer來釋放Marshall所得資源。

 
 
 
  1. // Now in the New OS Version  
  2.  
  3. // In XXX_IOControl after CeOpenCallerBuffer generates  
  4.  
  5. // g_pMappedEmbedded...  
  6.  
  7.  
  8. hr = CeAllocAsynchronousBuffer((PVOID*)&g_pMarshalled, g_pMappedEmbedded, pInput->dwSize, ARG_I_PTR);   
  9.  
  10. // Fail if FAILED(hr) == true  
  11.  
  12.  
  13. // When done with pointer...  
  14.  
  15. hr = CeFreeAsynchronousBuffer((PVOID)g_pMarshalled, g_pMappedEmbedded, pInput->dwSize, ARG_I_PTR);   
  16.  
  17.  
  18. // Now call CeCloseCallerBuffer as usual...  
  19.  

Windows CE 6驅(qū)動程序新特性之用戶模式下的驅(qū)動程序

在Windows Embedded CE 6.0之前,設(shè)備驅(qū)動程序是加載在device.exe進(jìn)程之中的,而device.exe與普通應(yīng)用程序一樣也是用戶態(tài)的進(jìn)程。所以每次應(yīng)用程序希望能夠與外設(shè)進(jìn)行交互時(shí),都需要通過操作系統(tǒng)內(nèi)核轉(zhuǎn)發(fā)請求到相應(yīng)的驅(qū)動程序。這樣一個(gè)請求就可以需要反復(fù)的進(jìn)出內(nèi)核多次,還需要在不同的進(jìn)程間進(jìn)行切換。這樣做的好處和缺點(diǎn)同樣的明顯,優(yōu)點(diǎn)是操作系統(tǒng)的穩(wěn)定性得到了提高,不會因?yàn)槟硞€(gè)設(shè)備驅(qū)動中的缺陷而使整個(gè)操作系統(tǒng)崩潰。但缺點(diǎn)是完成請求的效率太低。

在Windows Embedded CE 6.0中,設(shè)備驅(qū)動程序能夠工作在用戶模式或是內(nèi)核模式兩種不同的模式。由于在Windows Embedded CE 6.0新的體系結(jié)構(gòu)中將操作系統(tǒng)關(guān)鍵的部件如文件系統(tǒng)Filesystem.exe、設(shè)備驅(qū)動程序管理Device.exe等都移進(jìn)了操作系統(tǒng)內(nèi)核之中,驅(qū)動程序完成一個(gè)請求不再需要在不同的進(jìn)程下進(jìn)行切換,也不需要反復(fù)的進(jìn)出內(nèi)核,所以內(nèi)核模式下的驅(qū)動程序完成請求的效率將會大大的提高。但是這樣的效率提高也是要有代價(jià)的。內(nèi)核模式下的驅(qū)動程序需要有很高的穩(wěn)定性,任何一個(gè)錯誤都可能引起整個(gè)操作系統(tǒng)的崩潰。為了解決這個(gè)問題,Windows Embedded CE 6.0中還設(shè)計(jì)了另一類稱為用戶模式的設(shè)備驅(qū)動程序。

Windows Embedded CE 6.0中設(shè)計(jì)了一個(gè)用戶進(jìn)程udevice.exe用來加載設(shè)備驅(qū)動程序。因?yàn)槭潜挥脩魬B(tài)的進(jìn)程所加載,所以這類驅(qū)動程序就工作在用戶空間,這類驅(qū)動程序就成為用戶模式下的設(shè)備驅(qū)動程序。用戶模式的驅(qū)動程序無疑將增加操作系統(tǒng)的穩(wěn)定性,并且由于這類驅(qū)動程序工作在用戶空間,所以能力有限,不能使用諸如VirtualCopy這樣的特權(quán)API,也不能對系統(tǒng)中的硬件資源有任意的訪問權(quán)限。

用戶模式的設(shè)備驅(qū)動程序還有一個(gè)特點(diǎn)就是它們與內(nèi)核模式的設(shè)備驅(qū)動程序具有高度的兼容性。一個(gè)好的用戶模式的設(shè)備驅(qū)動程序的源代碼不需要做任何的改動就可以做為內(nèi)核模式的設(shè)備驅(qū)動程序被加載進(jìn)內(nèi)核空間。區(qū)分用戶模式的設(shè)備驅(qū)動程序和內(nèi)核模式的設(shè)備驅(qū)動程序標(biāo)志就是設(shè)備驅(qū)動程序在系統(tǒng)注冊表中的Flag值。當(dāng)Flag具有DEVFLAGS_LOAD_AS_USERPROC(0x10)時(shí),系統(tǒng)會將設(shè)備驅(qū)動程序加載成用戶模式,如果沒有該標(biāo)志就加載成內(nèi)核模式。

總的來說,用戶模式下Windows CE 6驅(qū)動程序新特性的設(shè)備驅(qū)動程序和內(nèi)核模式下的設(shè)備驅(qū)動程序是很相似的。在有了用戶模式設(shè)備驅(qū)動程序和內(nèi)核模式設(shè)備驅(qū)動程序后,在OEM開發(fā)BSP的過程中,如果采用了某些第三方的,未經(jīng)充分測試的驅(qū)動程序后??梢韵葘⑦@些驅(qū)動程序做為用戶模式下的設(shè)備驅(qū)動程序加載到用戶空間,等到整個(gè)系統(tǒng)經(jīng)過測試可以長時(shí)間穩(wěn)定運(yùn)行后,再將其轉(zhuǎn)變成內(nèi)核模式下的驅(qū)動程序加載到內(nèi)核空間以提高整個(gè)系統(tǒng)的效率。


網(wǎng)頁題目:探索WindowsCE6驅(qū)動程序新特性
瀏覽路徑:http://www.dlmjj.cn/article/ccspsoc.html