다음을 통해 공유


KD 명령줄 옵션

KD의 처음 사용자는 KD 및 NTKD를 사용하는 디버깅 섹션으로 시작해야 합니다.

KD 명령줄은 다음 구문을 사용합니다.

kd [ -server ServerTransport | -remote ClientTransport ] 
   [-b | -x] [-d] [-bonc] [-m] [-myob] [-lines] [-n] [-r] [-s] 
   [-v] [-clines lines] [-failinc] [-noio] [-noshell] 
   [-secure] [-sdce] [-ses] [-sicv] [-sins] [-snc] [-snul]
   [-sup] [-sflags 0xNumber] [-log{a|au|o|ou} LogFile] 
   [-aExtension] [-zp PageFile] 
   [-i ImagePath] [-y SymbolPath]  [-srcpath SourcePath] 
   [-k ConnectType | -kl | -kqm | -kx ExdiOptions] [-ee {masm|c++}] 
   [-z DumpFile] [-cf "filename"] [-cfr "filename"] [-c "command"] 
   [-t PrintErrorLevel] [-version] 

kd -iu KeyString

kd -QR Server 

kd -wake PID 

kd -?

KD 명령줄 옵션에 대한 설명은 다음과 같습니다. -remote-server 옵션만 대/소문자를 구분합니다. 초기 하이픈은 슬래시(/)로 바꿀 수 있습니다. 추가 매개 변수를 사용하지 않는 옵션은 연결할 수 있으므로 kd -r -n -v를 kd -rnv작성할 수 있습니다.

-remote 또는 -server 옵션을 사용하는 경우 명령줄의 다른 옵션 앞에 나타나야 합니다.

매개 변수

-서버 ServerTransport
다른 디버거에서 액세스할 수 있는 디버깅 서버를 만듭니다. 가능한 ServerTransport에 대한 설명은 디버깅 서버 활성화를 참조하세요. 이 매개 변수를 사용하는 경우 명령줄의 첫 번째 매개 변수여야 합니다.

-먼 ClientTransport
디버깅 클라이언트를 만들고 이미 실행 중인 디버깅 서버에 연결합니다. 가능한 ClientTransport 값에 대한 설명은 디버깅 클라이언트 활성화를 참조하세요. 이 매개 변수를 사용하는 경우 명령줄의 첫 번째 매개 변수여야 합니다.

-a 확장
기본 확장 DLL을 설정합니다. 기본값은 kdextx86.dll 또는 kdexts.dll. "a" 뒤의 공백이 없어야 하며 .dll 파일 이름 확장명을 포함해서는 안 됩니다. 자세한 내용 및 이 기본값을 설정하는 다른 방법은 디버거 확장 DLL 로드를 참조 하세요.

-b
이 옵션은 더 이상 지원되지 않습니다.

-bonc
이 옵션을 지정하면 세션이 시작되는 즉시 디버거가 대상에 침입합니다. 이 기능은 현재 대상으로 분할되지 않을 수 있는 디버깅 서버에 연결할 때 특히 유용합니다.

-c "command"
시작 시 실행할 초기 디버거 명령을 지정합니다. 이 명령은 따옴표로 묶어야 합니다. 여러 명령을 세미콜론으로 구분할 수 있습니다. (긴 명령 목록이 있는 경우 스크립트에 추가한 다음 $, $, $,><>< $<><$ (스크립트 파일 실행) 명령과 함께 -c 옵션을 사용하는 것이 더 쉬울 수 있습니다.)

디버깅 클라이언트를 시작하는 경우 이 명령은 디버깅 서버용이어야 합니다. .lsrcpath와 같은 클라이언트별 명령은 허용되지 않습니다.

-cf "filename"
스크립트 파일의 경로와 이름을 지정합니다. 이 스크립트 파일은 디버거가 시작되는 즉시 실행됩니다. 파일 이름에 공백이 포함된 경우 따옴표로 묶어야 합니다. 경로를 생략하면 현재 디렉터리가 가정됩니다. -cf 옵션을 사용하지 않으면 현재 디렉터리의 ntsd.ini 파일이 스크립트 파일로 사용됩니다. 파일이 없으면 오류가 발생하지 않습니다. 자세한 내용은 스크립트 파일 사용을 참조 하세요.

