我正在做一个类项目,我将采用C代码,在x86-64程序集中将其转换,然后将其更改为Y86。在此,我想将链表中的元素总和返回给rax。但是,当我尝试使用y86编译器时,它不会出现。我制作的y86看起来像这样:
.pos 0
irmovq Stack,%rsp
irmovq Stack,%rbp
jmp Main
Main:
irmovq ele1,%rax
pushq %rax
call sum_list
halt
sum_list:
pushq %rbp
rrmovq %rsp,%rbp
irmovq $24,%rdx
subq %rdx,%rsp
irmovq $0,%rdx
rmmovq %rdx,-8(%rbp)
jmp L2
L3:
mrmovq 24(%rbp),%rax
mrmovq (%rax),%rax
mrmovq -8(%rbp),%rdx
addq %rax,%rdx
rmmovq %rdx,-8(%rbp)
mrmovq 24(%rbp),%rax
mrmovq -8(%rax),%rax
rmmovq %rax,24(%rbp)
L2:
irmovq $0,%rcx
mrmovq 24(%rbp),%rdx
subq %rcx,%rdx
jne L3
mrmovq -8(%rbp),%rax
rrmovq %rbp,%rsp
popq %rbp
ret
#linked-list
.align 8
ele1:
.quad 0x00d
.quad ele2
ele2:
.quad 0x0e0
.quad ele3
ele3:
.quad 0xf00
.quad 0
.pos 0x500
Stack:
所以rax
应该有0xfed,但在我的结果中,没有任何内容出现。
这是我从中得到的C代码:
typedef struct ELE{
long val;
struct ELE *next;
} *list_ptr
long sum_list(list_ptr ls){
long val = 0;
while(ls){
val += ls->val;
ls = ls->next;
}
return val;
}
答案 0 :(得分:2)
查看代码,似乎指向节点的指针应为16(rbp),而不是24(rbp)。 0(rbp)=保存的rbp值,8(rbp)=返回地址,16(rbp)=指向节点的指针(到链表)。在保存rbp之前,我没有看到额外的8个字节被压入堆栈的位置。
程序以暂停指令结束。你是否能够确定rax的内容(例如使用调试器)?