我在进行鼻练习时遇到一些问题。我有一条消息说“分段错误(核心已转储)”,我想知道是否有人会帮助我 我正在尝试很多事情,但仍然无法解决问题。 希望有人能帮助我实现真正的哈哈
这是我目前的代码:
section .data
a1: dd 83
resultado: dw 0
section .text
global _start
start:
mov ebx,a1
mov ax,[ebx]
xor dx,dx
push dx
push ax
push dx
push dx
push dx
call redon5
pop dx
pop dx
pop dx
pop dx
pop dx
mov ebx,resultado
mov [ebx],dx
mov ebx,0 ; exit code, 0=normal
mov eax,1 ; exit command to kernel
int 0x80 ; interrupt 80 hex, call kernel
redon5:
mov ebp,esp ; "sincroniza" el base pointer
mov ax,[ebp + 10] ; pone en ax el argumento "p"
mov dx,10
div dx ; separa unidades de decenas (q y r)
cmp ax,3
jge intervalo_2
mov word [ebp + 4],0 ; k1 = 0
mov word [ebp + 2],0 ; k2 = 0
jmp fin_de_if
intervalo_2:
cmp ax,8
jge intervalo_3
mov word [ebp + 4],5 ; k1 = 5
mov word [ebp + 2],0 ; k2 = 0
jmp fin_de_if
intervalo_3:
mov word [ebp + 4],0 ; k1 = 0
mov word [ebp + 2],10 ; k2 = 10
fin_de_if:
mov dx,[ebp + 10] ; vuelve a recuperar p
sub dx,ax ;dx <-- p - r
add dx,[ebp + 4] ;dx <-- (p-r) + k1
add dx,[ebp + 2] ;dx <-- (p-r) + k1 + k2
mov [ebp + 8],dx ; valor de retorno de la función
ret
答案 0 :(得分:0)
我没有很高的声誉来添加评论,但是(假设您使用elf64是因为您试图在64位系统上运行32位代码)尝试使用:
nasm -f elf64 -g -F stabs test.asm
ld -o test test.o
或
nasm -f elf -g -F stabs test.asm
ld -o test test.o -melf_i386
大约在页面的一半以下:http://duntemann.com/assembly.html 进行一些解释。
“-g”后跟“ -F stabs”将产生可在gdb调试器中使用的输出,并真正找出seg-fault在程序^ _ ^中的位置(如Sami所示)。设置一些断点,并在gdb中使用“ stepi”来查找问题。