它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
16位编码的mul指令,取乘积低XLEN位
C.MUL (Zcb, CA格式)将rsd'和rs2'相乘,结果低XLEN位写入rsd'。rd'和rs2'仅限x8-x15。需要M或Zmmul支持。展开为mul rsd',rsd',rs2'。属于Zcb,依赖Zca和M/Zmmul。
C.MUL 是 压缩乘法 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 C 扩展规则理解。
结合 «c.mul x10, x11 # x10 = (x10 * x11)[XLEN-1:0]» 等实际代码理解该场景。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。