青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

沒畫完的畫

喂馬 劈柴 BBQ~
posts - 37, comments - 55, trackbacks - 0, articles - 0
  C++博客 ::  :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

關(guān)于 TrueCrypt

Posted on 2008-09-04 11:47 沒畫完的畫 閱讀(3598) 評論(4)  編輯 收藏 引用 所屬分類: Windows Driver
實現(xiàn)功能:
將用戶指定的某個文件A 虛擬成一個分區(qū)B, 用戶在分區(qū)上B操作的數(shù)據(jù)會保存到文件A上

需要解決的問題:
1、如何虛擬出一個新的設(shè)備(分區(qū))?
2、如何將訪問這個分區(qū)的操作轉(zhuǎn)化為讀取某個文件的操作?

2008.09.02
 大概看了 TrueCrypt 源代碼

1.
DriverEntry() 中
 for (i = 0; i <= IRP_MJ_MAXIMUM_FUNCTION; ++i)
 {
  DriverObject->MajorFunction[i] = TCDispatchQueueIRP;
 }

2、TCDispatchQueueIRP 處理 IRP 代碼
 case IRP_MJ_FLUSH_BUFFERS:
 case IRP_MJ_READ:
 case IRP_MJ_WRITE:
 case IRP_MJ_DEVICE_CONTROL:
  if (Extension->bRootDevice)
  {
   if (irpSp->MajorFunction == IRP_MJ_DEVICE_CONTROL)
    return ProcessMainDeviceControlIrp (DeviceObject, Extension, Irp);
   break;
  }
在處理IRP時,還需要注意區(qū)分是系統(tǒng)真實分區(qū)發(fā)出的IRP,還是由虛擬出來的分區(qū)發(fā)出的IRP

3、ProcessMainDeviceControlIrp() 中
 case TC_IOCTL_MOUNT_VOLUME:
   Irp->IoStatus.Information = sizeof (MOUNT_STRUCT);
   Irp->IoStatus.Status = MountDevice (DeviceObject, mount);
   DriverMutexRelease ();
判斷由應(yīng)用程序發(fā)出的 CTL_CODE

4、MountDevice() 中
 ntStatus = TCCreateDeviceObject (DeviceObject->DriverObject, &NewDeviceObject,
  mount);
 if (!NT_SUCCESS (ntStatus))
 {
  Dump ("Mount CREATE DEVICE ERROR, ntStatus = 0x%08x\n", ntStatus);
  return ntStatus;
 }

5、TCCreateDeviceObject() 中
NTSTATUS
TCCreateDeviceObject (PDRIVER_OBJECT DriverObject,
         PDEVICE_OBJECT * ppDeviceObject,
         MOUNT_STRUCT * mount)
{
 UNICODE_STRING Win32NameString, ntUnicodeString;
 WCHAR dosname[32], ntname[32];
 PEXTENSION Extension;
 NTSTATUS ntStatus;
 ULONG devChars = 0;
 Dump ("TCCreateDeviceObject BEGIN\n");
 ASSERT (KeGetCurrentIrql() == PASSIVE_LEVEL);
 TCGetDosNameFromNumber (dosname, mount->nDosDriveNo);
 TCGetNTNameFromNumber (ntname, mount->nDosDriveNo);
 RtlInitUnicodeString (&ntUnicodeString, ntname);
 RtlInitUnicodeString (&Win32NameString, dosname);
 devChars = FILE_DEVICE_SECURE_OPEN;
 devChars |= mount->bMountReadOnly ? FILE_READ_ONLY_DEVICE : 0;
 devChars |= mount->bMountRemovable ? FILE_REMOVABLE_MEDIA : 0;
 Dump ("Creating device nt=%ls dos=%ls\n", ntname, dosname);
 ntStatus = IoCreateDevice (
       DriverObject,   /* Our Driver Object */
       sizeof (EXTENSION), /* Size of state information */
       &ntUnicodeString,  /* Device name "\Device\Name" */
       FILE_DEVICE_DISK,  /* Device type */
       devChars,    /* Device characteristics */
       FALSE,    /* Exclusive device */
       ppDeviceObject);  /* Returned ptr to Device Object */
 if (!NT_SUCCESS (ntStatus))
 {
  Dump ("TCCreateDeviceObject NTSTATUS = 0x%08x END\n", ntStatus);
  return ntStatus;/* Failed to create DeviceObject */
 }
 /* Initialize device object and extension. */
 (*ppDeviceObject)->Flags |= DO_DIRECT_IO;
 (*ppDeviceObject)->StackSize += 2;  // Reduce occurrence of NO_MORE_IRP_STACK_LOCATIONS bug check caused by buggy drivers
 /* Setup the device extension */
 Extension = (PEXTENSION) (*ppDeviceObject)->DeviceExtension;
 memset (Extension, 0, sizeof (EXTENSION));
 Extension->IsVolumeDevice = TRUE;
 Extension->lMagicNumber = 0xabfeacde;
 Extension->nDosDriveNo = mount->nDosDriveNo;
 Extension->bRemovable = mount->bMountRemovable;
 KeInitializeEvent (&Extension->keCreateEvent, SynchronizationEvent, FALSE);
 KeInitializeSemaphore (&Extension->RequestSemaphore, 0L, MAXLONG);
 KeInitializeSpinLock (&Extension->ListSpinLock);
 InitializeListHead (&Extension->ListEntry);
 Dump ("TCCreateDeviceObject STATUS_SUCCESS END\n");
 return STATUS_SUCCESS;
}   

