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

沒畫完的畫

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

關于 TrueCrypt

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

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

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時,還需要注意區分是系統真實分區發出的IRP,還是由虛擬出來的分區發出的IRP

3、ProcessMainDeviceControlIrp() 中
 case TC_IOCTL_MOUNT_VOLUME:
   Irp->IoStatus.Information = sizeof (MOUNT_STRUCT);
   Irp->IoStatus.Status = MountDevice (DeviceObject, mount);
   DriverMutexRelease ();
判斷由應用程序發出的 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;
}   

虛擬出一個分區的關鍵應該在 (5) 中,等明天再試。

2008.09.03
在昨天的基礎上, 嘗試將創建虛擬設備的部份代碼抽出來
代碼如下:
  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    // 創建虛擬設備
 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 調試得到

SFilter!DriverEntry
SFilter!DriverEntry: Create Driver "?"
SFilter!DriverEntry: Error Creating Control Device Object "?", status=c000003b
問題:
設備創建失敗, 可能是由 ntUnicodeString 非法,
但為何 ntUnicodeString 會變成 ?
經試驗, 將 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));
--------------------------------------------------
輸出結果
SFilter!DriverEntry: Create Driver ntname = "\Device\TrueCryptVolume"
SFilter!DriverEntry: Create Driver ntUnicodeString = "$"
SFilter!DriverEntry: Error Creating Control Device Object "?", status=c000003b

經過 RtlInitUnicodeString (&ntUnicodeString, ntname); 后
ntUnicodeString 變成了 "?" ?
于是查 MSDN RtlInitUnicodeString 相關的信息, 用法似乎沒有錯
修改了一下程序
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));

 

輸出結果如下:
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

接著,藍屏……

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

KdPrint(("TCGetNTNameFromNumber: Create Driver tmp = \"%s\"\n", tmp));   
wcsncat (ntname, tmp, 1);
----------------------------------------------------------------------------------------
結果顯示
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

---
根據代碼的執行結果:
tmp 的值應該是 D: 才對!!!!! 奇怪!!!

問題,
1、KdPrint 在打印 WCHAR[] 與 UNICODE_STRING 時的處理
2、WCHAR[] 與 UNICODE_STRING 的連接又該如何?(如果沒有成功編譯 TrueCrypt,所以無法跟蹤到它里面的值的變化)
--------------------------------------------------------
于是先把創建設備的代碼去掉,先把 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;
 
    // 創建虛擬設備
    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;
}

---
代碼改成了這樣后, 調試依然會藍屏。
 

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.



需要回滾代碼。明天再繼續。