-cfr "filename"
스크립트 파일의 경로와 이름을 지정합니다. 이 스크립트 파일은 디버거가 시작되고 대상이 다시 시작될 때마다 실행됩니다. 파일 이름에 공백이 포함된 경우 따옴표로 묶어야 합니다. 경로를 생략하면 현재 디렉터리가 가정됩니다. 파일이 없으면 오류가 발생하지 않습니다. 자세한 내용은 스크립트 파일 사용을 참조 하세요.

-clines 라인
원격 디버깅 중에 액세스할 수 있는 명령 기록의 대략적인 명령 수를 설정합니다. 자세한 내용 및 이 숫자를 변경하는 다른 방법은 디버거 명령 사용을 참조 하세요.

-d
다시 부팅한 후 커널 모듈이 로드되는 즉시 디버거가 대상 컴퓨터에 침입합니다. (이 중단은 -b 옵션의 중단보다 이전입니다.) 자세한 내용 및 이 상태를 변경하는 다른 방법은 대상 컴퓨터 충돌 및 다시 부팅을 참조하세요.

-ee {masm|c++}
기본 식 계산기를 설정합니다. masm을 지정하면 MASM 식 구문이 사용됩니다. c++를 지정하면 C++ 식 구문이 사용됩니다. -ee 옵션을 생략하면 MASM 식 구문이 기본값으로 사용됩니다. 자세한 내용은 식 평가를 참조하세요.

-failinc
디버거가 의심스러운 기호를 무시하도록 합니다. 사용자 모드 또는 커널 모드 미니덤프 파일을 디버깅할 때 이 옵션은 디버거가 이미지를 매핑할 수 없는 모듈을 로드하지 못하게 합니다. 자세한 내용 및 이를 제어하는 다른 방법은 SYMOPT_EXACT_SYMBOLS 참조하세요.

-나는 ImagePath
오류를 생성한 실행 파일의 위치를 지정합니다. 경로에 공백이 포함된 경우 따옴표로 묶어야 합니다.

-iu KeyString
사용자가 URL을 사용하여 디버거 원격 클라이언트를 자동으로 시작할 수 있도록 디버거 원격을 URL 유형으로 등록합니다. KeyString 의 형식 remdbgeng://RemotingOption은 다음과 같습니다. RemotingOption은 디버깅 클라이언트 활성화 항목에 정의된 대로 전송 프로토콜을 정의하는 문자열입니다. 이 작업이 성공하면 메시지가 표시되지 않습니다. 실패하면 오류 메시지가 표시됩니다.

-iu 매개 변수는 다른 매개 변수와 함께 사용하면 안 됩니다. 이 명령은 실제로 KD를 시작하지 않습니다.

-k ConnectType
대상에 연결하는 방법을 디버거에 알려줍니다. 자세한 내용은 KD 및 NTKD를 사용하여 디버깅을 참조하세요.

-Kl 기
디버거와 동일한 컴퓨터에서 커널 디버깅 세션을 시작합니다.

-kqm
자동 모드에서 KD를 시작합니다.

-kx ExdiOptions
EXDI 드라이버를 사용하여 커널 디버깅 세션을 시작합니다. EXDI 드라이버는 이 설명서에 설명되어 있지 않습니다. 하드웨어 프로브 또는 하드웨어 시뮬레이터에 대한 EXDI 인터페이스가 있는 경우 디버깅 정보는 Microsoft에 문의하세요.

-라인
소스 줄 디버깅을 사용하도록 설정합니다. 이 옵션을 생략 하면 소스 디버깅이 허용되기 전에 .lines(소스 줄 지원 토글) 명령을 사용해야 합니다. 이를 제어하는 다른 방법은 SYMOPT_LOAD_LINES 참조하세요.

