[英]How to use an array in RISC-V Assembly
我正在学习 RISC-V 汇编,我需要将数组用于我正在解决的练习; 问题是我正在使用的模拟器( RARS )给了我一个错误:
Error in /home/username/file_name line 8: Runtime exception at 0x00400010: address out of range 0x000003e8.
这是我到目前为止编写的代码:
.data
arr: .word 1000
e0: .word 5
.text
lw t1, arr # load arr into t1
lw t2, e0 # Load e0 value into t2
sw t2, 0(t1) # save t2 value into arr[0]
我在做什么错?
指令sw t2, 0(t1)
将寄存器t2
的内容存入寄存器t1
提供的内存地址中。 但是, t1
不包含与标签arr
对应的地址——存储值1000
的地址——因为t1
是由指令lw t1, arr
初始化的,这会将与arr
对应的地址的内容加载到t1
,即,它将值1000
加载到t1
。
相反,将lw t1, arr
替换为la t1, arr
,这arr
表示的地址加载到t1
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.