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

沒畫完的畫

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

關(guān)于 TrueCrypt

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

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

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時(shí),還需要注意區(qū)分是系統(tǒng)真實(shí)分區(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;
}   

虛擬出一個(gè)分區(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    // 定義一個(gè) 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 會(huì)變成 ?
經(jīng)試驗(yàn), 將 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)的信息, 用法似乎沒有錯(cuò)
修改了一下程序
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;

    // 定義一個(gè) 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: 才對(duì)!!!!! 奇怪!!!

問題,
1、KdPrint 在打印 WCHAR[] 與 UNICODE_STRING 時(shí)的處理
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;
    // 定義一個(gè) 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)試依然會(huì)藍(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ū)動(dòng)通信的方法
然后再看下由 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ū)動(dòng)加載方面默認(rèn)是{自動(dòng)}的,所以不用改了
    產(chǎn)生問題1:
    有了這個(gè)  .reg 就相當(dāng)于 .inf?  .reg 安裝驅(qū)動(dòng)跟 .inf 安裝驅(qū)動(dòng)方法的區(qū)別?
    -- 未解決
3、運(yùn)行 filedisk.reg 然后重啟
4、重啟后, 在cmd 窗體執(zhí)行命令 
    filedisk /mount 0 c:\test.img 8M e:
5、此時(shí),系統(tǒng)多出一個(gè) e 盤,雙擊提示未格式化,格式化完 E 盤后,就可以像普通磁盤一樣操作了
 
產(chǎn)生問題1: 看了下設(shè)備管理器并沒有多出一個(gè)設(shè)備,那么E盤怎么出來的?
              用 WinObj.exe 也無所發(fā)現(xiàn)  (先迷茫一下先!!!)
 
接下來,試下編譯 filedisk sys 的源程序
build filedisk 沒出現(xiàn)問題,生成了 check 的 filedisk.sys
 
然后,試下編譯 filedisk exe 的程序
在 exe 目錄下 nmake /f makefile ,卻出現(xiàn)錯(cuò)誤提示
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 建一個(gè) Win32 Console Application 工程又能否編譯?
-- 試了一下,果然是可以滴!!
 
把自己編譯的 filedisk.sys 和 filedisk.exe 放到虛擬機(jī)試下是否正常先.
因?yàn)閯倓傇谇懊嬉呀?jīng)設(shè)置了驅(qū)動(dòng)是自動(dòng)加載的,怕覆蓋 filedisk.sys 后,系統(tǒng)還是會(huì)用回原來的 filedisk.sys
于是重啟一下系統(tǒng)先~!
 
產(chǎn)生很奇怪的問題1:
用自己編譯的 exe && sys 運(yùn)后,可以正常虛擬一個(gè)分區(qū)出來,但 win 提示不能格式化分區(qū)
-- 用原先的 exe 再試一下, 試過后, win 仍然提示不能格式化分區(qū)
    于是用回 原先的 sys 再試一下,
    突然間懷疑,是不是 映象文件的問題,因?yàn)槲矣玫氖?br>    filedisk /mount 0 c:\test.txt 8M e:
    后綴名是 .txt 
    改成 filedisk /mount 0 c:\test.img 8M e: 后 win 提示格式化分區(qū)成功,于是
 
產(chǎn)生很奇怪的問題2:
   filedisk 的映象文件的后綴名如果為 .txt ,會(huì)導(dǎo)致 win 不能格式化虛擬出來的分區(qū)?
   按道理應(yīng)該跟映象文件的后綴名無關(guān)才是,估計(jì)要研究下里面的代碼才清楚了!!!
-- 未解決
 
