Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 71. windbg + 닷넷 디버깅 (2) - null 체크 패턴 [링크 복사], [링크+제목 복사],
조회: 21757
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  68  69  70  71  [72]  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12197정성태3/17/202022134VS.NET IDE: 144. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 - 두 번째 이야기 [1]
12196정성태3/17/202018486오류 유형: 608. The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).
12195정성태3/16/202021028.NET Framework: 902. C# - 프로세스의 모든 핸들을 열람 - 세 번째 이야기
12194정성태3/16/202024007오류 유형: 607. PostgreSQL - Npgsql.NpgsqlException: sorry, too many clients already
12193정성태3/16/202021035개발 환경 구성: 485. docker - SAP Adaptive Server Enterprise 컨테이너 실행 [1]
12192정성태3/14/202022204개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행
12191정성태3/14/202023585개발 환경 구성: 483. docker - OracleXE 컨테이너 실행 [1]
12190정성태3/14/202018404오류 유형: 606. Docker Desktop 업그레이드 시 "The process cannot access the file 'C:\Program Files\Docker\Docker\resources\dockerd.exe' because it is being used by another process."
12189정성태3/13/202023814개발 환경 구성: 482. Facebook OAuth 처리 시 상태 정보 전달 방법과 "유효한 OAuth 리디렉션 URI" 설정 규칙
12188정성태3/13/202029768Windows: 169. 부팅 시점에 실행되는 chkdsk 결과를 확인하는 방법
12187정성태3/12/202018797오류 유형: 605. NtpClient was unable to set a manual peer to use as a time source because of duplicate error on '...'.
12186정성태3/12/202020044오류 유형: 604. The SysVol Permissions for one or more GPOs on this domain controller and not in sync with the permissions for the GPOs on the Baseline domain controller.
12185정성태3/11/202020908오류 유형: 603. The browser service was unable to retrieve a list of servers from the browser master...
12184정성태3/11/202023160오류 유형: 602. Automatic certificate enrollment for local system failed (0x800706ba) The RPC server is unavailable. [3]
12183정성태3/11/202019815오류 유형: 601. Warning: DsGetDcName returned information for \\[...], when we were trying to reach [...].
12182정성태3/11/202021573.NET Framework: 901. C# Windows Forms - Vista/7 이후의 Progress Bar 업데이트가 느린 문제파일 다운로드1
12181정성태3/11/202022001기타: 76. 재현 가능한 최소한의 예제 프로젝트란? - 두 번째 예제파일 다운로드1
12180정성태3/10/202018940오류 유형: 600. "Docker Desktop for Windows" - EXPOSE 포트가 LISTENING 되지 않는 문제
12179정성태3/10/202029760개발 환경 구성: 481. docker - PostgreSQL 컨테이너 실행
12178정성태3/10/202023353개발 환경 구성: 480. Linux 운영체제의 docker를 위한 tcp 바인딩 추가 [1]
12177정성태3/9/202022470개발 환경 구성: 479. docker - MySQL 컨테이너 실행
12176정성태3/9/202021737개발 환경 구성: 478. 파일의 (sha256 등의) 해시 값(checksum) 확인하는 방법
12175정성태3/8/202021826개발 환경 구성: 477. "Docker Desktop for Windows"의 "Linux Container" 모드를 위한 tcp 바인딩 추가
12174정성태3/7/202020115개발 환경 구성: 476. DockerDesktopVM의 파일 시스템 접근 [3]
12173정성태3/7/202022276개발 환경 구성: 475. docker - SQL Server 2019 컨테이너 실행 [1]
12172정성태3/7/202026529개발 환경 구성: 474. docker - container에서 root 권한 명령어 실행(sudo)
... 61  62  63  64  65  66  67  68  69  70  71  [72]  73  74  75  ...