-log{a|au|o|ou} LogFile
로그 파일에 대한 정보 로깅을 시작합니다. LogFile이 이미 있는 경우 -logo를 사용하는 경우 덮어쓰거나 -loga를 사용하는 경우 출력이 파일에 추가됩니다. 로그 파일이 유니코드 파일이라는 점을 제외하고 -logau-logou 옵션은 각각 -loga 및 -logo유사하게 작동합니다. 자세한 내용은 KD에서 로그 파일 유지를 참조하세요.

-m
직렬 포트가 모뎀에 연결되어 있음을 나타냅니다. 캐리어 감지 신호를 감시하도록 디버거에 지시합니다.

-myob
버전이 dbghelp.dll 일치하지 않으면 디버거가 계속 실행됩니다. (-myob 스위치가 없으면 심각한 오류로 간주됩니다.)

이 옵션의 보조 효과는 대상 컴퓨터에 침입할 때 일반적으로 나타나는 경고가 표시되지 않는다는 것입니다.

-n
노이즈 기호 로드: 기호 처리기에서 자세한 출력을 사용하도록 설정합니다. 자세한 내용 및 이를 제어하는 다른 방법은 SYMOPT_DEBUG 참조하세요.

-noio
디버깅 서버가 입력 또는 출력에 사용되지 않도록 합니다. 입력은 디버깅 클라이언트에서만 허용됩니다(-c 명령줄 옵션으로 지정된 모든 초기 명령 또는 명령 스크립트 포함).

모든 출력은 디버깅 클라이언트로 전달됩니다. 자세한 내용은 디버깅 서버 활성화를 참조 하세요.

-noshell
모든 .shell 명령을 금지합니다. 이 금지는 새 디버깅 세션이 시작되더라도 디버거가 실행되는 한 지속됩니다. 자세한 내용 및 셸 명령을 사용하지 않도록 설정하는 다른 방법은 셸 명령 사용을 참조 하세요.

-QR 서버
지정된 네트워크 서버에서 실행되는 모든 디버깅 서버를 나열합니다. 이전 서버의 이중 백슬래시(\\)는 선택 사항입니다. 자세한 내용은 디버깅 서버 검색을 참조하세요.

-QR 매개 변수는 다른 매개 변수와 함께 사용하면 안 됩니다. 이 명령은 실제로 KD를 시작하지 않습니다.

-r
레지스터를 표시합니다.

-s
지연 기호 로드를 사용하지 않도록 설정합니다. 이렇게 하면 프로세스 시작 속도가 느려집니다. 자세한 내용 및 이를 제어하는 다른 방법은 SYMOPT_DEFERRED_LOADS 참조하세요.

-sdce
기호를 로드하는 동안 디버거가 파일 액세스 오류 대화 상자를 표시하도록 합니다. 자세한 내용 및 이를 제어하는 다른 방법은 SYMOPT_FAIL_CRITICAL_ERRORS 참조하세요.

-확실한
보안 모드를 활성화합니다.

-ses
디버거가 모든 기호 파일에 대해 엄격한 평가를 수행하고 의심스러운 기호를 무시하도록 합니다. 자세한 내용 및 이를 제어하는 다른 방법은 SYMOPT_EXACT_SYMBOLS 참조하세요.

-sflags 0x
모든 기호 처리기 옵션을 한 번에 설정합니다. 숫자는 0x 접두사인 16진수여야 합니다. 즉, 0x가 없는 10진수는 허용되지만 기호 옵션은 이진 플래그이므로 16진수가 권장됩니다. 이 옵션은 모든 기호 처리기 기본값을 재정의하므로 주의하여 사용해야 합니다. 자세한 내용은 기호 옵션 설정을 참조 하세요.

-sicv
기호 처리기가 CV 레코드를 무시하도록 합니다. 자세한 내용 및 이를 제어하는 다른 방법은 SYMOPT_IGNORE_CVREC 참조하세요.

-죄
디버거가 기호 경로 및 실행 가능한 이미지 경로 환경 변수를 무시하도록 합니다. 자세한 내용은 SYMOPT_IGNORE_NT_SYMPATH 참조하세요.

-snc
디버거가 C++ 변환을 해제하도록 합니다. 자세한 내용 및 이를 제어하는 다른 방법은 SYMOPT_NO_CPP 참조하세요.

