Assembly
[어셈블리어] 추가 배열없이 배열 역순으로 배치 with assembly
GuTTe
2018. 10. 31. 00:51
x86 프로세서를 위한 어셈블리어 6판에서 문제인 배열의 역순 풀이
풀면서 여러방법이 있겠지만 2가지 방법이 떠오름
첫 번째로 임시 레지스터를 이용해서 배열의 값을 교체하는거
두 번째로 스택공간의 push와 pop을 이용해 교체하는 것
첫 번째 하다가 segment fault떠서 두 번째 방법으로 갈아탔는데 똑같이 segment fault떴음.
알고 보니깐 두 개다 마지막에 mov esp, ebp를 갈겨서 스택이 증발해벼렸던거... ;(
암튼 풀이는 스택에 1,2,3,4,5 ... 순서대로 push하면 마지막엔 10이 있음. 이 10을 기준으로 다시 pop하면 됨.
아 그리고 C 라이브러리함수인 printf를 호출하면 eax와 ebx, ecx의 값이 바뀌는데 eax의 값이 바뀌는건 알았는데 ecx 레지스터의 값이 바껴서 당황 그래서 sub esp, 4해서 지역변수를 만들어서 백업함. ~.~
nasm : 32bit intel assemby
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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 | %include "asm_io.inc" segment .bss segment .data array dd 1,2,3,4,5,6,7,8,9,10 format db "%d", 0 segment .text global main extern printf main: push ebp mov ebp, esp sub esp, 4 ;printf함수를 호출하면 ecx의 값이 바뀌는데 백업용 mov ecx, 10 mov esi, array xor ebx, ebx ready_reverse: push dword [esi+ebx] add ebx, 4 loop ready_reverse setting: mov ecx, 10 xor ebx, ebx reverse: pop eax mov [esi+ebx], eax add ebx, 4 loop reverse setting_lat: mov ecx, 10 xor ebx, ebx print: mov [ebp-4], ecx push dword [esi+ebx] push format call printf add esp, 8 call print_nl add ebx, 4 mov ecx, [ebp-4] loop print end: add esp, 4 pop ebp ret | cs |