Windows 讀取BIOS資訊

來源:互聯網
上載者:User
原始碼說明:

大家都知道,windows接管了對實體記憶體的直接存取,而bios資訊存在實體記憶體
的f000:0000處,關鍵就是如何讀取實體記憶體。
查閱了msdn的文章後,發現以下有幾個函數和實體記憶體訪問有關:
NTSTATUS ZwOpenSection(OUT PHANDLE SectionHandle, IN ACCESS_MASK DesiredAccess,IN POBJECT_ATTRIBUTES ObjectAttributes);
NTSTATUS ZwMapViewOfSection(IN HANDLE SectionHandle,
IN HANDLE ProcessHandle,
IN OUT PVOID *BaseAddress,
IN ULONG ZeroBits,
IN ULONG CommitSize,
IN OUT PLARGE_INTEGER SectionOffset OPTIONAL,
IN OUT PSIZE_T ViewSize,
IN SECTION_INHERIT InheritDisposition,
IN ULONG AllocationType,
IN ULONG Protect
);
NTSTATUS ZwUnmapViewOfSection(IN HANDLE ProcessHandle,IN PVOID BaseAddress);

用到的結構定義如下

typedef struct _UNICODE_STRING {
USHORT Length;//長度
USHORT MaximumLength;//最大長度
PWSTR Buffer;//緩衝指標,訪問實體記憶體時,此處指向UNICODE字串"/device/physicalmemory"
} UNICODE_STRING,*PUNICODE_STRING;

typedef struct _OBJECT_ATTRIBUTES {
ULONG Length;//長度 18h
HANDLE RootDirectory;// 00000000
PUNICODE_STRING ObjectName;//指向對象名的指標
ULONG Attributes;//對象屬性00000040h
PVOID SecurityDescriptor; // Points to type SECURITY_DESCRIPTOR,0
PVOID SecurityQualityOfService; // Points to type SECURITY_QUALITY_OF_SERVICE,0
} OBJECT_ATTRIBUTES;
typedef OBJECT_ATTRIBUTES *POBJECT_ATTRIBUTES;

函數說明
第一個函數ZwOpenSection用來開啟section,第一個參數是指向HANDLE變數的指標,第二個是訪問參數,第三個是指向OBJECT_ATTRIBUTES的指標
第二個函數ZwMapViewOfSection用來建立實體記憶體和當前進程的一段實體記憶體的聯絡,參數很多,一會在常式裡再詳細解釋
第三個函數ZwUnmapViewOfSection用來斷開實體記憶體和當前進程中的映射斷開聯絡,第一個參數是進程控制代碼,必須掉用第二個函數時一樣,第二
個是當前進程中映射的基址,由ZwMapViewOfSection返回

這三個函數都在ntdll.dll中,msdn裡的協助說這幾個函數用在驅動編製上。
常式如下

//結構定義
typedef struct _UNICODE_STRING {
USHORT Length;//長度
USHORT MaximumLength;//最大長度
PWSTR Buffer;//緩衝指標
} UNICODE_STRING,*PUNICODE_STRING;

typedef struct _OBJECT_ATTRIBUTES {
ULONG Length;//長度 18h
HANDLE RootDirectory;// 00000000
PUNICODE_STRING ObjectName;//指向對象名的指標
ULONG Attributes;//對象屬性00000040h
PVOID SecurityDescriptor; // Points to type SECURITY_DESCRIPTOR,0
PVOID SecurityQualityOfService; // Points to type SECURITY_QUALITY_OF_SERVICE,0
} OBJECT_ATTRIBUTES;
typedef OBJECT_ATTRIBUTES *POBJECT_ATTRIBUTES;

//函數指標變數類型生命
typedef DWORD (__stdcall *ZWOS)(PHANDLE,ACCESS_MASK,POBJECT_ATTRIBUTES);
typedef DWORD (__stdcall *ZWMV)(HANDLE,HANDLE,PVOID,ULONG,ULONG,PLARGE_INTEGER,PSIZE_T,DWORD,ULONG,ULONG);
typedef DWORD (__stdcall *ZWUMV)(HANDLE,PVOID);
//以上在程式開始定義全域變數處定義

//以下在程式的主函數裡
//變數聲明
UNICODE_STRING struniph;
OBJECT_ATTRIBUTES obj_ar;
ZWOS ZWopenS;
ZWMV ZWmapV;
ZWUMV ZWunmapV;
HANDLE hSection;
DWORD ba;
LARGE_INTEGER so;
SIZE_T ssize;
so.LowPart=0x000f0000;//實體記憶體的基址,就是f000:0000
so.HighPart=0x00000000;
ssize=0xffff;
wchar_t strPH[30]=L"//device//physicalmemory";
//變數初始化
ba=0;//聯絡後的基址將在這裡返回
struniph.Buffer=strPH;
struniph.Length=0x2c;//注意大小是按位元組算
struniph.MaximumLength =0x2e;//也是位元組
obj_ar.Attributes =64;//屬性
obj_ar.Length =24;//OBJECT_ATTRIBUTES類型的長度
obj_ar.ObjectName=&struniph;//指向對象的指標
obj_ar.RootDirectory=0;
obj_ar.SecurityDescriptor=0;
obj_ar.SecurityQualityOfService =0;
//讀入ntdll.dll,得到函數地址
hinstLib = LoadLibrary("ntdll.dll");
ZWopenS=(ZWOS)GetProcAddress(hinstLib,"ZwOpenSection");
ZWmapV=(ZWMV)GetProcAddress(hinstLib,"ZwMapViewOfSection");
ZWunmapV=(ZWUMV)GetProcAddress(hinstLib,"ZwUnmapViewOfSection");
//調用函數,對實體記憶體進行映射
ZWopenS(&hSection,4,&obj_ar);
ZWmapV(
(HANDLE)hSection, //開啟Section時得到的控制代碼
(HANDLE)0xffffffff, //將要映射進程的控制代碼,
&ba, //映射的基址
0, //沒怎麼看明白,設為0就好了
0xffff, //分配的大小
&so, //實體記憶體的地址
&ssize, //指向讀取記憶體塊大小的指標
1, //子進程的可繼承性設定
0, //配置類型
2 //保護類型
);
//執行後會在當前進程的空間開闢一段64k的空間,並把f000:0000到f000:ffff處的內容映射到這裡
//映射的基址由ba返回,如果映射不在有用,應該用ZwUnmapViewOfSection斷開映射 。

 

以上程式,我能通過,最後在bios.mem中查看時,卻發現是看不懂的亂碼。請高手幫我解決上面問題點在哪。上文摘自

http://www.chinaitpower.com

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.