Создание и вызов функции в сборке x86 (синтаксис AT&T)
Пожалуйста, дайте мне очень простой пример создания функции и вызова ее в сборке x86 (синтаксис AT&T). На самом деле я пытаюсь создать функцию, которая вычисляет factorial
из числа. Вот что я все сделал:
#include<syscall.h>
#include<asm/unistd.h>
# Calculates Factorial, Argument is passed through stack
.text
.global _start
_start:
pushl $5 #factorial of this value will be calculated
call Fact
movl %eax, %ebx #eax contains the result, Result is the return val of the program
movl $1, %eax
int $0x80
ret
Fact:
popl %ebx #Return address
popl %edx
movl $1, %ecx #Will be used as a counter
movl $1, %eax #Result(Partial & complete) will be stored here
LOOP:
mul %ecx
inc %ecx
cmp %ecx, %edx
jle LOOP
pushl %ebx #Restore the return address
ret
я получаю Segmentation Fault
ошибка снова и снова. Я использую ГАЗ на Ubuntu
,
1 ответ
Решение
Ваш код не должен падать. Убедитесь, что вы собрали и связали как 32 бита:
as --32 -o x.o x.s
ld -melf_i386 -o x x.o
Код неверный однако. Особенно:
- 'mul% ecx' изменяет%edx
- аргументы 'cmp' должны быть изменены
Вот исправленная версия:
.text
.global _start
_start:
pushl $5
call fact
addl $4, %esp
movl %eax, %ebx
movl $1, %eax # sys_exit
int $0x80
fact:
movl 4(%esp), %ecx
movl $1, %eax
1:
mul %ecx
loop 1b
ret
Запустите это с:
./x; echo $?