Конвертировать программу на C в Nasm Assembly x86 - PullRequest
0 голосов
/ 22 мая 2018

Я пытаюсь преобразовать код C (который читает число из стандартного ввода и вычисляет значение числа Фибоначчи, но содержание кода не так важно для проблемы) в код назма, используя эту ссылку: https://stackoverflow.com/a/20743090/9557460 но на шаге 3, когда я ставлю команду

nasm -f elf64 main.asm

, я получаю

 main.asm:45: error: symbol `?_001' undefined
 main.asm:106: error: symbol `?_001' undefined

по какой-то причине? _001 не определено, но используется в коде.и при удалении его вручную код не работает.

Код C:

#include <stdio.h>
#include <stdlib.h>
#define MAX_PHYSICAL_MEMORY 500
static long M[MAX_PHYSICAL_MEMORY] = {
};
int main()
{
    for (int i=0; i<MAX_PHYSICAL_MEMORY; i++){//taking the numbers from         an array
        scanf("%ld", &M[i]);
    }

    int i = 0;
    //char *format;
    while (M[i] || M[i + 1] || M[i + 2]){//this is the sic program
        if ((M[M[i]] -= M[M[i + 1]]) < 0) 
            i = M[i + 2];
        else 
            i += 3;
    }
    for (i = 0; i < MAX_PHYSICAL_MEMORY; ++i) {//it is just do the printing
        printf("%ld ", M[i]);
    }
    printf("\n");

    return 0;
 } 

сгенерированный код NASM:

       ; Disassembly of file: main.o
; Tue May 22 11:34:20 2018
; Mode: 64 bits
; Syntax: YASM/NASM
; Instruction set: Pentium Pro, x64

default rel

global main

extern putchar                                          ; near
extern __printf_chk                                     ; near
extern __isoc99_scanf                                   ; near


SECTION .text                           ; section number 1, code


SECTION .data                       ; section number 2, data


SECTION .bss                         ; section number 3, bss

M:                                                      ; byte
        resq    500                                     ; 0000


SECTION .rodata.str1.1                ; section number 4, const

?_002:                                                  ; byte
        db 25H, 6CH, 64H, 00H                           ; 0000 _ %ld.

?_003:                                                  ; byte
        db 25H, 6CH, 64H, 20H, 00H                      ; 0004 _ %ld .


SECTION .text.unlikely                   ; section number 5, code


SECTION .text.startup                   ; section number 6, code

main:   ; Function begin
        push    r12                                     ; 0000 _ 41: 54
        push    rbp                                     ; 0002 _ 55
        mov     r12d, ?_001                             ; 0003 _ 41: BC, 00000000(d)
        push    rbx                                     ; 0009 _ 53
        mov     ebx, M                                  ; 000A _ BB, 00000000(d)
        mov     rbp, rbx                                ; 000F _ 48: 89. DD
; Filling space: 6H
; Filler type: Multi-byte NOP
;       db 66H, 0FH, 1FH, 44H, 00H, 00H

ALIGN   8
?_004:  mov     rsi, rbp                                ; 0018 _ 48: 89. EE
        xor     eax, eax                                ; 001B _ 31. C0
        mov     edi, ?_002                              ; 001D _ BF, 00000000(d)
        add     rbp, 8                                  ; 0022 _ 48: 83. C5, 08
        call    __isoc99_scanf                          ; 0026 _ E8, 00000000(rel)
        cmp     r12, rbp                                ; 002B _ 49: 39. EC
        jnz     ?_004                                   ; 002E _ 75, E8
        xor     eax, eax                                ; 0030 _ 31. C0
; Filling space: 6H
; Filler type: Multi-byte NOP
;       db 66H, 0FH, 1FH, 44H, 00H, 00H

ALIGN   8
?_005:  movsxd  rdx, eax                                ; 0038 _ 48: 63. D0
; Note: Address is not rip-relative
        mov     rcx, qword [abs M+rdx*8]                ; 003B _ 48: 8B. 0C D5, 00000000(d)
        lea     edx, [rax+1H]                           ; 0043 _ 8D. 50, 01
        movsxd  rdx, edx                                ; 0046 _ 48: 63. D2
        test    rcx, rcx                                ; 0049 _ 48: 85. C9
; Note: Address is not rip-relative
        mov     rsi, qword [abs M+rdx*8]                ; 004C _ 48: 8B. 34 D5, 00000000(d)
        jnz     ?_006                                   ; 0054 _ 75, 16
        test    rsi, rsi                                ; 0056 _ 48: 85. F6
        jnz     ?_006                                   ; 0059 _ 75, 11
        lea     edx, [rax+2H]                           ; 005B _ 8D. 50, 02
        movsxd  rdx, edx                                ; 005E _ 48: 63. D2
; Note: Address is not rip-relative
        cmp     qword [abs M+rdx*8], 0                  ; 0061 _ 48: 83. 3C D5, 00000000(d), 00
        jz      ?_007                                   ; 006A _ 74, 24
?_006:
; Note: Address is not rip-relative
        mov     rdx, qword [abs M+rcx*8]                ; 006C _ 48: 8B. 14 CD, 00000000(d)
; Note: Address is not rip-relative
        sub     rdx, qword [abs M+rsi*8]                ; 0074 _ 48: 2B. 14 F5, 00000000(d)
        test    rdx, rdx                                ; 007C _ 48: 85. D2
; Note: Address is not rip-relative
        mov     qword [abs M+rcx*8], rdx                ; 007F _ 48: 89. 14 CD, 00000000(d)
        js      ?_008                                   ; 0087 _ 78, 3F
        add     eax, 3                                  ; 0089 _ 83. C0, 03
        jmp     ?_005                                   ; 008C _ EB, AA

; Filling space: 2H
; Filler type: NOP with prefixes
;       db 66H, 90H

ALIGN   8
?_007:  mov     rdx, qword [rbx]                        ; 0090 _ 48: 8B. 13
        xor     eax, eax                                ; 0093 _ 31. C0
        mov     esi, ?_003                              ; 0095 _ BE, 00000000(d)
        mov     edi, 1                                  ; 009A _ BF, 00000001
        add     rbx, 8                                  ; 009F _ 48: 83. C3, 08
        call    __printf_chk                            ; 00A3 _ E8, 00000000(rel)
        cmp     rbx, ?_001                              ; 00A8 _ 48: 81. FB, 00000000(d)
        jnz     ?_007                                   ; 00AF _ 75, DF
        mov     edi, 10                                 ; 00B1 _ BF, 0000000A
        call    putchar                                 ; 00B6 _ E8, 00000000(rel)
        pop     rbx                                     ; 00BB _ 5B
        xor     eax, eax                                ; 00BC _ 31. C0
        pop     rbp                                     ; 00BE _ 5D
        pop     r12                                     ; 00BF _ 41: 5C
        ret                                             ; 00C1 _ C3

; Filling space: 6H
; Filler type: Multi-byte NOP
;       db 66H, 0FH, 1FH, 44H, 00H, 00H

ALIGN   8
?_008:  add     eax, 2                                  ; 00C8 _ 83. C0, 02
        cdqe                                            ; 00CB _ 48: 98
; Note: Address is not rip-relative
        mov     eax, dword [abs M+rax*8]                ; 00CD _ 8B. 04 C5, 00000000(d)
        jmp     ?_005                                   ; 00D4 _ E9, FFFFFF5F
; main End of function
...