Y86代码 - 不返回或显示rax

时间:2016-10-09 22:31:29

标签: assembly x86-64 y86

我正在做一个类项目,我将采用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;
}

1 个答案:

答案 0 :(得分:2)

查看代码,似乎指向节点的指针应为16(rbp),而不是24(rbp)。 0(rbp)=保存的rbp值,8(rbp)=返回地址,16(rbp)=指向节点的指针(到链表)。在保存rbp之前,我没有看到额外的8个字节被压​​入堆栈的位置。

程序以暂停指令结束。你是否能够确定rax的内容(例如使用调试器)?