以下是一本书(Introduction to 64 Bit Intel Assembly Language Programming for Linux,Seyfarth,2012 年)第 9 章中的程序。故障(在 gdb 中)是:
程序收到信号 SIGSEGV,分段错误。0x00007ffff7aa10a5 in __printf_size (fp=0x400400, info=0x0, args=) at printf_size.c:199 199 printf_size.c: 没有这样的文件或目录。
直到本章,我成功地使用以下内容“生成目标文件”,如推荐的那样,
yasm -f elf64 -g dwarf2 -l exit.lst exit.asm
进而,
ld -o prgm prgm.o
这是从书中复制的程序(l 10 push rbp; 我首先rem'd ; 但结果相同):
segment .text
global main
extern printf
; void print_max ( long a, long b )
; {
a equ 0
b equ 8
print_max:
push rbp; ;normal stack frame
mov rbp, rsp
; leave space for a, b and max
sub rsp, 32
; int max;
max equ 16
mov [rsp+a], rdi ; save a
mov [rsp+b], rsi ; save b
; max = a;
mov [rsp+max], rdi
; if ( b > max ) max = b;
cmp rsi, rdi
jng skip
mov [rsp+max], rsi
skip:
; printf ( "max(%1d,%1d ) = %1d\n",
; a, b, max );
segment .data
fmt db 'max(%1d,%1d) = %1d',0xa,0
segment .text
lea rdi, [fmt]
mov rsi, [rsp+a]
mov rdx, [rsp+b]
mov rcx, [rsp+max]
call printf
; }
leave
ret
main:
push rbp
mov rbp, rsp
; print_max ( 100, 200 );
mov rdi, 100 ;first parameter
mov rsi, 200 ;second parameter
call print_max
xor eax, eax ;to return 0
leave
ret
在本章中的前一个程序(“Hello World”示例)发生类似的分段错误之后,我使用了
gcc -o prgm prgm.o
在这个程序之前一直有效。