Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 71. windbg + 닷넷 디버깅 (2) - null 체크 패턴 [링크 복사], [링크+제목 복사],
조회: 20556
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

windbg + 닷넷 디버깅 (2) - null 체크 패턴

setnz와 setne는 같은 역할을 하는 명령어입니다.

setne == Set if not equal
SETNZ == Set if not zero

단지, .NET JIT 컴파일러의 특성이겠지만 닷넷 응용 프로그램을 disassembly 창에서 보면 setnz보다는 setne 명령어를 더 자주 볼 수 있습니다.

2개의 명령어 모두 같음(equal)을 판별하기 위해 FLAG 레지스터의 Zero 플래그를 확인하는데, 대개의 경우 cmp 명령어 등이 선행되어 2개의 값을 비교해 Zero 플래그를 변경시킨 이후 setne/setnz 명령어가 나오는 패턴을 따릅니다.

예를 들어, 닷넷에서 null 비교하는 구문을 보면,

if (myvar == null)
{
}

disassembly 창에서 이런 식으로 cmp 명령어가 등장합니다.

cmp         dword ptr [ebp-4Ch],0    // [ebp-4ch] == myvar
                                     // 32비트인 경우, 지역 변수는 대개 [ebp-offset] 값 형식입니다.

즉, [ebp-4ch] 주소가 가리키는 값에서 0을 빼서 0 이 나왔다면, cmp 명령어는 ZERO 플래그를 SET 시킵니다. (cmp는 결과 값을 저장하지 않을 뿐 sub 명령어와 역할이 유사합니다.)

따라서, 이어서 나오는 setne 명령어는,

setne al

(cmp 명령어로 변경된) zero flag == 1이면 'equal'로 판정하고 al 레지스터에 0을 설정하지만, zero flag == 0이면 "if not equal"이므로 al 레지스터의 값에 1을 설정합니다.

setne 명령어가 1바이트 레지스터 값을 조정하므로, 대개의 경우 (32비트인 경우) 4바이트로 확장하는 movzx 명령어가 이어서 나오게 됩니다.

movzx       eax,al 

예를 들어, setne 하기 전에 eax == 02CB503C 값이었다면, setne로 (값이 같지 않은 경우) 02cb5001로 바뀌게 되고, 이어서 "movzx eax,al"로 인해 eax == 00000001로 최종 완성됩니다.




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







[최초 등록일: ]
[최종 수정일: 2/26/2015]

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

비밀번호

댓글 작성자
 




... 166  167  168  169  170  171  172  173  174  175  [176]  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
633정성태12/20/200826111기타: 24. RMClock for x64 [2]
632정성태12/19/200834563기타: 23. D820 - 배터리 없이 바이오스 업데이트 방법 [2]파일 다운로드1
631정성태12/10/200843566VC++: 36. Detours 라이브러리를 이용한 Win32 API - Sleep 호출 가로채기 [3]
630정성태12/9/200824381.NET Framework: 117. WPF - TreeView에서 항목이 펼쳐질 때 Cursors.Wait 사용파일 다운로드1
629정성태12/7/200833585.NET Framework: 116. 소켓 연결 시간 제한
628정성태12/6/200822151.NET Framework: 115. Marshal 타입 관련 2가지 자원 해제 메서드파일 다운로드1
627정성태12/6/200824774VS.NET IDE: 58. VS.NET IDE 팁 - 커서 위치 이동 [1]
626정성태12/6/200824850오류 유형: 65. TF53018: The application tier XXXXXXX is attempting to connect to a data tier with an incompatible version
625정성태12/6/200825063오류 유형: 64. TFS 2008 SP1 설치 - MsiApplyMultiplePatches returned 0x643
624정성태12/5/200826024.NET Framework: 114. WPF 이벤트에 속한 핸들러 확인 [2]파일 다운로드1
623정성태12/4/200830478디버깅 기술: 22. VS.NET SP1 + .NET Framework 소스 코드 디버깅 [2]파일 다운로드1
622정성태12/1/200832765오류 유형: 63. WPF - XamlParseException 대응 방법 [2]
621정성태11/30/200824790Team Foundation Server: 27. TeamBuild + VDPROJ 셋업 프로젝트 [1]
620정성태11/30/200823684디버깅 기술: 21. 올바른 이벤트 예외 정보 출력
619정성태11/30/200823813디버깅 기술: 20. 예외 처리를 방해하는 WPF Modal 대화창파일 다운로드1
618정성태11/29/200824104.NET Framework: 113. 이벤트에 속한 이벤트 핸들러 확인파일 다운로드1
617정성태11/26/200830291.NET Framework: 112. How to Interop DISPPARAMS [2]파일 다운로드2
616정성태11/26/200823591디버깅 기술: 19. C++/CLI - F11 디버깅 시의 변수 초기화파일 다운로드1
615정성태11/9/200833182.NET Framework: 111. WPF - Window, UserControl 클래스 상속 [1]
614정성태11/9/200833136.NET Framework: 110. WPF - 전역 예외 처리 [4]파일 다운로드1
613정성태11/8/200822673.NET Framework: 109. WPF - SystemColors 색상표파일 다운로드1
612정성태11/1/200828037.NET Framework: 108. WPF + WCF 환경에서는 DataContract를 권장 [1]
611정성태10/31/200822059오류 유형: 62. WPF - Visual Studio 2008 비정상 종료
610정성태10/24/200824630Team Foundation Server: 26. TFS 2008 SP1 + SQL Server 2008 설치
609정성태10/24/200828741.NET Framework: 107. WPF - RadioButton 데이터 바인딩 해제 현상파일 다운로드2
608정성태10/23/200822881오류 유형: 61. TFS 연결 오류: TF31003, TF30331 오류
... 166  167  168  169  170  171  172  173  174  175  [176]  177  178  179  180  ...