繁体   English   中英

MIPS程序集中的内存寻址

[英]Memory addressing in MIPS assembly

我最近正在阅读Patterson和Hennessy的书“计算机组织与设计”,以研究一些汇编。 我碰到了一节,其中解释了lwsw机器指令,以及它们如何将16位立即数作为加载/存储地址。 作者在此处指出的是:“ 16位地址意味着装载字指令可以在基址寄存器rs中的地址的8192字区域内装载任何字”。

我的问题是:

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

这是否意味着所有寄存器的地址彼此隔开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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM