Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 162. x86/x64의 기계어 코드 최대 길이 [링크 복사], [링크+제목 복사],
조회: 18531
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

x86/x64의 기계어 코드 최대 길이

궁금해서 찾아본 것인데,

x86_64 ASM - maximum bytes for an instruction?
; https://stackoverflow.com/questions/14698350/x86-64-asm-maximum-bytes-for-an-instruction

2.3.11 AVX Instruction Length
The maximum length of an Intel 64 and IA-32 instruction remains 15 bytes.

x86/x64 모두 15 바이트가 최대 길이라고 합니다. 실제로 다음의 글에 보면,

Longest x86 Instruction
; https://web.archive.org/web/20131109063453/https://www.onlinedisassembler.com/blog/?p=23

예제가 하나 나옵니다. ^^

lock add DWORD PTR ds:[esi+ecx*4+0x12345678],0xefcdab89

==> 67 66 f0 3e 81 84 8e 78 56 34 12 89 ab cd ef

이와 함께 우연히 발견한 CLR의 코드가 재미있습니다. ^^

clr!JIT_MonEnter:
00007fff`8b0a26b0 33d2            xor     edx,edx
00007fff`8b0a26b2 6666666666660f1f840000000000 nop word ptr [rax+rax]

nop 코드인데 "word ptr" 및 레지스터 연산을 통한 간접 주소까지 합해 14바이트입니다. 유사한 코드로 x86에서는 NOP 코드가 9바이트까지 길어질 수 있는 것 같습니다. ^^

[x86 환경]
66 NOP DWORD ptr [EAX + EAX*1 + 00000000H]

==> 66 0F 1F 84 00 00 00 00 00H

1바이트 nop을 n번 반복해도 되겠지만. ^^




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 2/27/2020]

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

비밀번호

댓글 작성자
 




... [121]  122  123  124  125  126  127  128  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
10899정성태2/17/201623373개발 환경 구성: 282. kernel32.dll, kernel32legacy.dll, api-ms-win-core-sysinfo-l1-2-0.dll [1]
10898정성태2/17/201621836.NET Framework: 547. PerformanceCounter의 InstanceName 지정 시 주의 사항파일 다운로드1
10897정성태2/17/201621229디버깅 기술: 76. windbg 분석 사례 - 닷넷 프로파일러의 GC 콜백 부하
10896정성태2/17/201622343오류 유형: 320. FATAL: 28000: no pg_hba.conf entry for host "fe80::1970:8120:695:a41e%12"
10895정성태2/17/201621124.NET Framework: 546. System.AppDomain으로부터 .NET Profiler의 AppDomainID 구하는 방법 [1]
10894정성태2/17/201621845오류 유형: 319. Visual Studio에서 찾기는 성공하지만 해당 소스 코드 정보가 보이지 않는 경우
10893정성태2/16/201620515.NET Framework: 545. 닷넷 - 특정 클래스가 로드되었는지 여부를 알 수 있을까? - 두 번째 이야기
10892정성태2/16/201621109오류 유형: 318. 탐색기에서 폴더 생성/삭제 시 몇 초 동안 멈추는 현상
10891정성태2/16/201624134VC++: 95. 내 CPU가 MPX/SGX를 지원할까요? [1]
10890정성태2/15/201624034.NET Framework: 544. C# 5의 Caller Info를 .NET 4.5 미만의 응용 프로그램에 적용하는 방법 [5]
10889정성태2/14/201620315.NET Framework: 543. C++의 inline asm 사용을 .NET으로 포팅하는 방법 - 두 번째 이야기파일 다운로드1
10888정성태2/14/201618645.NET Framework: 542. 닷넷 - 특정 클래스가 로드되었는지 여부를 알 수 있을까?
10887정성태2/3/201619335VC++: 94. MPX(Memory Protection Extensions) 테스트파일 다운로드1
10886정성태2/3/201620559개발 환경 구성: 281. Intel MPX Runtime Driver 수동 설치
10885정성태2/2/201620268오류 유형: 317. Sybase.Data.AseClient.AseException: The command has timed out.
10884정성태1/11/201621463개발 환경 구성: 280. 닷넷에서 SAP Adaptive Server Enterprise 데이터베이스 사용파일 다운로드1
10882정성태1/6/201620760Windows: 113. 윈도우의 2179, 26143, 47001 TCP 포트 사용 [1]
10881정성태1/3/201622185오류 유형: 316. 윈도우 10 - 바탕/돋음 체가 사라져 한글이 깨지는 현상 [2]
10880정성태12/16/201519901오류 유형: 315. 닷넷 프로파일러의 오류 코드 정보
10879정성태12/16/201521834오류 유형: 314. Error : DEP0700 : Registration of the app failed. error 0x80070005
10878정성태12/9/201524867디버깅 기술: 75. UWP(유니버설 윈도우 플랫폼) 앱에서 global::System.Diagnostics.Debugger.Break 예외 발생 시 대응 방법
10877정성태12/9/201529296VC++: 93. std::thread 사용 시 R6010 오류 [2]
10876정성태11/26/201525362.NET Framework: 541. SignedXml을 이용한 ds:Signature만드는 방법 [3]파일 다운로드1
10875정성태11/26/201530340개발 환경 구성: 279. signtool.exe의 다중 서명 기능 [2]
10874정성태11/26/201526351개발 환경 구성: 278. 인증서와 인증서를 이용한 코드 사인의 해시 구분
10873정성태11/25/201525462.NET Framework: 540. C# - 부동 소수 계산 왜 이렇게 나오죠? (2) [3]파일 다운로드1
... [121]  122  123  124  125  126  127  128  129  130  131  132  133  134  135  ...