首页/指令库/C-ZEXT-W
C.ZEXT.W

RISC-V C.ZEXT.W 指令详解

指令手册C-type

16位编码的零扩展字(RV64:低32位零扩展)

指令语法

c.zext.w rsd'
操作数说明
压缩指令仅 16 位,寄存器选择通常限制在 x8–x15。
立即数字段较窄,查看特定压缩指令的完整编码。
Zcb压缩指令

指令行为说明

C.ZEXT.W (Zcb, CU 格式,仅 RV64) 将 rsd' 的低 32 位零扩展到 64 位,rsd' 仅限 x8-x15。它需要 Zba 支持,等价于 32 位编码的 add.uw rd', rd', zero。注意 ADDIW/C.ADDIW 加 0 是 32 位符号扩展,不是零扩展。属于 Zcb,依赖 Zca 和 Zba。

快速理解与检索要点

C.ZEXT.W 是 压缩字零扩展 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 C 扩展规则理解。

C.ZEXT.W 的官方等价操作是 add.uw rd, rd, zero,用于低 32 位零扩展。
ADDIW/C.ADDIW +0 是 sign-extension 对比项,不是 zext.w 的替代实现。

常见使用场景

压缩与代码优化

结合 «c.zext.w x10 # x10 = EXTZ(x10[31:0]) (RV64)» 等实际代码理解该场景。

使用前检查清单

语法检查
  • 确认当前指令格式为 C-type。
  • 确认操作数排列顺序与示例一致。
语义检查
  • 确认目标寄存器用途和调用约定兼容。
  • 确认该指令不是伪指令展开后的底层形式。

容易混淆 / 常见误区

仅 RV64 可用。
需要 Zba 支持,语义对应 add.uw rd, rd, zero。
不要用 ADDIW/C.ADDIW +0 解释为零扩展;那是 32 位符号扩展。
操作数仅限 x8-x15,高 32 位清零。

常见问题

它一定等价于同名 32 位指令吗?

不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。

为什么要关注寄存器限制?

许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。