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

沒畫完的畫

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

關于 TrueCrypt

Posted on 2008-09-04 11:47 沒畫完的畫 閱讀(3605) 評論(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>
            欧美日韩国产高清| 欧美大香线蕉线伊人久久国产精品| 国产婷婷精品| 欧美fxxxxxx另类| 久久久免费精品| 国产精品毛片大码女人| 狠狠色丁香婷婷综合久久片| 一区二区三区欧美激情| 久久人人精品| 一本色道久久综合亚洲精品不卡| 欧美v日韩v国产v| 国产午夜精品视频免费不卡69堂| 亚洲精品乱码久久久久久蜜桃91| 麻豆国产va免费精品高清在线| 亚洲免费网站| 亚洲人成网站999久久久综合| 欧美影院精品一区| 国产精品久久久久久超碰| 国内外成人免费激情在线视频| 亚洲一区在线免费| 亚洲乱码视频| 欧美日韩在线看| 欧美亚洲免费在线| 亚洲一区二区少妇| 亚洲激情精品| 一区二区免费看| 欧美福利视频| 亚洲午夜精品福利| 国产精品v日韩精品| 亚洲麻豆国产自偷在线| 亚洲精品日韩在线观看| 欧美高清在线观看| 在线日本成人| 欧美理论片在线观看| 亚洲图片自拍偷拍| 久热re这里精品视频在线6| 在线观看亚洲视频啊啊啊啊| 久久精品理论片| 久久亚洲国产精品一区二区 | 亚洲福利电影| 亚洲欧美日韩国产一区| 亚洲欧洲三级| 欧美极品一区| 亚洲欧美经典视频| 亚洲自拍另类| 国产主播在线一区| 91久久中文| 久久久久综合一区二区三区| 久久天天躁狠狠躁夜夜av| 免费日本视频一区| 一区二区日韩| 久久精品女人的天堂av| 一区二区在线视频播放| 欧美大秀在线观看| 国产精品中文在线| 久久久久久久97| 欧美激情小视频| 午夜视频一区二区| 久久精品免费| 香蕉久久久久久久av网站| 欧美影院在线播放| 国产日韩欧美在线播放不卡| 亚洲国产天堂久久综合| 国产精品日韩高清| 国产亚洲免费的视频看| 欧美xart系列在线观看| 欧美日本在线播放| 久久人人爽人人爽爽久久| 免费久久99精品国产自在现线| 99精品欧美一区二区三区综合在线 | 亚洲欧美偷拍卡通变态| 国产精品羞羞答答| 国产精品有限公司| 亚洲高清自拍| 欧美一区二区三区久久精品| 亚洲夫妻自拍| 韩国v欧美v日本v亚洲v| 亚洲欧美日产图| 久久三级福利| 一区二区三区国产在线| 亚洲国产网站| 亚洲第一区中文99精品| 一本色道久久综合狠狠躁篇怎么玩| 136国产福利精品导航网址| 一区二区三区日韩在线观看| 欧美日韩亚洲一区二区三区在线观看| 久久精品电影| 蜜臀91精品一区二区三区| 亚洲欧美日韩在线高清直播| 91久久精品美女| 国产一区香蕉久久| 欧美亚洲视频一区二区| 中文av字幕一区| 亚洲精品女av网站| 久久久国产亚洲精品| 欧美片网站免费| 亚洲国产日韩综合一区| 国产一区二区三区观看| 亚洲少妇自拍| 亚洲欧美日韩国产成人| 久久不见久久见免费视频1| 亚洲精品1234| 国产精品私人影院| 日韩一级黄色av| 国内偷自视频区视频综合| 久久国产精品久久久久久| 亚洲影院在线| 国产精品一区在线观看| 亚洲婷婷免费| 午夜精品久久久久久久99水蜜桃| 国产精品久久久| 一区二区三区久久久| 亚洲国产aⅴ天堂久久| 男人的天堂亚洲在线| 女仆av观看一区| 亚洲人成人99网站| 免费成人高清视频| 亚洲电影下载| 欧美午夜无遮挡| 在线视频一区观看| 久久精品视频在线观看| 欧美电影电视剧在线观看| 亚洲国产精品传媒在线观看| 亚洲激情在线观看视频免费| 欧美 亚欧 日韩视频在线| 亚洲精品视频在线观看免费| 免费观看久久久4p| 亚洲黄色天堂| 久久福利资源站| 国产午夜亚洲精品不卡| 狠狠久久亚洲欧美| 欧美伊久线香蕉线新在线| 久久精品综合网| 亚洲精品免费在线观看| 欧美日韩国产a| 亚洲欧美日韩天堂| 久热精品在线| 亚洲欧洲日本国产| 国产精品手机在线| 久久国产精品99国产精| 亚洲精品久久久久久下一站 | 久久视频在线视频| 亚洲第一黄色| 亚洲最新合集| 午夜在线观看免费一区| 久久精品99无色码中文字幕| 激情综合网激情| 欧美激情在线播放| 亚洲小说欧美另类社区| 国产亚洲一区二区三区在线观看| 久久蜜臀精品av| 亚洲精品乱码久久久久久久久| 尤物精品国产第一福利三区| 欧美国产精品v| 亚洲综合日韩| 日韩视频在线播放| 米奇777在线欧美播放| 亚洲欧美综合一区| 亚洲欧美在线aaa| 在线看日韩欧美| 国产视频精品免费播放| 欧美精品亚洲一区二区在线播放| 国产日本欧美一区二区三区在线| 亚洲国产精品第一区二区三区| 亚洲综合色激情五月| 亚洲精品国久久99热| 国产日韩欧美麻豆| 欧美精品1区| 欧美承认网站| 久久精品在这里| 欧美一激情一区二区三区| 亚洲电影欧美电影有声小说| 欧美中文字幕久久| 亚洲免费在线视频一区 二区| 激情六月婷婷综合| 亚洲欧洲在线一区| 免费日韩成人| 黄色亚洲在线| 永久域名在线精品| 国产欧美日韩精品丝袜高跟鞋| 国产精品视频精品| 欧美性猛片xxxx免费看久爱| 欧美成年人视频| 欧美美女bbbb| 欧美大片91| 欧美三级网址| 欧美色另类天堂2015| 久久成人国产| 老鸭窝毛片一区二区三区| 欧美一级在线播放| 欧美一区二区视频在线| 国产一区二区无遮挡| 欧美日韩国语| 欧美精品一区三区| 久热精品在线视频| 久久亚洲精品中文字幕冲田杏梨| 欧美在线免费| 欧美高清视频免费观看| 欧美成人精品| 99www免费人成精品|