虛擬出一個分區(qū)的關(guān)鍵應(yīng)該在 (5) 中,等明天再試。

2008.09.03
在昨天的基礎(chǔ)上, 嘗試將創(chuàng)建虛擬設(shè)備的部份代碼抽出來
代碼如下:
  1#ifdef __cplusplus
  2extern "C"
  3{
  4#endif
  5#include <ntddk.h>
  6#ifdef __cplusplus
  7}
  8#endif
  9#ifdef NT4_DRIVER
 10#define DRIVER_STR WIDE
 11#else
 12#define DRIVER_STR
 13#endif
 14#define NT_MOUNT_PREFIX DRIVER_STR("\\Device\\TrueCryptVolume")
 15PDEVICE_OBJECT gSFilterDriverObject = NULL;
 16/**//* This structure is allocated for non-root devices! WARNING: bRootDevice
 17   must be the first member of the structure! */
 18typedef struct EXTENSION
 19{
 20} EXTENSION, *PEXTENSION;
 21typedef struct _DEVICE_EXTENSION
 22{
 23PDEVICE_OBJECT fdo;
 24PDEVICE_OBJECT NextStackDevice;
 25UNICODE_STRING ifSymLinkName;
 26}DEVICE_EXTENSION, *PDEVICE_EXTENSION;
 27extern "C" NTSTATUS AddDevice(IN PDRIVER_OBJECT DriverObject,
 28IN PDEVICE_OBJECT PhysicalDeviceObject)
 29{
 30  
 31  NTSTATUS status;
 32  PDEVICE_OBJECT fdo;
 33  
 34  status = IoCreateDevice(
 35  DriverObject,
 36  sizeof(DEVICE_EXTENSION),
 37  NULL,
 38  FILE_DEVICE_DISK, 
 39  0, 
 40  FALSE, 
 41  &fdo); 
 42  
 43  if( !NT_SUCCESS(status))
 44     return status;
 45  
 46  PDEVICE_EXTENSION dx = (PDEVICE_EXTENSION)fdo->DeviceExtension;
 47  dx->fdo = fdo;
 48  
 49  dx->NextStackDevice = IoAttachDeviceToDeviceStack(fdo, PhysicalDeviceObject);
 50  fdo->Flags |= DO_BUFFERED_IO | DO_POWER_PAGABLE;
 51  fdo->Flags &= ~DO_DEVICE_INITIALIZING;
 52  
 53  return STATUS_SUCCESS;
 54}
 55extern "C" void
 56TCGetNTNameFromNumber (LPWSTR ntname, int nDriveNo)
 57{
 58 WCHAR tmp[3] =
 59 {0, ':', 0};
 60 int j = nDriveNo + (WCHAR) 'A';
 61 tmp[0] = (short) j;
 62 wcscpy (ntname, (LPWSTR) NT_MOUNT_PREFIX);
 63 wcsncat (ntname, tmp, 1);
 64}
 65extern "C" NTSTATUS
 66DriverEntry (IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath)
 67{
 68    NTSTATUS ntStatus;   
 69    WCHAR dosname[32], ntname[32]; 
 70    ULONG devChars = 0;
 71    // 定義一個 Unicode 字符串
 72    UNICODE_STRING ntUnicodeString;
 73    //RtlInitUnicodeString(&nameString, L"\\FileSystem\\Filters\\SFilter");
 74    DriverObject->DriverExtension->AddDevice = AddDevice;
 75    KdPrint(("SFilter!DriverEntry\n"));
 76    
 77    TCGetNTNameFromNumber (ntname, 3);
 78    RtlInitUnicodeString (&ntUnicodeString, ntname);
 79    KdPrint(("SFilter!DriverEntry: Create Driver \"%wZ\"\n", &ntUnicodeString));
 80   devChars = FILE_DEVICE_SECURE_OPEN;
 81 
 82   PDEVICE_OBJECT pDeviceObject = NULL;
 83 
 84    // 創(chuàng)建虛擬設(shè)備
 85    ntStatus = IoCreateDevice (
 86       DriverObject,   /**//* Our Driver Object */
 87       sizeof (EXTENSION), /**//* Size of state information */
 88       &ntUnicodeString,  /**//* Device name "\Device\Name" */
 89       FILE_DEVICE_DISK,  /**//* Device type */
 90       devChars,    /**//* Device characteristics */
 91       FALSE,    /**//* Exclusive device */
 92       &pDeviceObject);  /**//* Returned ptr to Device Object */
 93                            
 94    if ( !NT_SUCCESS( ntStatus ) )
 95    {
 96        KdPrint(("SFilter!DriverEntry: Error Creating Control Device Object \"%wZ\", status=%08x\n", &ntUnicodeString, ntStatus));
 97    }
 98    else
 99    {
100        KdPrint(("SFilter!DriverEntry: Success Creating Control Device Object \"%wZ\", status=%08x\n", &ntUnicodeString, ntStatus));
101    }
102    
103    return ntStatus;
104}
105

