它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
对rd'进行逻辑右移。CB格式。
C.SRLI (CB格式,rd'仅限x8-x15)将rd'逻辑右移shamt位后写回rd'。展开为srli rd',rd',shamt。RV32C中shamt[5]必须为0。shamt=0时为HINT。
C.SRLI 是 压缩立即数逻辑右移 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 C 扩展规则理解。
结合 «c.srli x8, 2 # x8 >>= 2 (logical)» 等实际代码理解该场景。
结合 «c.srli x8, 2 # x8 >>= 2 (logical)» 等实际代码理解该场景。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。