Microsoft MVP성태의 닷넷 이야기
DDK: 1. Visual Studio 2010 - Device Driver 제작- Hello World 예제 [링크 복사], [링크+제목 복사],
조회: 42219
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 3개 있습니다.)
Visual Studio 2010 - Device Driver 제작- Hello World 예제

친숙한 Visual Studio 개발환경을 떠나지 않고 ^^ "Hello World" 예제를 만들어 볼까요?
저도 밑바닥부터는 "스스로" 알 수는 없으니, 방법을 찾아보았는데 다음의 글이 눈에 띄었습니다. ^^

How to Configure Visual Studio 2008 for Compiling Drivers
; https://www.codeproject.com/Articles/31865/How-to-Configure-Visual-Studio-2008-for-Compiling

정확한 해결 방법이 될 것 같죠? ^^




일단, 기본적인 단계는 위의 글을 따르긴 했는데, Visual Studio 2010이기 때문에 나름대로 변경된 것이 있습니다. (Visual Studio 2008이라면, 위의 글에 나온 순서대로 따라하시면 됩니다.)

또한, x64 빌드를 기준으로 설정이 되었습니다.

1. Visual Studio 2010 설치

2. WDK 설치
; http://www.microsoft.com/downloads/details.aspx?displaylang=en&FamilyID=36a2630f-5d56-43b5-b996-7633f2ec14ff

3. "Win32 Project" 유형의 새 프로젝트를 생성하고,
; Applicaiton type - Windows application
; Additional Options: Empty project

4. 솔루션의 "Configuration Manager"를 통해서 'x64' 플랫폼을 추가

vs2010_dd_sample_1.png

5. "Configuration Properties" / "General"
; Target Extension: .sys

vs2010_dd_sample_2.png

6. "Configuration Properties" / "VC++ Directories"에 DDK의 include, lib, bin 폴더를 추가
; Executable Directories: D:\WinDDK\7600.16385.1\bin;$(ExecutablePath)
; Include Directories: D:\WinDDK\7600.16385.1\inc\ddk;D:\WinDDK\7600.16385.1\inc\api;D:\WinDDK\7600.16385.1\inc\crt
; Library Directories: D:\WinDDK\7600.16385.1\lib\win7\amd64

vs2010_dd_sample_3.png

7. "Configuration Properties"에서 "Configuration" 설정을 "All Configurations"로 바꾼 후,
1. C/C++ - General - Debug Information Format = Program Database (/Zi)
2. C/C++ - Preprocessor - Preprocessor Definitions = _AMD64_
3. C/C++ - Code Generation - Enable C++ Exceptions = No
4. C/C++ - Code Generation - Basic Runtime Checks = Default
5. C/C++ - Code Generation - Buffer Security Check = No (/GS-)
6. C/C++ - Advanced - Calling Convention = __stdcall (/Gz)
7. C/C++ - Advanced - Compile As = Compile as C Code (/TC) [if you are going to use plain C]
8. Linker - General - Enable Incremental Linking = [빈 문자열]
9. Linker - Input - Additional Dependencies = ntoskrnl.lib;hal.lib (상속 받지 않음을 체크)
10. Linker - Input - Ignore All Default Libraries = Yes (/NODEFAULTLIB)
11. Linker - Manifest File - Generate Manifest = No
12. Linker - System - SubSystem = Native (/SUBSYSTEM:NATIVE)
13. Linker - System - Driver = Driver (/DRIVER)
14. Linker - Advanced - Entry Point = DriverEntry
15. Linker - Advanced - Base Address = 0x10000
16-1. Linker - Advanced - Randomized Base Address = [빈 문자열]
16-2. Linker - Advanced - Data Execution Prevention (DEP) = [빈 문자열]

vs2010_dd_sample_4.png

6. 예제 코드 작성으로 마무리

#include <ntddk.h>

VOID DriverUnload( PDRIVER_OBJECT pDriverObject )
{
    DbgPrint("Driver Unload\n" );
}

NTSTATUS DriverEntry(PDRIVER_OBJECT pDriverObject, PUNICODE_STRING pRegistryPath)
{
    DbgPrint("DriverEntry\n");

    pDriverObject->DriverUnload = DriverUnload;

    return STATUS_SUCCESS;
}

7. 빌드!




사실, 코딩을 Visual Studio 2010이라는 편집기를 이용하고 컴파일만 하는 것에 의미가 있을 뿐 "F5 디버깅"이 되는 것은 아니기 때문에 어차피 별도의 배포 스크립트는 만드는 것이 좋습니다. (설령 된다고 해도, Blue Screen이 자신의 개발 PC에서 뜨는 것이 유쾌하지는 않죠. ^^)




