




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、驅(qū)動(dòng)對(duì)象與設(shè)備對(duì)象 DRIVER_OBJECT和DEVICE_OBJECT的關(guān)系DRIVER_OBJECT是驅(qū)動(dòng)程序在內(nèi)核中的數(shù)據(jù)結(jié)構(gòu),每個(gè)驅(qū)動(dòng)程序有唯一DRIVER_OBJECT,IO管理器使用驅(qū)動(dòng)程序?qū)ο蟠砻總€(gè)設(shè)備驅(qū)動(dòng)程序,驅(qū)動(dòng)程序描述了驅(qū)動(dòng)程序的載入到內(nèi)存什么地方,驅(qū)動(dòng)程序的大小和它的主要入口點(diǎn)(MajorFunction數(shù)組);驅(qū)動(dòng)程序?qū)ο笥幸粋€(gè)DeviceObject域指向一個(gè)設(shè)備對(duì)象鏈表,每個(gè)設(shè)備對(duì)象代表一個(gè)設(shè)備。DEVICE_OBJECT是物理設(shè)備或邏輯設(shè)備在內(nèi)核中的數(shù)據(jù)結(jié)構(gòu),跟這個(gè)概念相關(guān)的有PDO和FDO;PDO對(duì)應(yīng)于具體的硬件設(shè)備,每個(gè)硬件設(shè)備對(duì)應(yīng)一個(gè)PDO,而一個(gè)PDO
2、可以對(duì)應(yīng)多個(gè)FDO;PDO和FDO都是DEVICE_OBJECT的實(shí)體;同一個(gè)設(shè)備驅(qū)動(dòng)程序?qū)ο笙碌乃性O(shè)備通過NextObject域連接成一個(gè)鏈表(即上述驅(qū)動(dòng)程序設(shè)備對(duì)象的一個(gè)域);AttachedDevice域是針對(duì)“早期”驅(qū)動(dòng)的(Window NT4以前的版本,在以后的版本中也可以正常使用);DriverObject域指向與該設(shè)備相關(guān)的驅(qū)動(dòng)程序?qū)ο?。這里所說的驅(qū)動(dòng)對(duì)象是一種數(shù)據(jù)結(jié)構(gòu), 在DDK 中名為DRIVER_OBJECT。任何驅(qū)動(dòng)程序都對(duì)應(yīng)一個(gè)DRIVER_OBJECT.如何獲得本人所寫的驅(qū)動(dòng)對(duì)應(yīng)的DRIVER_OBJECT 呢?驅(qū)動(dòng)程序的入口函數(shù)為DriverEntry,因此,當(dāng)你
3、寫一個(gè)驅(qū)動(dòng)的開始,你會(huì)寫下如下的代碼:NTSTATUS DriverEntry(IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath )這個(gè)函數(shù)就相當(dāng)與喜歡c 語言的你所常用的main().IN 是無意義的宏,僅僅表明后邊的參數(shù)是一種輸入,而對(duì)應(yīng)的OUT 則代表這個(gè)參數(shù)是一種返回。這里沒有使用引用,因此如果想在參數(shù)中返回結(jié)果,一律傳入指針。DriverObject 就是你所寫的驅(qū)動(dòng)對(duì)應(yīng)的DRIVER_OBJECT, 是系統(tǒng)在加載你的驅(qū)動(dòng)時(shí)候所分配的。RegisteryPath 是專用于你記錄你的驅(qū)動(dòng)相關(guān)參數(shù)的注冊(cè)表路徑。
4、這兩者都由系統(tǒng)分配并通過這兩個(gè)參數(shù)傳遞給你。DriverObject 重要之處,在于它擁有一組函數(shù)指針,稱為dispatch functions.開發(fā)驅(qū)動(dòng)的主要任務(wù)就是親手撰寫這些dispatch functions.當(dāng)系統(tǒng)用到你的驅(qū)動(dòng),會(huì)向你的驅(qū)動(dòng)發(fā)送IRP(這是windows 所有驅(qū)動(dòng)的共同工作方式)。你的任務(wù)是在dispatch function 中處理這些請(qǐng)求。你可以讓irp 失敗,也可以成功返回,也可以修改這些irp,甚至可以自己發(fā)出irp。設(shè)備對(duì)象則是指DEVICE_OBJECT.下邊簡稱DO.但是實(shí)際上每個(gè)irp 都是針對(duì)DO 發(fā)出的。只有針對(duì)由該驅(qū)動(dòng)所生成的DO 的IRP, 才
5、會(huì)發(fā)給該驅(qū)動(dòng)來處理。具體的分發(fā)函數(shù),決定于DO 下的DriverObject 域。當(dāng)一個(gè)應(yīng)用程序打開文件并讀寫文件的時(shí)候,windows 系統(tǒng)將這些請(qǐng)求變成irp 發(fā)送給文件系統(tǒng)驅(qū)動(dòng)。文件系統(tǒng)過濾驅(qū)動(dòng)將可以過濾這些irp.這樣,你就擁有了捕獲和改變文件系統(tǒng)操作的能力。象Fat32,NTFS 這樣的文件系統(tǒng)(File System,簡稱FS),可能生成好幾種設(shè)備。首先文件系統(tǒng)驅(qū)動(dòng)本身往往生成一個(gè)控制設(shè)備(CDO).這個(gè)設(shè)備的主要任務(wù)是修改整個(gè)驅(qū)動(dòng)的內(nèi)部配置。因此一個(gè)Driver 只對(duì)應(yīng)一個(gè)CDO.另一種設(shè)備是被這個(gè)文件系統(tǒng)Mount 的Volume。一個(gè)FS 可能有多個(gè)Volume,也可能一個(gè)都
6、沒有。解釋一下,如果你有C:,D:,E:,F:四個(gè)分區(qū)。C:,D:為NTFS,E:,F:為Fat32.那么E:,F:則是Fat 的兩個(gè)Volume 設(shè)備對(duì)象.實(shí)際上"C:"是該設(shè)備的符號(hào)連接(Symbolic Link)名。而不是真正的設(shè)備名??梢源蜷_Symbolic Links Viewer,能看到:C: DeviceHarddiskVolume1因此該設(shè)備的設(shè)備名為“DeviceHarddiskVolume1”.這里也看出來,文件系統(tǒng)驅(qū)動(dòng)是針對(duì)每個(gè)Volume 來生成一個(gè)DeviceObject,而不是針對(duì)每個(gè)文件的。實(shí)際上對(duì)文件的讀寫的irp,都發(fā)到Volume 設(shè)備
7、對(duì)象上去了。并不會(huì)生成一個(gè)“文件設(shè)備對(duì)象”。掌握了這些概念的話,我們現(xiàn)在用簡單的代碼來生成我們的CDO,作為我們開發(fā)文件系統(tǒng)驅(qū)動(dòng)的第一步牛刀小試。NTSTATUSDriverEntry(IN PDRIVER_OBJECT DriverObject,IN PUNICODE_STRING RegistryPath)/ 定義一個(gè)Unicode 字符串。UNICODE_STRING nameString;RtlInitUnicodeString( &nameString, L"FileSystemFiltersSFilter" );/ 生成控制設(shè)備status = IoCr
8、eateDevice( DriverObject,0, /has no device extension&nameString,FILE_DEVICE_DISK_FILE_SYSTEM,FILE_DEVICE_SECURE_OPEN,FALSE,&gSFilterControlDeviceObject );/ 如果因?yàn)槁窂經(jīng)]找到而生成失敗if (status = STATUS_OBJECT_PATH_NOT_FOUND) / 這是因?yàn)橐恍┑桶姹镜牟僮飨到y(tǒng)沒有FileSystemFilters這個(gè)目錄/ 如果沒有,我們則改變位置,生成到FileSystem下.RtlInitUni
9、codeString( &nameString, L"FileSystemSFilterCDO" );status = IoCreateDevice( DriverObject,0,&nameString,FILE_DEVICE_DISK_FILE_SYSTEM,FILE_DEVICE_SECURE_OPEN,FALSE,&gSFilterControlDeviceObject );/ 成功后,用KdPrint 打印一個(gè)log.if (!NT_SUCCESS( status ) KdPrint( "SFilter!DriverEntry:
10、Error creating control device object "%wZ",status=%08xn", &nameString, status );return status; else if (!NT_SUCCESS( status ) / 失敗也打印一個(gè)。并直接返回錯(cuò)誤KdPrint( "SFilter!DriverEntry: Error creating control device object "%wZ",status=%08xn", &nameString, status );return 2) 用KdPrint()來代替printf 輸出信息。這些信息可以在DbgView 中看到。KdPrint()自身是一個(gè)宏,為了完整傳入?yún)?shù)所以使用了
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 太極沉香活動(dòng)方案
- 地名文化競賽活動(dòng)方案
- 天府新區(qū)植樹節(jié)活動(dòng)方案
- 地產(chǎn)關(guān)懷活動(dòng)方案
- 大班畫畫比賽活動(dòng)方案
- 夏季出門活動(dòng)方案
- 夏天促銷文案活動(dòng)方案
- 大將軍陶瓷宣傳活動(dòng)方案
- 夜市廣場活動(dòng)方案
- 大班社區(qū)菜場活動(dòng)方案
- 人教版七年級(jí)下冊(cè)數(shù)學(xué)全冊(cè)課件
- 全自動(dòng)橡膠注射硫化成型機(jī)操作規(guī)程
- 申報(bào)正高工程師職稱技術(shù)總結(jié)范文
- 比亞迪秦PLUS EV說明書
- 幼兒園中班紅色經(jīng)典故事《抗日英雄王二小》紅色革命教育繪本故事PPT課件【幼兒教案】
- 貝雷法簡介及貝雷三參數(shù)在瀝青混合料配合級(jí)配設(shè)計(jì)中應(yīng)用
- 信用管理師(三級(jí))理論考試題庫(300題)
- 電大《中國現(xiàn)代文學(xué)專題》期末復(fù)習(xí)題及答案
- 投標(biāo)密封條格式大全
- (2023)國庫知識(shí)競賽題庫(含答案)
- 2023年北京理工附中小升初英語分班考試復(fù)習(xí)題
評(píng)論
0/150
提交評(píng)論