我正在使用riscv代码,我想使用尖峰工具来模拟它。模拟的目的是查看一些浮点寄存器的内容。
所以,如果我想看一个整数寄存器的内容,我使用下一个命令:
reg 0 s0
但如果我尝试对浮点寄存器使用相同的命令:
reg 0 ft0
它总是向我显示设置为零的所有位............
我附上了一些我正在使用的汇编代码......
10164: 0000f053 fadd.s ft0,ft1,ft0
10168: fe042227 fsw ft0,-28(s0)
在代码的这个片段中,我使用命令reg来查看浮点数寄存器ft1和ft0(reg 0 ft1或reg 0 ft0)之后的内容 fadd.s指令,结果是:
core 0: 0x0000000000010164 (0x0000f053) fadd.s ft0, ft1, ft0
: reg 0 ft0
0x0000000000000000
但如果我在执行fsw指令后查找保存在内存中的内容,结果不为零且正确
core 0: 0x0000000000010168 (0xfe042227) fsw ft0, -28(s0)
: mem 0 7fffff04
0x0000000040e00000
正如您所看到的,问题是为什么使用reg命令查看浮点寄存器的内容总是将零作为寄存器的内容。 reg格式和浮点寄存器有问题吗?
答案 0 :(得分:1)
对于浮点寄存器,必须使用命令fregs
或fregd
,具体取决于您是希望将值表示为单精度值还是双精度值。