0

我最近正在阅读 Patterson 和 Hennessy 的书《计算机组织与设计》,以学习一点汇编。我遇到了一个部分,其中解释了lwsw机器指令以及它们如何将 16 位立即数作为加载/存储地址。作者在这里指出的是:“16 位地址意味着加载字指令可以加载基址寄存器rs中地址的 [...] 8192 个字的区域内的任何字”。

我的问题是:

  • 这是否意味着所有寄存器的地址都相隔 8192 个字?
  • 另外,这是否意味着整个可用内存为 32 * 8192 = 262144 个字?
4

1 回答 1

4

这是否意味着所有寄存器的地址都相隔 8192 个字?

不,寄存器没有地址。

另外,这是否意味着整个可用内存为 32 * 8192 = 262144 个字?

不,这些立即数是用于加载/存储的基地址的偏移量。它允许您在基地址的 -32768..+32767 字节内指定地址。32768/sizeof(word) == 8192。如果你想超出这个范围,你可以简单地改变基址寄存器的值。
寄存器的数量与您可以寻址的内存量无关。

例如:

li $a0,0       # set $a0 to 0
lw $t0,0($a0)  # load a word from address 0
lw $t0,8($a0)  # load a word from address 8

lui $a0,0xffff # set the upper half-word of $a0 to 0xffff
lw $t0,4($a0)  # load a word from address 0xffff0004
于 2013-04-16T14:35:38.100 回答