템플릿을 기반으로 KMDF(유니버설 Windows 드라이버) 작성

이 항목에서는 KMDF(Kernel-Mode Driver Framework)를 사용하여 유니버설 Windows 드라이버를 작성하는 방법을 설명합니다. Microsoft Visual Studio 템플릿으로 시작한 다음, 별도의 컴퓨터에 드라이버를 배포하고 설치합니다.

계속하기 전에 WDK(Windows 드라이버 키트) 다운로드에 나열된 설치 단계를 따라야 합니다.

WDK를 설치할 때 Windows용 디버깅 도구가 포함됩니다.

드라이버 만들기 및 빌드

  1. Microsoft Visual Studio를 엽니다. 파일 메뉴에서 새 > 프로젝트를 선택합니다.

  2. 새 프로젝트 만들기 대화 상자의 왼쪽 드롭다운에서 C++를 선택하고, 가운데 드롭다운에서 Windows를 선택하고, 오른쪽 드롭다운에서 드라이버를 선택합니다.

  3. 프로젝트 형식 목록에서 KMDF(커널 모드 드라이버) 를 선택합니다. 다음을 선택합니다.

    선택한 커널 모드 드라이버를 보여 주는 새 프로젝트 대화 상자의 스크린샷

  4. 새 프로젝트 구성 대화 상자의 프로젝트 이름 필드에 "KmdfDriver"를 입력합니다.

    참고

    새 KMDF 또는 UMDF 드라이버를 만들 때 32자 이하의 드라이버 이름을 선택해야 합니다. 이 길이 제한은 wdfglobals.h에 정의되어 있습니다.  

  5. 위치 필드에 새 프로젝트를 만들 디렉터리를 입력합니다.

  6. 솔루션 및 프로젝트를 동일한 디렉터리에 배치를 선택하고 만들기를 선택합니다.

    프로젝트 구성 대화 상자의 스크린샷

    Visual Studio는 하나의 프로젝트와 솔루션을 만듭니다. 솔루션 탐색기 창에서 해당 항목을 볼 수 있습니다. (솔루션 탐색기 창이 표시되지 않으면 보기 메뉴에서 솔루션 탐색기 선택합니다. 솔루션에는 KmdfDriver라는 드라이버 프로젝트가 있습니다. 드라이버 소스 코드를 보려면 원본 파일에서 파일을 엽니다. Driver.c 및 Device.c는 시작하기에 좋은 장소입니다.

    드라이버 프로젝트의 파일을 보여 주는 솔루션 탐색기의 스크린샷

  7. 솔루션 탐색기 창에서 KmdfDriver를 길게 누르거나 마우스 오른쪽 단추로 클릭하고 속성을 선택합니다. 구성 속성 > 드라이버 설정 > 일반으로 이동하고 대상 플랫폼의 기본값은 유니버설입니다.

  8. 드라이버를 빌드하려면 빌드 메뉴에서 솔루션 빌드를 선택합니다. Microsoft Visual Studio는 출력 창에 빌드 진행률을 표시합니다. 출력 창이 표시되지 않으면 보기 메뉴에서 출력을 선택합니다.

    빌드 출력에 다음이 포함되어 있는지 확인합니다.

    >    Driver is 'Universal'.
    

    솔루션이 성공적으로 빌드되었는지 확인하면 Visual Studio를 닫을 수 있습니다.

  9. 빌드된 드라이버를 보려면 파일 탐색기 KmdfDriver 폴더로 이동한 다음 x64\Debug\KmdfDriver로 이동합니다. 디렉터리에는 다음 파일이 포함됩니다.

    • KmdfDriver.sys -- 커널 모드 드라이버 파일
    • KmdfDriver.inf - 드라이버를 설치할 때 Windows에서 사용하는 정보 파일입니다.

드라이버 배포

일반적으로 드라이버를 테스트하고 디버그할 때 디버거와 드라이버는 별도의 컴퓨터에서 실행됩니다. 디버거를 실행하는 컴퓨터를 호스트 컴퓨터라고 하며 드라이버를 실행하는 컴퓨터를 대상 컴퓨터라고 합니다. 대상 컴퓨터를 테스트 컴퓨터라고도 합니다. 드라이버 디버깅에 대한 자세한 내용은 Windows용 디버깅 도구를 참조하세요.

지금까지 Visual Studio를 사용하여 호스트 컴퓨터에서 드라이버를 빌드했습니다. 이제 대상 컴퓨터를 구성해야 합니다.

  1. 드라이버 배포 및 테스트를 위한 컴퓨터 프로비전(WDK 10)의 지침을 따릅니다.

    네트워크 케이블을 사용하여 대상 컴퓨터를 자동으로 프로비전하는 단계를 수행하면 포트 및 키를 기록해 둡니다. 디버깅 단계의 뒷부분에서 사용합니다. 이 예제에서는 포트로 50000 을 사용하고 1.2.3.4 를 키로 사용합니다.

    실제 드라이버 디버깅 시나리오에서는 KDNET 생성 키를 사용하는 것이 좋습니다. KDNET을 사용하여 임의 키를 생성하는 방법에 대한 자세한 내용은 디버그 드라이버 - 단계별 랩(Sysvad 커널 모드) 항목을 참조하세요.

  2. 호스트 컴퓨터에서 Visual Studio에서 솔루션을 엽니다. KmdfDriver 폴더에서 솔루션 파일 KmdfDriver.sln 두 번 클릭할 수 있습니다.

  3. 솔루션 탐색기 창에서 KmdfDriver 프로젝트를 길게 누르거나 마우스 오른쪽 단추로 클릭하고 속성을 선택합니다.

  4. KmdfDriver 패키지 속성 페이지 창의 왼쪽 창에서 구성 속성 > 드라이버 설치 > 배포로 이동합니다.

  5. 배포 전에 이전 드라이버 버전 제거를 선택합니다.

  6. 원격 컴퓨터 이름에 대해 테스트 및 디버깅을 위해 구성한 컴퓨터의 이름을 선택합니다. 이 연습에서는 MyTestComputer라는 컴퓨터를 사용합니다.

  7. 하드웨어 ID 드라이버 업데이트를 선택하고 드라이버의 하드웨어 ID를 입력합니다. 이 연습에서 하드웨어 ID는 Root\KmdfDriver입니다. 확인을 선택합니다.

    선택한 배포 드라이버 설치를 보여 주는 kmdfdriver 패키지 속성 페이지 창의 스크린샷

    참고

    이 연습에서는 하드웨어 ID가 실제 하드웨어 부분을 식별하지 않습니다. 디바이스 트리에 루트 노드의 자식으로 배치될 가상 디바이스 를 식별합니다. 실제 하드웨어의 경우 하드웨어 ID 드라이버 업데이트를 선택하지 마세요. 대신 설치 및 확인을 선택합니다. 드라이버의 정보(INF) 파일에 하드웨어 ID가 표시됩니다. 솔루션 탐색기 창에서 KmdfDriver > 드라이버 파일로 이동하고 KmdfDriver.inf를 두 번 클릭합니다. 하드웨어 ID는 [Standard.NT$ARCH$] 아래에 있습니다.

    [Standard.NT$ARCH$]
    %KmdfDriver.DeviceDesc%=KmdfDriver_Device, Root\KmdfDriver
    
  8. 빌드 메뉴에서 솔루션 배포를 선택합니다. Visual Studio는 드라이버를 설치하고 실행하는 데 필요한 파일을 자동으로 대상 컴퓨터에 복사합니다. 1분 또는 2분이 걸릴 수 있습니다.

    드라이버를 배포하면 드라이버 파일이 테스트 컴퓨터의 %Systemdrive%\drivertest\drivers 폴더에 복사됩니다. 배포 중에 문제가 발생하면 검사 파일이 테스트 컴퓨터에 복사되었는지 확인할 수 있습니다. .inf, .cat, 테스트 인증서 및 .sys 파일 및 기타 필요한 파일이 %systemdrive%\drivertest\drivers 폴더에 있는지 확인합니다.

    드라이버 배포에 대한 자세한 내용은 테스트 컴퓨터에 드라이버 배포를 참조하세요.

드라이버 설치

KMDF 드라이버를 대상 컴퓨터에 배포하면 이제 드라이버를 설치합니다. 이전에 자동 옵션을 사용하여 Visual Studio에서 대상 컴퓨터를 프로비전한 경우 Visual Studio는 프로비전 프로세스의 일부로 테스트 서명된 드라이버를 실행하도록 대상 컴퓨터를 설정했습니다. 이제 DevCon 도구를 사용하여 드라이버를 설치하기만 하면 됩니다.

  1. 호스트 컴퓨터에서 WDK 설치의 도구 폴더로 이동하여 DevCon 도구를 찾습니다. 예를 들어 다음 폴더를 확인합니다.

    C:\Program Files (x86)\Windows Kits\10\Tools\x64\devcon.exe

    DevCon 도구를 원격 컴퓨터에 복사합니다.

  2. 대상 컴퓨터에서 드라이버 파일이 포함된 폴더로 이동한 다음 DevCon 도구를 실행하여 드라이버를 설치합니다.

    1. 다음은 드라이버를 설치하는 데 사용할 devcon 도구의 일반적인 구문입니다.

      devcon install <INF 파일><하드웨어 ID>

      이 드라이버를 설치하는 데 필요한 INF 파일은 KmdfDriver.inf입니다. INF 파일에는KmdfDriver.sys드라이버 이진 파일을 설치하기 위한 하드웨어 ID가 포함되어 있습니다. INF 파일에 있는 하드웨어 ID는 Root\KmdfDriver입니다.

    2. 관리자 권한으로 명령 프롬프트 창을 엽니다. 드라이버 패키지 폴더로 이동한 다음 다음 명령을 입력합니다.

      devcon install kmdfdriver.inf root\kmdfdriver

      devcon이 인식되지 않는 것에 대한 오류 메시지가 표시되면 devcon 도구에 경로를 추가해 보세요. 예를 들어 C:\Tools라는 대상 컴퓨터의 폴더에 복사한 경우 다음 명령을 사용해 보세요.

      c:\tools\devcon install kmdfdriver.inf root\kmdfdriver

      테스트 드라이버가 서명되지 않은 드라이버임을 나타내는 대화 상자가 나타납니다. 계속하려면 이 드라이버 설치를 선택합니다.

      드라이버 설치 경고의 스크린샷

드라이버 디버그

이제 대상 컴퓨터에 KMDF 드라이버를 설치했으므로 호스트 컴퓨터에서 원격으로 디버거를 연결합니다.

  1. 호스트 컴퓨터에서 관리자 권한으로 명령 프롬프트 창을 엽니다. WinDbg.exe 디렉터리로 변경합니다. Windows 키트 설치의 일부로 설치된 WDK(Windows 드라이버 키트)의 WinDbg.exe x64version을 사용합니다. WinDbg.exe 기본 경로는 다음과 같습니다.

    C:\Program Files (x86)\Windows Kits\10\Debuggers\x64

  2. WinDbg를 시작하여 다음 명령을 사용하여 대상 컴퓨터의 커널 디버그 세션에 연결합니다. 포트 및 키의 값은 대상 컴퓨터를 프로비전하는 데 사용한 값과 동일해야 합니다. 포트에는 50000 , 배포 단계에서 사용한 값인 키에 1.2.3.4 를 사용합니다. k 플래그는 커널 디버그 세션임을 나타냅니다.

    WinDbg -k net:port=50000,key=1.2.3.4

  3. 디버그 메뉴에서 중단을 선택합니다. 호스트 컴퓨터의 디버거가 대상 컴퓨터에 침입합니다. 디버거 명령 창에서 커널 디버깅 명령 프롬프트 kd>를 볼 수 있습니다.

  4. 이 시점에서 kd> 프롬프트에서 명령을 입력하여 디버거를 실험할 수 있습니다. 예를 들어 다음 명령을 사용해 볼 수 있습니다.

  5. 대상 컴퓨터를 다시 실행하려면 디버그 메뉴에서 이동을 선택하거나 "g"를 누른 다음 "enter"를 누릅니다.

  6. 디버깅 세션을 중지하려면 버그 메뉴에서 디버그 분리를 선택합니다.

    중요

    "go" 명령을 사용하여 디버거를 종료하기 전에 대상 컴퓨터를 다시 실행하도록 하거나 대상 컴퓨터가 여전히 디버거와 통신하고 있기 때문에 마우스 및 키보드 입력에 응답하지 않는 상태로 유지되는지 확인합니다.

드라이버 디버깅 프로세스에 대한 자세한 단계별 연습은 유니버설 드라이버 디버그 - 단계별 랩(Echo 커널 모드)을 참조하세요.

원격 디버깅에 대한 자세한 내용은 WinDbg를 사용하여 원격 디버깅을 참조하세요.

DMF(드라이버 모듈 프레임워크) 사용

DMF(드라이버 모듈 프레임워크)는 WDF 드라이버 개발자에게 추가 기능을 제공하는 WDF 확장입니다. 개발자가 모든 유형의 WDF 드라이버를 더 빠르고 더 빠르게 작성하는 데 도움이 됩니다.

DMF를 프레임워크로 사용하면 DMF 모듈이라는 WDF 개체를 만들 수 있습니다. 이러한 DMF 모듈에 대한 코드는 서로 다른 드라이버 간에 공유할 수 있습니다. 또한 DMF는 드라이버를 위해 개발한 DMF 모듈 라이브러리를 번들로 제공하며 다른 드라이버 개발자에게 가치를 제공할 것이라고 생각합니다.

DMF는 WDF를 대체하지 않습니다. DMF는 WDF와 함께 사용되는 두 번째 프레임워크입니다. DMF를 활용하는 개발자는 여전히 WDF 및 모든 기본 형식을 사용하여 디바이스 드라이버를 작성합니다.

자세한 내용은 DMF(드라이버 모듈 프레임워크)를 참조하세요.