-snul
정규화되지 않은 이름에 대해 자동 기호 로드를 사용하지 않도록 설정합니다. 자세한 내용 및 이를 제어하는 다른 방법은 SYMOPT_NO_UNQUALIFIED_LOADS 참조하세요.

-srcpath SourcePath
원본 파일 검색 경로를 지정합니다. 여러 경로를 세미콜론(;)으로 구분합니다. 경로에 공백이 포함된 경우 따옴표로 묶어야 합니다. 자세한 내용 및 이 경로를 변경하는 다른 방법은 원본 경로를 참조 하세요.

-sup
기호 처리기가 모든 기호 검색 중에 공용 기호 테이블을 검색하도록 합니다. 자세한 내용 및 이를 제어하는 다른 방법은 SYMOPT_AUTO_PUBLICS 참조하세요.

-t PrintErrorLevel
디버거에서 오류 메시지를 표시할 오류 수준을 지정합니다. 0, 1, 2 또는 3과 같은 10진수입니다. 값은 다음과 같이 설명됩니다.

상수 의미

0

NONE

오류를 표시하지 마세요.

1

오류

오류 수준 디버깅 이벤트를 표시합니다.

2

MINORERROR

MINORERROR 및 ERROR 수준 디버깅 이벤트를 표시합니다.

3

WARNING

경고, MINORERROR 및 ERROR 수준 디버깅 이벤트를 표시합니다.

이 오류 수준은 Microsoft Windows의 확인된 빌드에서만 의미가 있습니다. 기본값은 1입니다. 확인된 빌드는 Windows 10 버전 1803 이전 버전의 Windows에서 사용할 수 있었습니다.

-v
로드, 지연된 로드 및 언로드에 대한 자세한 정보를 생성합니다.

-버전
디버거 버전 문자열을 인쇄합니다.

-웨이크 PID
PID에서 프로세스 ID를 지정하는 사용자 모드 디버거에 대해 절전 모드가 종료되도록 합니다. 절전 모드 중에 대상 컴퓨터에서 이 명령을 실행해야 합니다. 자세한 내용은 커널 디버거에서 사용자 모드 디버거 제어를 참조하세요.

-wake 매개 변수는 다른 매개 변수와 함께 사용하면 안 됩니다. 이 명령은 실제로 KD를 시작하지 않습니다.

-x
예외를 발생시킨 애플리케이션 또는 모듈이 예외를 처리하도록 하는 대신 예외가 처음 발생할 때 디버거가 중단되도록 합니다. (초기 eb nt를 제외하고 -b와 동일! NtGlobalFlag 9; g command.)

-y SymbolPath
기호 검색 경로를 지정합니다. 여러 경로를 세미콜론(;)으로 구분합니다. 경로에 공백이 포함된 경우 따옴표로 묶어야 합니다. 자세한 내용 및 이 경로를 변경하는 다른 방법은 기호 경로를 참조 하세요.

-z DumpFile
디버그할 크래시 덤프 파일의 이름을 지정합니다. 경로와 파일 이름에 공백이 포함된 경우 따옴표로 묶어야 합니다. 여러 -z 옵션, 각각 다른 DumpFile 값을 포함하여 여러 덤프 파일을 한 번에 열 수 있습니다. 자세한 내용은 KD를 사용하여 커널 모드 덤프 파일 분석을 참조하세요.

-zp PageFile
수정된 페이지 파일의 이름을 지정합니다. 덤프 파일을 디버깅하고 .pagein(메모리 내 페이지) 명령을 사용하려는 경우에 유용합니다. 표준 Windows 페이지 파일에서 -zp를 사용할 수 없습니다. 특별히 수정된 페이지 파일만 사용할 수 있습니다.

-?
명령줄 도움말 텍스트를 표시합니다.

KD는 대상이 실행되는 플랫폼을 자동으로 검색합니다. KD 명령줄에서 대상을 지정할 필요가 없습니다. 이전 구문(이름 I386KD 또는 IA64KD 사용)은 사용되지 않습니다.