[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 4/11/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2011-10-06 12시45분
[홍반장] 자료 잘 보고 갑니다.
항상 퍼가기만 하는데요. 저도 이제는 퍼주는 사람이 되도록 노력 해야겠네요
감사합니다.

[guest]
2015-05-06 11시32분
간단한 리눅스 커널 모듈 예제 및 빌드 방법
; http://kkamagui.tistory.com/882
정성태
2023-01-19 10시38분
Lord Of The Ring0 - Part 1 | Introduction
; https://idov31.github.io/2022/07/14/lord-of-the-ring0-p1.html

Lord Of The Ring0 - Part 2 | A tale of routines, IOCTLs and IRPs
; https://idov31.github.io/2022/08/04/lord-of-the-ring0-p2.html

Lord Of The Ring0 - Part 3 | Sailing to the land of the user (and debugging the ship)
; https://idov31.github.io/2022/10/30/lord-of-the-ring0-p3.html
정성태

... 61  62  63  64  65  66  67  68  69  70  71  72  73  [74]  75  ...
NoWriterDateCnt.TitleFile(s)
12117정성태1/15/202020282디버깅 기술: 159. C# - 디버깅 중인 프로세스를 강제로 다른 디버거에서 연결하는 방법파일 다운로드1
12116정성태1/15/202021019디버깅 기술: 158. Visual Studio로 디버깅 시 sos.dll 확장 명령어를 (비롯한 windbg의 다양한 기능을) 수행하는 방법
12115정성태1/14/202021250디버깅 기술: 157. C# - PEB.ProcessHeap을 이용해 디버깅 중인지 확인하는 방법파일 다운로드1
12114정성태1/13/202022643디버깅 기술: 156. C# - PDB 파일로부터 심벌(Symbol) 및 타입(Type) 정보 열거 [1]파일 다운로드3
12113정성태1/12/202022932오류 유형: 590. Visual C++ 빌드 오류 - fatal error LNK1104: cannot open file 'atls.lib' [1]
12112정성태1/12/202017606오류 유형: 589. PowerShell - 원격 Invoke-Command 실행 시 "WinRM cannot complete the operation" 오류 발생
12111정성태1/12/202021478디버깅 기술: 155. C# - KernelMemoryIO 드라이버를 이용해 실행 프로그램을 숨기는 방법(DKOM: Direct Kernel Object Modification) [16]파일 다운로드1
12110정성태1/11/202021543디버깅 기술: 154. Patch Guard로 인해 블루 스크린(BSOD)가 발생하는 사례 [5]파일 다운로드1
12109정성태1/10/202017767오류 유형: 588. Driver 프로젝트 빌드 오류 - Inf2Cat error -2: "Inf2Cat, signability test failed."
12108정성태1/10/202018753오류 유형: 587. Kernel Driver 시작 시 127(The specified procedure could not be found.) 오류 메시지 발생
12107정성태1/10/202020194.NET Framework: 877. C# - 프로세스의 모든 핸들을 열람 - 두 번째 이야기
12106정성태1/8/202020461VC++: 136. C++ - OSR Driver Loader와 같은 Legacy 커널 드라이버 설치 프로그램 제작 [1]
12105정성태1/8/202018990디버깅 기술: 153. C# - PEB를 조작해 로드된 DLL을 숨기는 방법
12104정성태1/7/202021008DDK: 9. 커널 메모리를 읽고 쓰는 NT Legacy driver와 C# 클라이언트 프로그램 [4]
12103정성태1/7/202024118DDK: 8. Visual Studio 2019 + WDK Legacy Driver 제작- Hello World 예제 [1]파일 다운로드2
12102정성태1/6/202019685디버깅 기술: 152. User 권한(Ring 3)의 프로그램에서 _ETHREAD 주소(및 커널 메모리를 읽을 수 있다면 _EPROCESS 주소) 구하는 방법
12101정성태1/5/202020796.NET Framework: 876. C# - PEB(Process Environment Block)를 통해 로드된 모듈 목록 열람
12100정성태1/3/202018063.NET Framework: 875. .NET 3.5 이하에서 IntPtr.Add 사용
12099정성태1/3/202021005디버깅 기술: 151. Windows 10 - Process Explorer로 확인한 Handle 정보를 windbg에서 조회 [1]
12098정성태1/2/202020745.NET Framework: 874. C# - 커널 구조체의 Offset 값을 하드 코딩하지 않고 사용하는 방법 [3]
12097정성태1/2/202018692디버깅 기술: 150. windbg - Wow64, x86, x64에서의 커널 구조체(예: TEB) 구조체 확인
12096정성태12/30/201920757디버깅 기술: 149. C# - DbgEng.dll을 이용한 간단한 디버거 제작 [1]
12095정성태12/27/201923115VC++: 135. C++ - string_view의 동작 방식
12094정성태12/26/201920933.NET Framework: 873. C# - 코드를 통해 PDB 심벌 파일 다운로드 방법
12093정성태12/26/201920431.NET Framework: 872. C# - 로딩된 Native DLL의 export 함수 목록 출력파일 다운로드1
12092정성태12/25/201918580디버깅 기술: 148. cdb.exe를 이용해 (ntdll.dll 등에 정의된) 커널 구조체 출력하는 방법
... 61  62  63  64  65  66  67  68  69  70  71  72  73  [74]  75  ...