另外還產(chǎn)生很奇怪的問題3:
   我把映象文件的大小設(shè)置 1K, win會(huì)提示“無法完成格式化”,難道 win 需要空間存放文件分配表?
   試了一下,映象文件的大小在 3M 左右,win才可以格式化成功,具體值無嘗試
   另一方面,如果 windows 的分區(qū)在格式化時(shí),它應(yīng)該會(huì)建一個(gè){文件分配表}之類的東西,
   而這個(gè){文件分配表}的大小應(yīng)該跟分區(qū)的大小有關(guān) (暫無找到相關(guān)的資料,未解決)
-- 未解決
 
大概看了下 filedisk.c 的代碼, 里面用的是 
CreateFile + DeviceIoControl 的方法 跟 驅(qū)動(dòng)通信
里面并沒有采用動(dòng)態(tài)加載驅(qū)動(dòng)
問題1:
如何動(dòng)態(tài)加載驅(qū)動(dòng)?
之前在網(wǎng)上看到的資料應(yīng)該有“SM”之類的API可以動(dòng)態(tài)加載驅(qū)動(dòng),
這個(gè)有時(shí)間再研究.

一個(gè)上午的時(shí)間就這樣被花光了!!!!!



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

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

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

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

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

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

Feedback

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

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

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

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

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

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

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

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)自動(dòng)銷毀的

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