使用 windgb 調(diào)試得到

SFilter!DriverEntry
SFilter!DriverEntry: Create Driver "?"
SFilter!DriverEntry: Error Creating Control Device Object "?", status=c000003b
問題:
設(shè)備創(chuàng)建失敗, 可能是由 ntUnicodeString 非法,
但為何 ntUnicodeString 會變成 ?
經(jīng)試驗, 將 KdPrint 的 \"%wZ\", 改為 %s

 KdPrint(("SFilter!DriverEntry\n"));
    TCGetNTNameFromNumber (ntname, 3);
   
    KdPrint(("SFilter!DriverEntry: Create Driver ntname = \"%s\"\n", &ntname));
   
    RtlInitUnicodeString (&ntUnicodeString, ntname);
KdPrint(("SFilter!DriverEntry: Create Driver ntUnicodeString = \"%s\"\n", &ntUnicodeString));
--------------------------------------------------
輸出結(jié)果
SFilter!DriverEntry: Create Driver ntname = "\Device\TrueCryptVolume"
SFilter!DriverEntry: Create Driver ntUnicodeString = "$"
SFilter!DriverEntry: Error Creating Control Device Object "?", status=c000003b

經(jīng)過 RtlInitUnicodeString (&ntUnicodeString, ntname); 后
ntUnicodeString 變成了 "?" ?
于是查 MSDN RtlInitUnicodeString 相關(guān)的信息, 用法似乎沒有錯
修改了一下程序
extern "C" void
TCGetNTNameFromNumber (LPWSTR ntname, int nDriveNo)
{
 WCHAR tmp[3] = {0, ':', 0};
 int j = nDriveNo + (WCHAR) 'A';
 tmp[0] = (short) j;
 wcscpy (ntname, (LPWSTR) NT_MOUNT_PREFIX);
 
 KdPrint(("TCGetNTNameFromNumber: Create Driver ntname = \"%d\"\n", nDriveNo)); 
 KdPrint(("TCGetNTNameFromNumber: Create Driver ntname = \"%s\"\n", ntname));
     
 wcsncat (ntname, tmp, 1);
 
 KdPrint(("TCGetNTNameFromNumber: Create Driver ntname = \"%s\"\n", ntname));
}