2008.09.04
今天打算先看下應用層與驅動通信的方法
然后再看下由 Bill Gates 說的(做file disk建議看filedisk的源代碼,在http://www.acc.umu.se/~bosse。)
在開始工作之前,先感謝一下 BillGates ,雖然他已經退休了,但居然光臨我的BLOG,
讀 filedisk 的代碼前,想先使用一下它
看了 Readme,安裝 filedisk 的步驟(它居然連 .inf 都省了,直接用.reg 暈!!!! )
1、把 filedisk.sys 拷貝到 %systemroot%\system32\drivers\
2、filedisk.reg 里面設置的驅動加載方面默認是{自動}的,所以不用改了
    產生問題1:
    有了這個  .reg 就相當于 .inf?  .reg 安裝驅動跟 .inf 安裝驅動方法的區別?
    -- 未解決
3、運行 filedisk.reg 然后重啟
4、重啟后, 在cmd 窗體執行命令 
    filedisk /mount 0 c:\test.img 8M e:
5、此時,系統多出一個 e 盤,雙擊提示未格式化,格式化完 E 盤后,就可以像普通磁盤一樣操作了
 
產生問題1: 看了下設備管理器并沒有多出一個設備,那么E盤怎么出來的?
              用 WinObj.exe 也無所發現  (先迷茫一下先!!!)
 
接下來,試下編譯 filedisk sys 的源程序
build filedisk 沒出現問題,生成了 check 的 filedisk.sys
 
然后,試下編譯 filedisk exe 的程序
在 exe 目錄下 nmake /f makefile ,卻出現錯誤提示
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了一下,找到方法
據說 exe 同樣用DDK的環境來編譯
在 filedisk 的 exe 目錄  build -cz
 
果然,編譯通過了生成了 filedisk.exe
 
產生問題1:
filedisk 的 exe 為何不能用 nmake 來編譯?
產生問題2:
ddk 也可以用來編譯 exe 程序?
產生問題3:
如果用 vc 建一個 Win32 Console Application 工程又能否編譯?
-- 試了一下,果然是可以滴!!
 
把自己編譯的 filedisk.sys 和 filedisk.exe 放到虛擬機試下是否正常先.
因為剛剛在前面已經設置了驅動是自動加載的,怕覆蓋 filedisk.sys 后,系統還是會用回原來的 filedisk.sys
于是重啟一下系統先~!
 
產生很奇怪的問題1:
用自己編譯的 exe && sys 運后,可以正常虛擬一個分區出來,但 win 提示不能格式化分區
-- 用原先的 exe 再試一下, 試過后, win 仍然提示不能格式化分區
    于是用回 原先的 sys 再試一下,
    突然間懷疑,是不是 映象文件的問題,因為我用的是
    filedisk /mount 0 c:\test.txt 8M e:
    后綴名是 .txt 
    改成 filedisk /mount 0 c:\test.img 8M e: 后 win 提示格式化分區成功,于是
 
產生很奇怪的問題2:
   filedisk 的映象文件的后綴名如果為 .txt ,會導致 win 不能格式化虛擬出來的分區?
   按道理應該跟映象文件的后綴名無關才是,估計要研究下里面的代碼才清楚了!!!
-- 未解決
 
另外還產生很奇怪的問題3:
   我把映象文件的大小設置 1K, win會提示“無法完成格式化”,難道 win 需要空間存放文件分配表?
   試了一下,映象文件的大小在 3M 左右,win才可以格式化成功,具體值無嘗試
   另一方面,如果 windows 的分區在格式化時,它應該會建一個{文件分配表}之類的東西,
   而這個{文件分配表}的大小應該跟分區的大小有關 (暫無找到相關的資料,未解決)
-- 未解決
 
大概看了下 filedisk.c 的代碼, 里面用的是 
CreateFile + DeviceIoControl 的方法 跟 驅動通信
里面并沒有采用動態加載驅動
問題1:
如何動態加載驅動?
之前在網上看到的資料應該有“SM”之類的API可以動態加載驅動,
這個有時間再研究.

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



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

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

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

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

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

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

Feedback

# re: 關于 TrueCrypt  回復  更多評論   

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

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

# re: 關于 TrueCrypt  回復  更多評論   

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

# re: 關于 TrueCrypt  回復  更多評論   

2008-09-04 16:13 by 沒畫完的畫
發現 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.

所以并不是系統自動銷毀的

# re: 關于 TrueCrypt  回復  更多評論   

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>
            欧美不卡在线| 亚洲欧洲一区二区三区久久| 亚洲一品av免费观看| 欧美日韩一区自拍| 亚洲欧美网站| 午夜免费日韩视频| 激情国产一区| 亚洲人妖在线| 国产精品mv在线观看| 久久精品成人一区二区三区| 久久国产精品99精品国产| 亚洲第一精品久久忘忧草社区| 欧美mv日韩mv国产网站| 欧美激情久久久久久| 亚洲天堂av综合网| 欧美在线地址| 亚洲精品三级| 午夜久久电影网| 亚洲人成在线观看网站高清| 99riav1国产精品视频| 国产手机视频一区二区| 欧美黑人国产人伦爽爽爽| 欧美日韩精品免费看| 欧美专区在线观看一区| 你懂的亚洲视频| 亚洲欧美网站| 快射av在线播放一区| 亚洲自拍三区| 麻豆成人在线| 午夜视频在线观看一区二区| 噜噜噜久久亚洲精品国产品小说| 一区二区三区四区国产精品| 欧美在线三区| 亚洲一区在线看| 欧美大学生性色视频| 欧美一区高清| 欧美日韩综合视频| 欧美黄网免费在线观看| 国产日韩欧美视频| 在线亚洲电影| 亚洲精品午夜精品| 久久九九免费视频| 欧美一区二区视频在线| 欧美日韩精品高清| 亚洲国产91精品在线观看| 国产在线乱码一区二区三区| 一本色道久久88亚洲综合88| 最近中文字幕mv在线一区二区三区四区| 亚洲欧美国产一区二区三区| 日韩视频免费观看高清在线视频| 久久国产综合精品| 欧美中文字幕视频| 国产精品久久777777毛茸茸| 亚洲人成久久| 亚洲精品免费电影| 理论片一区二区在线| 久久在线视频在线| 国内外成人在线视频| 亚洲综合色丁香婷婷六月图片| 日韩一区二区电影网| 欧美v日韩v国产v| 欧美成人69av| 亚洲欧洲久久| 欧美高清视频www夜色资源网| 麻豆国产va免费精品高清在线| 国产一区二区三区日韩| 亚洲欧美国产77777| 性视频1819p久久| 亚洲高清免费| 精品成人在线视频| 欧美伊人精品成人久久综合97| 亚洲欧美日韩国产一区二区三区| 欧美日韩第一区| 日韩视频在线免费| 亚洲欧美日韩另类精品一区二区三区 | 欧美激情一区二区三区在线视频 | 久久久久久综合| 国产婷婷成人久久av免费高清| 午夜久久tv| 欧美大片免费| 日韩午夜免费| 国产精品久久久久免费a∨大胸| 日韩亚洲精品电影| 性欧美精品高清| 国产在线日韩| 欧美大片专区| 亚洲一区成人| 久久久久久欧美| 亚洲精品三级| 国产精品日韩| 老司机精品视频一区二区三区| 亚洲国产毛片完整版| 一区二区三区 在线观看视频| 国产精品久久久久久久久久久久| 亚洲欧美日韩成人高清在线一区| 久久久久久网| 一区二区三区欧美亚洲| 国产日产高清欧美一区二区三区| 久久亚洲综合网| 一区二区日韩伦理片| 久久蜜桃精品| 亚洲视频成人| 91久久精品视频| 欧美亚洲免费在线| 精品999在线观看| 欧美精品成人91久久久久久久| 亚洲午夜免费视频| 欧美成人免费一级人片100| 中国成人亚色综合网站| 激情伊人五月天久久综合| 欧美日韩精品不卡| 久久午夜视频| 亚洲伊人伊色伊影伊综合网| 亚洲电影毛片| 久久亚洲午夜电影| 亚洲欧美一区二区在线观看| 亚洲片在线观看| 国产一级一区二区| 欧美色图天堂网| 欧美二区不卡| 葵司免费一区二区三区四区五区| 亚洲一卡久久| 在线一区二区日韩| 亚洲激情综合| 欧美国产亚洲视频| 亚洲第一色在线| 国产精品第一区| 欧美国产日韩一区二区在线观看| 欧美一区二区三区在| 亚洲综合社区| 一区二区三区欧美成人| 亚洲美女在线一区| 亚洲激情专区| 亚洲国产婷婷综合在线精品| 免费不卡中文字幕视频| 久久久久久久久久久一区| 欧美一区日韩一区| 亚洲欧美国产高清va在线播| 一本久道久久综合狠狠爱| 亚洲日本成人网| 91久久综合| 91久久久久久久久| 91久久国产综合久久91精品网站| 在线观看日韩| 亚洲高清自拍| 亚洲伦理一区| 一个色综合av| 亚洲欧美日韩国产综合精品二区| 一区二区三区国产| 国产精品99久久久久久久女警| aa国产精品| 亚洲伊人网站| 久久精品国产96久久久香蕉| 久久久99精品免费观看不卡| 久久久噜噜噜久久中文字免| 久久美女性网| 欧美刺激性大交免费视频| 亚洲激情中文1区| 夜夜嗨一区二区三区| 亚洲免费视频在线观看| 欧美一级午夜免费电影| 久久久综合香蕉尹人综合网| 蜜桃av一区二区三区| 欧美日韩久久久久久| 国产精品久久久久久久一区探花| 国产精品视频观看| 黄网动漫久久久| 亚洲日本中文字幕区| 亚洲一区二区三区精品视频| 欧美一区二区视频在线观看| 美女主播精品视频一二三四| 亚洲成人中文| 亚洲一区二区三区乱码aⅴ| 久久国产日韩| 欧美经典一区二区| 国产欧美视频一区二区三区| 亚洲成人在线视频播放| 一区二区欧美激情| 久久激五月天综合精品| 亚洲国产日韩在线| 亚洲欧美日韩久久精品| 免费永久网站黄欧美| 国产精品系列在线播放| 91久久精品一区二区三区| 亚洲欧美综合另类中字| 欧美成人综合一区| 亚洲一区二区在线视频| 欧美jizz19性欧美| 国产亚洲欧美在线| 一二三区精品福利视频| 美女露胸一区二区三区| 一区二区三区回区在观看免费视频| 欧美亚洲日本一区| 欧美午夜一区二区| 最新国产成人av网站网址麻豆| 午夜电影亚洲| 亚洲精品一区二区三区四区高清| 久久精品国产视频| 国产精品视频内| 在线亚洲欧美视频|