-1

我们必须在汇编中编码,这您可能很难知道。或者教授没有给我们任何关于如何正确编码或链接的信息。我们必须自学。明天我必须交作业。目的是将第 n 个斐波那契数打印到控制台。

section .data
    fmt: db "fib=%d",10,0

section .text
extern _printf
global _main, fib

_main:
    mov eax, 10     ; e.g. n=10
    mov ebx, 1      ; we know f_0 and f_1
    sub eax, ebx    ; thats why n--
    push eax        ; push n
    push 0      ; f_0 = 0 
    push 1      ; f_1 = 1

    call fib

    push eax        ; in eax the result is stored
    push fmt
    call _printf

    mov ebx, 0
    mov eax, 1      ; exit(0)
    int 0x80    


fib:
    mov ecx, eax
    pop esi
    calc:
    pop ebx
    pop edx
    add ebx, edx
    mov eax, ebx
    push edx
    push ebx
    sub ecx, 1
    cmp ecx, 0
    jne calc
    push esi
    ret

在与链接器斗争之后,我终于设法组装和链接我的程序。但它不起作用 - 我每次都会遇到分段错误。

编辑: 更正的代码 - 我在控制台上得到了一些文本,但遗憾的是没有正确的数字它总是显示“fib = 1”并再次出现段错误。

4

2 回答 2

0

你有

push 0      ; f_0 = 0 
push 1      ; f_1 = 1

call fib

然后

fib:
    mov ecx, eax
    calc:
    pop ebx
    pop edx

你不能这样做——调用指令会将返回地址压入堆栈,这是你将在 fib 中弹出的第一件事。

于 2012-05-29T22:41:14.573 回答
0

我没有发现组装很难,而是我发现它简单直接。如果您的老师没有正确地教您,您最好在互联网上搜索信息。几年前,当我们大多数人开始工作时,没有那么多信息,所以我们通过反复试验来学习。

我建议您从简单开始并了解堆栈。将此用作工作示例:

 extern printf
    section .data
    msg:    db "Your sum is %d",10 ,0

    section .text
    global _start

    _start:
        push    20
        push    2
        push    6
        call    AddEm

        push    eax
        push    msg
        call    printf
        add     esp, 4 * 2  ; printf is C calling convention, we have to adjust stack

        mov     ebx, 0
        mov     eax, 1      ; exit(0)
        int     0x80    

    AddEm:
        push    ebp     ; set up a stack frame
        mov     ebp, esp    ; we could just use esp but we won't

        mov     eax, [ebp + 8]  ; 1st param - 6
        add     eax, [ebp + 12] ; 2nd param - 2
        add     eax, [ebp + 16] ; 3rd param - 20

        mov     esp, ebp    ; restore the stack
        pop     ebp
        ret     4 * 3       ; passed 3 params, clean up stack

这就是我组装、链接和输出的方式。

截屏

于 2012-05-30T03:12:33.767 回答