它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
C.LH (Zcb, CLH格式)从rs1'加零扩展偏移加载一个半字到rd',结果符号扩展到XLEN位。rd'和rs1'仅限x8-x15。展开为lh rd',uimm(rs1')。偏移为1位无符号×2。属于Zcb,依赖Zca。
C.LH 是 压缩有符号半字加载 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 C 扩展规则理解。
结合 «c.lh x9, 2(x10) # sign-extended halfword load» 等实际代码理解该场景。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。