일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- call instruction
- void main
- struct반환
- disassemble
- WPF
- return
- NASM
- effective address
- 운영체제
- stackalign
- movups
- movdqu
- 어셈블리
- movaps
- OS
- compare
- 유효 주소
- modr/m
- sib
- load effective address
- C#
- csproj
- C언어
- 숏코딩
- struct
- assembly
- modrm
- instruction
- GCC
- C
- Today
- Total
프로그래밍 잡화점
ModR/M과 SIB에 관한 이야기 1 본문
최근 어셈블리를 사용하던 도중 왜 돌아가지 라는 생각이 드는 코드가 있었다.
mov eax, [arr+edx*3]
엥? 뭐가 문제인데요?
이전 글을 참고해 보자.
Scale의 경우에는 보이다 싶이 1, 2, 4, 8만 사용될 수 있다.
그렇다. Instruction 상에는 저런 SIB가 존재할 수 없다는 얘기다.
가장 간단한 방법을 통해 어떤일이 벌어졌는지 알아보자.
gdb로 빌드된 파일을 역어셈 해보았더니
맞다. 눈치 빠른 사람은 벌써 눈치를 챘을 텐데
원래 우리가 해석할려고 했던 것에서 뭐가 문제인지 알아냇을 것이다.
저 코드를 이상하다고 보고 해석했다면,
arr을 base, edx를 index, 3을 scale로 해석했을 것이다.
arr을 base로 두어야 하는가? ModR/M에서 SIB 형태만 존재하는게 아닐텐데?
이것이 제일 핵심인 것이다.
이번엔 분해된 코드를 보자
이번에는 arr이 ModR/M에서의 disp32를 담당하고 있으며
edx가 base, edx가 index, 2가 scale을 담당하고 있다.
이러면 이제 말이 된다.
ModR/M에 있던 형태중 하나인, SIB + disp32와 SIB의 [edx*2] + edx 라는 형태가 사용되어 결합된 명령어가 된 것이다.
같은 논리로, 3뿐만 아니라 5, 9까지 되는 것을 확인해볼 수 있다.
'Assembly' 카테고리의 다른 글
0 - 4 기본적인 Assembly 개념 - 문법과 instruction Part 3 (0) | 2023.08.24 |
---|---|
어셈블리와 기계어에 관해서 (0) | 2023.06.10 |
0 - 3 기본적인 Assembly 개념 - 문법과 instruction Part 2 (0) | 2023.04.13 |
SIMD in Assembly (2) | 2023.04.10 |
0 - 2 기본적인 Assembly 개념 - 문법과 instruction Part 1 (0) | 2022.09.29 |
Comments