gpt4 book ai didi

assembly - 为 sw MIPS 汇编指令指定一个参数?

转载 作者:行者123 更新时间:2023-12-01 10:24:35 27 4
gpt4 key购买 nike

我正在为计算机体系结构类(class)学习 MIPS 汇编。对于本类(class),该类(class)使用 MARS。在将十个数字放入数组中进行分配时,我决定测试一些东西。我想看看我是否可以创建一个循环,自动将用户输入的整数压入堆栈。到目前为止,这是我的代码:

 # For loop initialization
li $s0, 0 # Set $s0 equal to zero.
li $sp, -40 # Reserve space for 10 integers on the stack.
li $t0, 0 # temp var to increment stack offset.
# Stores ten user inputted numbers onto the stack.
stackLoop:
beq $s0, 10, doneStack
li $v0, 51
la $a0, prompt
syscall
sw $t0($sp)
# Print out stack values.
li $v0, 1
lw $0($sp)
syscall
addi $t0, $t0, 4
addi $s0, $s0, 1
j stackLoop
doneStack:

当我到达 sw 指令时遇到问题,当我指定两个参数时抛出错误,因为 $t0($sp) 无效。但是,如上所示,仅指定一个参数似乎有效。在开始这个工作之前,我问过我的教授,他说这是不可能的。为什么只使用一个参数有效?我的结论是 sw 必须默认存储 $v0。但是,这并不能成为语法的借口。例如,键入 sw $v0, $t0($sp) 会在编译时引发错误。

同样,为什么在使用 $0($sp) 时 lw 起作用?我猜 lw 默认加载到 $a0,这可以解释为什么 li $v0, 1 有效。但是,如果是这样,为什么 lw $a0, 0($sp) 会产生 4 的增量,即一个字中的字节数?它不会引用 0($sp) 处的数据,该数据在每次迭代时从堆栈中弹出吗?

我查看了一些文档,但所有文档都使用两个参数 sw 和 lw。我类的教科书甚至没有提到我在上面所做的事情是可能的。为中篇小说风格的帖子道歉,但我的好奇心被激起了。

最佳答案

MARS 使用非常简单的解析器和更简单的分词器。
分布式JAR中,源文件可用,想哭的可以看看Java类mars.mips.instructions.InstructionSet
由于 MARS 的本质:教育 模拟器,这是完全可以接受的。

分词器将文本分成空格(但是,输入首先分行)、逗号和括号的分词。
因此这些语法都是等价的:

sw $t0($sp)
sw $t0 ($sp)
sw $t0, ($sp)

没有在 MIPS ISA 中 swlw(或任何其他指令)的默认寄存器。

这对每条指令都是正确的,但是,尊重 RISC 思想,只有 lwsw(和兄弟)可以有括号(因为它们表示寻址模式)从而缓解问题(仍然可以使用 或 $t0 $t0 $t1 之类的东西)。

最后,sw $v0, $t0($sp) 在 MIPS 中不可编码。
sw 这是一个 I-type instruction ,因此它有一个源寄存器(t),一个基址寄存器(s)和一个16位立即数(i):

101011 ttttt sssss iiiiiiiiiiiiiiii

TL;DR:sw $t0($sp) 只是一个 MARS 工件。

关于assembly - 为 sw MIPS 汇编指令指定一个参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48726133/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com