0

LinuxでNASMを使用して、Cライブラリ(printf)から関数を呼び出す基本的なアセンブリプログラムを作成しています。残念ながら、そうしている間にセグメンテーション違反が発生しています。printfの呼び出しをコメントアウトすると、プログラムをエラーなしで実行できます。

; Build using these commands:
;   nasm -f elf64 -g -F stabs <filename>.asm 
;   gcc <filename>.o -o <filename>
;

SECTION .bss    ; Section containing uninitialized data

SECTION .data   ; Section containing initialized data

  text db "hello world",10 ; 

SECTION .text   ; Section containing code


global main

extern printf

;-------------
;MAIN PROGRAM BEGINS HERE
;-------------

main:



      push rbp

      mov rbp,rsp

      push rbx

      push rsi

      push rdi ;preserve registers

      ****************


      ;code i wish to execute

      push text ;pushing address of text on to the stack
      ;x86-64 uses registers for first 6 args, thus should have been:
      ;mov rdi,text (place address of text in rdi)
      ;mov rax,0 (place a terminating byte at end of rdi)

      call printf ;calling printf from c-libraries

      add rsp,8 ;reseting the stack to pre "push text"

      **************  

      pop rdi ;preserve registers

      pop rsi

      pop rbx

      mov rsp,rbp

      pop rbp

      ret
4

2 に答える 2

3

x86_64 は、最初の 6 つの引数にスタックを使用しません。それらを適切なレジスタにロードする必要があります。それらは:

rdi, rsi, rdx, rcx, r8, r9

memcpy最初の 2 つを覚えるために私が使用するトリックは、関数が次のように実装されていると想像することですrep movsb

于 2013-03-22T16:57:22.830 に答える
0

varargs 関数を呼び出しています -- printf は可変数の引数を想定しており、引数スタックでそれを考慮する必要があります。ここを参照してください: http://www.csee.umbc.edu/portal/help/nasm/sample.shtml#printf1

于 2013-03-22T16:48:21.433 に答える