2008-09-08 16:26 by Bill Gates
IoDeleteDevice 只是把reference count - 1,到0的時(shí)候才刪除
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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视频在线观看一区三区| 欧美视频日韩视频在线观看| 美女图片一区二区| 国产伦精品免费视频| 亚洲精品中文字| 亚洲狼人综合| 女人色偷偷aa久久天堂| 欧美成年人网| 亚洲福利小视频| 老司机一区二区| 欧美成人黄色小视频| 狠狠色综合网| 久久久99久久精品女同性| 久久国产欧美精品| 国产亚洲一本大道中文在线| 亚洲欧美bt| 欧美一级夜夜爽| 国产无一区二区| 久久av在线看| 欧美高清在线精品一区| 亚洲经典自拍| 欧美区一区二区三区| 亚洲理论在线| 亚洲在线成人精品| 国产精品综合久久久| 亚洲中字黄色| 久久天天躁狠狠躁夜夜爽蜜月| 亚洲欧美日韩在线一区| 亚洲午夜视频| 国产欧美一区二区色老头| 西瓜成人精品人成网站| 久久综合久久美利坚合众国| 亚洲国产高清一区二区三区| 免费成人在线观看视频| 亚洲精品日韩在线| 亚洲欧美日本国产有色| 国产在线播精品第三| 久久香蕉国产线看观看网| 亚洲国产精品传媒在线观看| 一区二区三区国产| 国产精品午夜电影| 久久频这里精品99香蕉| 亚洲经典在线| 久久国产加勒比精品无码| 亚洲第一黄色| 国产精品久久久久一区二区| 久久成人18免费网站| 亚洲国产经典视频| 亚洲一区三区视频在线观看 | 久久久激情视频| 一区在线免费观看| 欧美日本一区二区视频在线观看| 欧美在线视频播放| 亚洲国产精品综合| 国产精品久久久久久久久久久久久| 欧美不卡视频| 亚洲欧美日韩国产成人| 激情欧美一区二区| 欧美视频日韩视频| 麻豆精品视频在线观看| 亚洲一区二区三区四区五区午夜| 亚洲久久一区| 国产亚洲欧洲997久久综合| 欧美丰满高潮xxxx喷水动漫| 亚洲欧美影音先锋| 亚洲精选久久| 欧美国产欧美亚洲国产日韩mv天天看完整 | 亚洲男人av电影| 你懂的国产精品永久在线| 亚洲素人在线| 亚洲精品久久久久久一区二区 | 香蕉视频成人在线观看| 亚洲高清av在线| 久久久精品tv| 午夜伦欧美伦电影理论片| 亚洲国产日韩一区| 国产亚洲一区二区精品| 国产精品毛片va一区二区三区 | 另类酷文…触手系列精品集v1小说| 国产精品久久久久一区二区三区共 | 欧美中文字幕在线观看| 99riav国产精品| 尤物在线观看一区| 国产亚洲欧美日韩美女| 国产精品国产亚洲精品看不卡15 | 亚洲新中文字幕| 亚洲精品日韩欧美| 亚洲福利专区| 亚洲第一精品在线| 伊人一区二区三区久久精品| 国产色爱av资源综合区| 国产精品天天摸av网| 欧美四级剧情无删版影片| 欧美日韩国产欧美日美国产精品| 一区二区三区久久精品| 欧美黄色免费| 亚洲电影免费观看高清| 欧美va亚洲va香蕉在线| 蜜臀久久99精品久久久画质超高清| 91久久在线观看| 亚洲欧洲免费视频| 日韩视频一区| 亚洲精品自在在线观看| 亚洲欧洲一区二区三区久久| 91久久夜色精品国产九色| 亚洲精品在线看| 一区二区毛片| 午夜久久tv| 久久久欧美一区二区| 久久亚洲欧洲| 亚洲国产精品久久人人爱蜜臀| 亚洲男女自偷自拍| 欧美一区1区三区3区公司| 久久本道综合色狠狠五月| 久久久久亚洲综合| 欧美成人免费va影院高清| 欧美激情一二区| 亚洲理论在线观看| 亚洲女人av| 久久综合九色综合久99| 欧美精品在线观看| 国产精品免费观看视频| 国产亚洲精品激情久久| 在线观看成人av| 在线亚洲一区观看| 久久成人资源| 欧美国产视频一区二区| 99视频超级精品| 欧美专区亚洲专区| 欧美好吊妞视频| 国产精品午夜国产小视频| 亚洲第一黄色网| 亚洲欧美精品| 欧美国产日韩一区二区在线观看| 性色av一区二区三区在线观看| 亚洲国产精品福利| 亚洲在线视频观看| 久久精品国产精品亚洲综合| 亚洲国产精品成人综合| 午夜精品久久久久影视| 欧美成人免费va影院高清| 国产精品乱码久久久久久| 亚洲国产91精品在线观看| 亚洲欧美精品在线| 欧美成人三级在线| 亚洲欧美日韩国产另类专区| 免费精品视频| 国产一区二区三区久久久久久久久 | 欧美日韩精品是欧美日韩精品| 欧美中文字幕在线| 欧美日韩在线直播| 国语自产偷拍精品视频偷 | 亚洲精品一线二线三线无人区| 国产有码在线一区二区视频| 亚洲国产成人av好男人在线观看| 在线观看视频亚洲| 午夜宅男久久久| 日韩亚洲欧美一区| 久久久久成人网| 国产欧美一区二区三区另类精品 | 久久精品99国产精品| 亚洲欧洲在线免费| 久久久久9999亚洲精品| 国产精品一区二区在线观看不卡| 欧美午夜三级| 99热在线精品观看| 欧美成人xxx| 久久久久在线观看| 国产日韩欧美精品一区| 亚洲视频在线二区| 亚洲久久视频| 欧美区在线播放| 夜夜夜精品看看| 亚洲精品乱码久久久久久日本蜜臀| 日韩一级大片在线| 欧美精品一区二区三区很污很色的 | 一区二区电影免费在线观看| 欧美国产日韩视频| 麻豆av一区二区三区久久| 狠狠色丁香婷婷综合影院| 亚洲欧美一区二区精品久久久| 久久久久国产一区二区三区| 制服诱惑一区二区| 国产精品美女在线观看| 国产精品99久久久久久久vr| 亚洲免费观看高清完整版在线观看熊 | 中文av字幕一区| 欧美亚一区二区| 亚洲在线免费| 亚洲欧美日韩中文视频| 国产乱码精品1区2区3区| 亚洲欧美激情四射在线日| 亚洲素人在线| 国产一区在线看| 欧美成人精品一区二区| 欧美/亚洲一区| aⅴ色国产欧美| 亚洲永久精品大片|