Introduce
시스템 해커는 어셈블리어어로 작성된 소프트웨어에서 취약점을 발견해야한다
Assembly Language
Assembler
개발자들이 작성한 어셈블리어 -> 컴퓨터가 이해 할 수 있는 기계어로 치환하는 통역사
Disassembler
기계어 -> 어셈블리 언어로 번역
Assembly Language and x86-64
Assembly Language
CPU 에서 사용되는 ISA (Instruction Set Architecture) 가 여러 종류인 것 과 같이 다양한 수의 어셈블리어가 존재한다
x64 Assembly Language
문법 구조
- 명령어(operation Code, Opcode)
- 피연산자 (Operand)
명령어 ; Opcode
- 데이터 이동 (Data Transfer)
mov, lea
- 산술 연산 (Arithmetic)
inc, dec, add, sub
- 논리 연산 (Logical)
and, or, xor, not
- 비교 (Comparison)
cmp, test
- 분기 (Branch)
jmp, je, jg
- 스택 (Stack)
push, pop
- 프룃져 (Procedure)
call, ret, leave
- 시스템 콜 (System Call)
sycall
Operand
- Immediate Value (상수)
- Register (레지스터)
- memory (메모리)
data:image/s3,"s3://crabby-images/0cc67/0cc672717a7b3fcf7c0bd89f94f51b55dac69534" alt=""
Type PTR : Size Directive (크기 지정자) 가 추가 될 수 있음
type
- BYTE : 1byte
- WORD : 2 byte
- DWORD : 4byte
- QWORD : 8byte
Opcode: x86-86 Assembly Language
Ddata Transfer
data:image/s3,"s3://crabby-images/a5dbb/a5dbb1ace0f19a2b097aa084dc831719302b8a1b" alt=""
data:image/s3,"s3://crabby-images/a7dd2/a7dd264d500dbf9dcfb826e5ca651ef19b1688f8" alt=""
data:image/s3,"s3://crabby-images/ac47a/ac47a9befb160cbbdc1398c1bf961d9084926a6e" alt=""
data:image/s3,"s3://crabby-images/57435/57435432c70e2edf00a78cee1f7ea712d03889ef" alt=""
Arithmethic
data:image/s3,"s3://crabby-images/84120/841208010c94d2accdf2ab3f09bc9b8b313e5b7a" alt=""
data:image/s3,"s3://crabby-images/8d577/8d5770907de26f004b65751efce8c6f9eca04eb0" alt=""
data:image/s3,"s3://crabby-images/c903f/c903fa4087911e7a000527eb1b00bc939066b9bc" alt=""
data:image/s3,"s3://crabby-images/7089f/7089fa2593df62ae2e7a74b1312cb180a53401fe" alt=""
Q . [rbx+rcx*8] 에서 rcx 는 왜 0x10(0x555555554010) 인지?
Logical ; 논리연산
And
data:image/s3,"s3://crabby-images/881b9/881b99ea0fbef5cb1ff9785e4dabf09cf8c715e2" alt=""
Or
data:image/s3,"s3://crabby-images/86b91/86b911e5204f8ad78043acc398f2795b2ceba6c8" alt=""
data:image/s3,"s3://crabby-images/1ea22/1ea22fcecb68f0643d117417e91c1e28a7bc316f" alt=""
data:image/s3,"s3://crabby-images/a4bda/a4bda3297906aa788cac9327f5fca76a2ad71503" alt=""
xor
data:image/s3,"s3://crabby-images/28457/28457fecdd1957715291683cf521712f159c18e8" alt=""
not
data:image/s3,"s3://crabby-images/c7ca4/c7ca490bb469a5bd98daf1405d34f297dc007b18" alt=""
data:image/s3,"s3://crabby-images/b0857/b0857eb5841822e347787ee4cc855156574c9f66" alt=""
Q. xor 연산
Comparison ; 비교
두 피연산자의 값을 비교하고, 플래그를 설정
data:image/s3,"s3://crabby-images/04ddc/04ddc21f63d3e8d7aa4e5bf3176e3958059e8c24" alt=""
Branch ; 분기
rip 를 이동시켜 실행흐름 변경
data:image/s3,"s3://crabby-images/d7179/d71795f9178f90efa6f31c3b6cf8da9bf550f86d" alt=""