extern "C" NTSTATUS
DriverEntry (IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath)
{
    NTSTATUS ntStatus;   
    WCHAR dosname[32], ntname[32]; 
    ULONG devChars = 0;

    // 定義一個 Unicode 字符串
    UNICODE_STRING ntUnicodeString;
    //RtlInitUnicodeString(&nameString, L"\\FileSystem\\Filters\\SFilter");

    DriverObject->DriverExtension->AddDevice = AddDevice;

    KdPrint(("SFilter!DriverEntry\n"));

    
    TCGetNTNameFromNumber (ntname, 3);
    
    KdPrint(("SFilter!DriverEntry: Create Driver ntname = \"%s\"\n", &ntname));
    
    RtlInitUnicodeString (&ntUnicodeString, ntname);

    KdPrint(("SFilter!DriverEntry: Create Driver ntUnicodeString = \"%s\"\n", &ntUnicodeString));

 

輸出結(jié)果如下:
SFilter!DriverEntry
TCGetNTNameFromNumber: Create Driver ntname = "3"
TCGetNTNameFromNumber: Create Driver ntname = "\Device\TrueCryptVolume"
TCGetNTNameFromNumber: Create Driver ntname = "\Device\TrueCryptVolume"
SFilter!DriverEntry: Create Driver ntname = "\Device\TrueCryptVolume"
SFilter!DriverEntry: Create Driver ntUnicodeString = "H"
SFilter!DriverEntry: Error Creating Control Device Object "?", status=c000003b

接著,藍(lán)屏……

表示很懷疑,把  tmp 的值也打印出來

KdPrint(("TCGetNTNameFromNumber: Create Driver tmp = \"%s\"\n", tmp));   
wcsncat (ntname, tmp, 1);
----------------------------------------------------------------------------------------
結(jié)果顯示
SFilter!DriverEntry
TCGetNTNameFromNumber: Create Driver ntname = "3"
TCGetNTNameFromNumber: Create Driver ntname = "\Device\TrueCryptVolume"
TCGetNTNameFromNumber: Create Driver tmp = "D"
TCGetNTNameFromNumber: Create Driver ntname = "\Device\TrueCryptVolume"
SFilter!DriverEntry: Create Driver ntname = "\Device\TrueCryptVolume"
SFilter!DriverEntry: Create Driver ntUnicodeString = "H"
SFilter!DriverEntry: Error Creating Control Device Object "?", status=c000003b

---
根據(jù)代碼的執(zhí)行結(jié)果:
tmp 的值應(yīng)該是 D: 才對!!!!! 奇怪!!!

問題,
1、KdPrint 在打印 WCHAR[] 與 UNICODE_STRING 時的處理
2、WCHAR[] 與 UNICODE_STRING 的連接又該如何?(如果沒有成功編譯 TrueCrypt,所以無法跟蹤到它里面的值的變化)
--------------------------------------------------------
于是先把創(chuàng)建設(shè)備的代碼去掉,先把 ntUnicodeString  正確顯示出來

#ifdef __cplusplus
extern "C"
{
#endif
#include <ntddk.h>
#ifdef __cplusplus
}
#endif
#ifdef NT4_DRIVER
#define DRIVER_STR WIDE
#else
#define DRIVER_STR
#endif
#define NT_MOUNT_PREFIX DRIVER_STR("\\Device\\TrueCryptVolume")
PDEVICE_OBJECT gSFilterDriverObject = NULL;
/**//* This structure is allocated for non-root devices! WARNING: bRootDevice
   must be the first member of the structure! */
typedef struct EXTENSION
{
} EXTENSION, *PEXTENSION;
typedef struct _DEVICE_EXTENSION
{
PDEVICE_OBJECT fdo;
PDEVICE_OBJECT NextStackDevice;
UNICODE_STRING ifSymLinkName;
}DEVICE_EXTENSION, *PDEVICE_EXTENSION;
extern "C" NTSTATUS AddDevice(IN PDRIVER_OBJECT DriverObject,
IN PDEVICE_OBJECT PhysicalDeviceObject)
{
  
  NTSTATUS status;
  PDEVICE_OBJECT fdo;
  
  status = IoCreateDevice(
  DriverObject,
  sizeof(DEVICE_EXTENSION),
  NULL,
  FILE_DEVICE_DISK, 
  0, 
  FALSE, 
  &fdo); 
  
  if( !NT_SUCCESS(status))
     return status;
  
  PDEVICE_EXTENSION dx = (PDEVICE_EXTENSION)fdo->DeviceExtension;
  dx->fdo = fdo;
  
  dx->NextStackDevice = IoAttachDeviceToDeviceStack(fdo, PhysicalDeviceObject);
  fdo->Flags |= DO_BUFFERED_IO | DO_POWER_PAGABLE;
  fdo->Flags &= ~DO_DEVICE_INITIALIZING;
  
  return STATUS_SUCCESS;
}
extern "C" void
TCGetNTNameFromNumber (LPWSTR ntname, int nDriveNo)
{
 WCHAR tmp[3] = {0, ':', 0};
 int j = nDriveNo + (WCHAR) 'A';
 tmp[0] = (short) j;
 wcscpy (ntname, (LPWSTR) NT_MOUNT_PREFIX);
 
 KdPrint(("TCGetNTNameFromNumber: Create Driver ntname = \"%d\"\n", nDriveNo)); 
 KdPrint(("TCGetNTNameFromNumber: Create Driver ntname = \"%s\"\n", ntname));
 
  KdPrint(("TCGetNTNameFromNumber: Create Driver tmp = \"%s\"\n", tmp));    
  wcsncat (ntname, tmp, 1);
  
 KdPrint(("TCGetNTNameFromNumber: Create Driver ntname = \"%s\"\n", ntname));
}
extern "C" NTSTATUS
DriverEntry (IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath)
{
    NTSTATUS ntStatus = STATUS_SUCCESS;   
    WCHAR dosname[32], ntname[32]; 
    ULONG devChars = 0;
    // 定義一個 Unicode 字符串
    UNICODE_STRING ntUnicodeString;
    //RtlInitUnicodeString(&nameString, L"\\FileSystem\\Filters\\SFilter");
    DriverObject->DriverExtension->AddDevice = AddDevice;
    KdPrint(("SFilter!DriverEntry\n"));
    
    TCGetNTNameFromNumber (ntname, 3);
    
    KdPrint(("SFilter!DriverEntry: Create Driver ntname = \"%s\"\n", &ntname));
    
    RtlInitUnicodeString (&ntUnicodeString, ntname);
    KdPrint(("SFilter!DriverEntry: Create Driver ntUnicodeString = \"%s\"\n", &ntUnicodeString));
/**//*
   devChars = FILE_DEVICE_SECURE_OPEN;
 
   PDEVICE_OBJECT pDeviceObject = NULL;
 
    // 創(chuàng)建虛擬設(shè)備
    ntStatus = IoCreateDevice (
       DriverObject,   /* Our Driver Object * /
       sizeof (EXTENSION), /* Size of state information * /
       &ntUnicodeString,  /* Device name "\Device\Name" * /
       FILE_DEVICE_DISK,  /* Device type * /
       devChars,    /* Device characteristics * /
       FALSE,    /* Exclusive device * /
       &pDeviceObject);  /* Returned ptr to Device Object * /
                            
    if ( !NT_SUCCESS( ntStatus ) )
    {
        KdPrint(("SFilter!DriverEntry: Error Creating Control Device Object \"%wZ\", status=%08x\n", &ntUnicodeString, ntStatus));
    }
    else
    {
        KdPrint(("SFilter!DriverEntry: Success Creating Control Device Object \"%wZ\", status=%08x\n", &ntUnicodeString, ntStatus));
    }*/
    
    return ntStatus;
}

---
代碼改成了這樣后, 調(diào)試依然會藍(lán)屏。
 

SFilter!DriverEntry
TCGetNTNameFromNumber: Create Driver ntname = "3"
TCGetNTNameFromNumber: Create Driver ntname = "\Device\TrueCryptVolume"
TCGetNTNameFromNumber: Create Driver tmp = "D"
TCGetNTNameFromNumber: Create Driver ntname = "\Device\TrueCryptVolume"
SFilter!DriverEntry: Create Driver ntname = "\Device\TrueCryptVolume"
SFilter!DriverEntry: Create Driver ntUnicodeString = "H"

*** Fatal System Error: 0x0000007e
                       (0xC0000005,0x46656D61,0xF9EA2770,0xF9EA246C)

Break instruction exception - code 80000003 (first chance)

A fatal system error has occurred.
Debugger entered on first try; Bugcheck callbacks have not been invoked.

A fatal system error has occurred.



需要回滾代碼。明天再繼續(xù)。



2008.09.04
今天打算先看下應(yīng)用層與驅(qū)動通信的方法
然后再看下由 Bill Gates 說的(做file disk建議看filedisk的源代碼,在http://www.acc.umu.se/~bosse。)
在開始工作之前,先感謝一下 BillGates ,雖然他已經(jīng)退休了,但居然光臨我的BLOG,
讀 filedisk 的代碼前,想先使用一下它
看了 Readme,安裝 filedisk 的步驟(它居然連 .inf 都省了,直接用.reg 暈!!!! )
1、把 filedisk.sys 拷貝到 %systemroot%\system32\drivers\
2、filedisk.reg 里面設(shè)置的驅(qū)動加載方面默認(rèn)是{自動}的,所以不用改了
    產(chǎn)生問題1:
    有了這個  .reg 就相當(dāng)于 .inf?  .reg 安裝驅(qū)動跟 .inf 安裝驅(qū)動方法的區(qū)別?
    -- 未解決
3、運行 filedisk.reg 然后重啟
4、重啟后, 在cmd 窗體執(zhí)行命令 
    filedisk /mount 0 c:\test.img 8M e:
5、此時,系統(tǒng)多出一個 e 盤,雙擊提示未格式化,格式化完 E 盤后,就可以像普通磁盤一樣操作了
 
產(chǎn)生問題1: 看了下設(shè)備管理器并沒有多出一個設(shè)備,那么E盤怎么出來的?
              用 WinObj.exe 也無所發(fā)現(xiàn)  (先迷茫一下先!!!)
 
接下來,試下編譯 filedisk sys 的源程序
build filedisk 沒出現(xiàn)問題,生成了 check 的 filedisk.sys
 
然后,試下編譯 filedisk exe 的程序
在 exe 目錄下 nmake /f makefile ,卻出現(xiàn)錯誤提示
Microsoft (R) Program Maintenance Utility   Version 6.00.9782.0
Copyright (C) Microsoft Corp 1988-1998. All rights reserved.

makefile(7) : fatal error U1052: file '\makefile.def' not found
Stop.
 
google了一下,找到方法
據(jù)說 exe 同樣用DDK的環(huán)境來編譯
在 filedisk 的 exe 目錄  build -cz
 
果然,編譯通過了生成了 filedisk.exe
 
產(chǎn)生問題1:
filedisk 的 exe 為何不能用 nmake 來編譯?
產(chǎn)生問題2:
ddk 也可以用來編譯 exe 程序?
產(chǎn)生問題3:
如果用 vc 建一個 Win32 Console Application 工程又能否編譯?
-- 試了一下,果然是可以滴!!
 
把自己編譯的 filedisk.sys 和 filedisk.exe 放到虛擬機(jī)試下是否正常先.
因為剛剛在前面已經(jīng)設(shè)置了驅(qū)動是自動加載的,怕覆蓋 filedisk.sys 后,系統(tǒng)還是會用回原來的 filedisk.sys
于是重啟一下系統(tǒng)先~!
 
產(chǎn)生很奇怪的問題1:
用自己編譯的 exe && sys 運后,可以正常虛擬一個分區(qū)出來,但 win 提示不能格式化分區(qū)
-- 用原先的 exe 再試一下, 試過后, win 仍然提示不能格式化分區(qū)
    于是用回 原先的 sys 再試一下,
    突然間懷疑,是不是 映象文件的問題,因為我用的是
    filedisk /mount 0 c:\test.txt 8M e:
    后綴名是 .txt 
    改成 filedisk /mount 0 c:\test.img 8M e: 后 win 提示格式化分區(qū)成功,于是
 
產(chǎn)生很奇怪的問題2:
   filedisk 的映象文件的后綴名如果為 .txt ,會導(dǎo)致 win 不能格式化虛擬出來的分區(qū)?
   按道理應(yīng)該跟映象文件的后綴名無關(guān)才是,估計要研究下里面的代碼才清楚了!!!
-- 未解決
 
另外還產(chǎn)生很奇怪的問題3:
   我把映象文件的大小設(shè)置 1K, win會提示“無法完成格式化”,難道 win 需要空間存放文件分配表?
   試了一下,映象文件的大小在 3M 左右,win才可以格式化成功,具體值無嘗試
   另一方面,如果 windows 的分區(qū)在格式化時,它應(yīng)該會建一個{文件分配表}之類的東西,
   而這個{文件分配表}的大小應(yīng)該跟分區(qū)的大小有關(guān) (暫無找到相關(guān)的資料,未解決)
-- 未解決
 
大概看了下 filedisk.c 的代碼, 里面用的是 
CreateFile + DeviceIoControl 的方法 跟 驅(qū)動通信
里面并沒有采用動態(tài)加載驅(qū)動
問題1:
如何動態(tài)加載驅(qū)動?
之前在網(wǎng)上看到的資料應(yīng)該有“SM”之類的API可以動態(tài)加載驅(qū)動,
這個有時間再研究.

一個上午的時間就這樣被花光了!!!!!



問題1:
運行 TrueCrypt\Driver\BuildDriver.cmd ,不能編譯驅(qū)動,提示 "BuildDriver.cmd: error: Cannot copy target."
沒有時間看 ReadMe. 未解決

問題2:
將 TrueCrypt.sln 用工具轉(zhuǎn)換為 TrueCrypt.dsw ,打開后無論編譯哪一個工程,都會提示很多錯誤信息
未解決

問題3:
IoCreateDevice 最后一個參數(shù) Returned ptr to Device Object, 是否需要為其分配空間
-- Answered by bill Bill Gates : Device Object對象由系統(tǒng)分配,系統(tǒng)會在這個對象reference count為0的時候自動銷毀。

安裝 filedisk 后
產(chǎn)生問題1: 看了下設(shè)備管理器并沒有多出一個設(shè)備,那么E盤怎么出來的?
              用 WinObj.exe 也無所發(fā)現(xiàn)  (先迷茫一下先!!!)

產(chǎn)生問題1:
filedisk 的 exe 為何不能用 nmake 來編譯?
產(chǎn)生問題2:
ddk 也可以用來編譯 exe 程序?
產(chǎn)生問題3:
如果用 vc 建一個 Win32 Console Application 工程又能否編譯?
-- 試了一下,果然是可以滴!!

產(chǎn)生很奇怪的問題1:
用自己編譯的 exe && sys 運后,可以正常虛擬一個分區(qū)出來,但 win 提示不能格式化分區(qū)
-- 用原先的 exe 再試一下, 試過后, win 仍然提示不能格式化分區(qū)
    于是用回 原先的 sys 再試一下,
    突然間懷疑,是不是 映象文件的問題,因為我用的是
    filedisk /mount 0 c:\test.txt 8M e:
    后綴名是 .txt 
    改成 filedisk /mount 0 c:\test.img 8M e: 后 win 提示格式化分區(qū)成功,于是
 
產(chǎn)生很奇怪的問題2:
   filedisk 的映象文件的后綴名如果為 .txt ,會導(dǎo)致 win 不能格式化虛擬出來的分區(qū)?
   按道理應(yīng)該跟映象文件的后綴名無關(guān)才是,估計要研究下里面的代碼才清楚了!!!
-- 未解決
 
另外還產(chǎn)生很奇怪的問題3:
   我把映象文件的大小設(shè)置 1K, win會提示“無法完成格式化”,難道 win 需要空間存放文件分配表?
   試了一下,映象文件的大小在 3M 左右,win才可以格式化成功,具體值無嘗試
   另一方面,如果 windows 的分區(qū)在格式化時,它應(yīng)該會建一個{文件分配表}之類的東西,
   而這個{文件分配表}的大小應(yīng)該跟分區(qū)的大小有關(guān) (暫無找到相關(guān)的資料,未解決)
-- 未解決

Feedback

# re: 關(guān)于 TrueCrypt  回復(fù)  更多評論   

2008-09-03 22:18 by Bill Gates
3. Device Object對象由系統(tǒng)分配,系統(tǒng)會在這個對象reference count為0的時候自動銷毀。

做file disk建議看filedisk的源代碼,在http://www.acc.umu.se/~bosse。TrueCrypt有很多加密解密部分,跟file disk無關(guān)。

# re: 關(guān)于 TrueCrypt  回復(fù)  更多評論   

2008-09-04 08:45 by 沒畫完的畫
Thx Bill

# re: 關(guān)于 TrueCrypt  回復(fù)  更多評論   

2008-09-04 16:13 by 沒畫完的畫
發(fā)現(xiàn) Bill Gates 說錯了

MSDN 中說

IoCreateDevice creates a device object and returns a pointer to the object. The caller is responsible for deleting the object when it is no longer needed by calling IoDeleteDevice.

所以并不是系統(tǒng)自動銷毀的

# re: 關(guān)于 TrueCrypt  回復(fù)  更多評論   

2008-09-08 16:26 by Bill Gates
IoDeleteDevice 只是把reference count - 1,到0的時候才刪除
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产目拍亚洲精品99久久精品| 久久精品视频在线| 欧美视频在线观看| 亚洲欧美在线一区二区| 老司机午夜精品| 亚洲精品日韩欧美| 国产精品99一区| 欧美一区二区三区视频免费| 欧美福利精品| 亚洲综合不卡| 狠狠入ady亚洲精品| 欧美高清视频一区二区| 一区二区三区欧美在线| 久久只精品国产| 亚洲小说欧美另类婷婷| 国产一区二区三区久久精品| 女仆av观看一区| 亚洲女同精品视频| 亚洲国产精品悠悠久久琪琪| 亚洲深夜福利| **网站欧美大片在线观看| 欧美日韩在线观看视频| 久久久久久黄| 亚洲私人影吧| 亚洲黄色影片| 老司机成人网| 久久综合国产精品台湾中文娱乐网| 亚洲黄色性网站| 久久亚洲影院| 午夜精品久久久久久久久久久久| 亚洲国产精品电影| 国产欧美视频一区二区| 欧美喷潮久久久xxxxx| 欧美伊久线香蕉线新在线| 亚洲日本在线视频观看| 久热精品视频在线观看一区| 亚洲欧美另类在线| 99精品视频免费观看视频| 伊人久久婷婷色综合98网| 国产精品久久国产三级国电话系列| 久久综合图片| 久久不射中文字幕| 亚洲无毛电影| 日韩视频专区| 亚洲国产清纯| 欧美国产日韩xxxxx| 久久福利资源站| 性久久久久久久久| 亚洲欧美影院| 亚洲愉拍自拍另类高清精品| 日韩西西人体444www| 亚洲国产小视频| 亚洲高清不卡av| 激情91久久| 国产日韩欧美亚洲一区| 国产精品在线看| 国产精品免费观看视频| 欧美午夜精品理论片a级按摩| 欧美高清视频一区二区三区在线观看| 久久久久久久综合色一本| 久久国产66| 久久精品国产91精品亚洲| 性色av香蕉一区二区| 性欧美暴力猛交69hd| 亚洲欧美综合| 欧美一区二区三区成人| 亚洲综合首页| 西瓜成人精品人成网站| 亚洲影院在线| 欧美亚洲综合网| 久久久精品国产99久久精品芒果| 久久精品国产免费观看| 久久久久久久久久久久久久一区| 久久精品国产精品亚洲精品| 久久精品在线视频| 老司机67194精品线观看| 免费亚洲网站| 欧美欧美全黄| 国产精品多人| 国产一区二区三区四区| 一区二区三区在线免费播放| 亚洲国产精品一区二区三区| 亚洲精品一区在线观看| 中国女人久久久| 欧美在线免费观看视频| 久久中文精品| 亚洲精品日韩久久| 亚洲欧美一级二级三级| 久久精品一本| 欧美精品亚洲二区| 国产精品午夜在线观看| 国产亚洲欧美日韩一区二区| 在线观看91精品国产麻豆| 亚洲精品男同| 欧美在线视频一区二区| 女人色偷偷aa久久天堂| 亚洲美女诱惑| 欧美综合77777色婷婷| 欧美gay视频| 国产精品欧美久久久久无广告| 国产三区精品| 亚洲最快最全在线视频| 久久激情视频久久| 亚洲日本免费电影| 午夜老司机精品| 蜜桃av噜噜一区二区三区| 欧美午夜电影在线观看| 精品不卡一区| 亚洲一区网站| 欧美高清视频在线| 亚洲欧美激情精品一区二区| 久久漫画官网| 国产精品高潮呻吟久久av无限| 黄网站免费久久| 亚洲欧美不卡| 亚洲国产一区在线| 欧美在线3区| 欧美日韩一区二区在线观看视频| 国产综合色产在线精品| 亚洲图片激情小说| 欧美激情一区在线观看| 欧美一二三区在线观看| 欧美日韩精品二区第二页| 在线电影国产精品| 欧美中文字幕精品| 一本久久a久久免费精品不卡| 久久米奇亚洲| av不卡在线| 免费亚洲一区二区| 激情欧美日韩| 久久精品在这里| 亚洲在线免费视频| 欧美日韩午夜剧场| 亚洲精品免费观看| 亚洲福利国产| 久久天堂精品| 久久视频精品在线| 欧美黑人国产人伦爽爽爽| 国产欧美精品一区二区色综合 | 久久久久国产精品一区| 亚洲自拍另类| 99re视频这里只有精品| 亚洲国产激情| 在线成人国产| 亚洲成人在线视频播放| 国内精品久久久久久久影视蜜臀 | 欧美激情在线狂野欧美精品| 久久免费视频网| 久久频这里精品99香蕉| 久久久爽爽爽美女图片| 久久米奇亚洲| 乱中年女人伦av一区二区| 女同一区二区| 欧美色欧美亚洲另类七区| 欧美婷婷久久| 国产精品视频1区| 国产在线精品成人一区二区三区| 欧美影院成人| 亚洲伊人一本大道中文字幕| 欧美11—12娇小xxxx| 欧美大片第1页| 亚洲国产福利在线| 亚洲国产一区二区精品专区| 99国产精品视频免费观看| 亚洲一区二区视频在线观看| 欧美亚洲尤物久久| 免费一级欧美在线大片| 欧美三级免费| 伊大人香蕉综合8在线视| 亚洲美女av在线播放| 亚洲一区二区三区四区视频| 久久精品最新地址| 亚洲国产欧美另类丝袜| 亚洲午夜电影在线观看| 久久久www| 欧美性久久久| 伊人久久亚洲影院| 亚洲一二三区视频在线观看| 久久久国产一区二区三区| 亚洲人午夜精品免费| 欧美一区二区精美| 欧美日韩国产精品一卡| 国外成人在线视频| 亚洲美女中出| 国产精品99久久久久久宅男 | 伊人春色精品| 在线视频免费在线观看一区二区| 欧美一站二站| 亚洲精品一区二区三区在线观看 | 一区二区久久| 美女视频网站黄色亚洲| 国产精品高清在线| 91久久在线视频| 久久久噜噜噜久久| 亚洲在线免费观看| 欧美日韩综合在线免费观看| 亚洲国产成人久久综合| 欧美伊人精品成人久久综合97 | 久久久精品一区| 一本一本大道香蕉久在线精品|