我不确定您显示的两个描述的行为是否完全相同。它们似乎是不同的实现。
在他们的文档中出现的 Imagination 的 MIPS 的实现如下(在 SystemVerilog 语法中,假设 GPR 寄存器是 32 位):
if ({1'b0 , GPR[rs]} < {1'b0 , sign_extend(immediate)}
GPR[rd] = 32'h00000001;
else
GPR[rd] = 32'h00000000;
请注意,这是一个 33 位比较,其中第 33 位为 0,因此是无符号比较。
另外,请注意:
sign_extend(immediate) returns: { {16{immediate[15]}}, immediate }
这意味着立即数首先被视为有符号数,即 15 位值,第 16 位是符号。所以:
If immediate >=0, then sign_extend(immediate) is in [0,32767].
另一方面,如果立即数是负数,我们将有:
sign_extend(immediate) = { {16{1'b1}}, 1'b1, immediate[15:0] }, which is in [32'hFFFFFFFF-32767, 32'hFFFFFFFF]
其中 32'hFFFFFFFF 称为 max_unsigned。
基本上,这条指令使您能够在 GPR[rs] 和[0,32767] 或 [32'hFFFFFFFF-32767, 32'hFFFFFFFF] 中的无符号数之间执行无符号比较。
第二种实现在 GPR[rs] 和 [0,65535] 之间执行无符号比较。
编辑:
请注意,在 SLTI 和 SLTIU 中,立即数是符号扩展的,但意图不同。在 SLTIU 中,被比较的两个数字被强制取消(通过添加第 33 位)。因此立即数的符号扩展启用了不同的比较范围:最小的 32767 个和最大的 32767 个无符号值,而不仅仅是 0 到 65535。符号扩展不是为了有符号比较的目的而进行的,因为可能会混淆。
然而,在 SLTI 中,立即数的符号扩展是出于不同的目的:将负值与正值进行比较(有符号比较)。