C到NIOS II计划

时间:2015-04-16 14:17:21

标签: computer-architecture intel-fpga nios

我需要在NIOS II汇编代码中编写以下C代码。并从L1标签知道堆栈状态。

struct lelt 
{
   int value; 
   struct lelt* next;
}

struct lelt x = {3,NULL};

lelt* get_tail(lelt *ptr)
{
   lelt* last; 
   L1: last = NULL; 
   while(ptr != NULL)
   {
      last = ptr; 
      ptr = ptr -> next; 
   }
   return last; 
}

这是我到目前为止所写的内容,但我不知道如何管理编写其余代码,因为我不太熟悉汇编代码中的结构。所以,如果有人可以帮我解释一下,我会很感激。

x: 
 value .word 3
 next .word 0
get_tail: 
 subi sp, sp,12
 stw ra, 0(sp) 
 stw r16, 4(sp) // ptr
 stw r17, 8(sp) // last
 movia r16,zero,r4
 bne r4,zero,endwhile
 add r17,zero,r16
 ... // i don't know how to write ptr=ptr->next 
endwhile: 
 add r2,r17,zero
 br end
end: 
 ldw ra,0(sp)
 ldw r16,4(sp)
 ldw r17,8(sp) 
 addi sp,sp,12
 ret 

1 个答案:

答案 0 :(得分:1)

所以我猜r16是你的ptr。结构中的next成员位于偏移4。要将其加载到ptr,只需执行ldw r16, 4(r16)