它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
将非零6位立即数加载到rd[17:12],低12位清零,符号扩展。CI格式。
C.LUI (CI格式)将非零6位立即数加载到rd的bit 17:12,低12位清零,bit 17符号扩展到所有更高位。展开为lui rd,imm。rd≠{x0,x2}且imm≠0;rd=x0且imm≠0时为HINT;rd=x2且imm≠0对应C.ADDI16SP。
C.LUI 是 压缩高位立即数加载 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 C 扩展规则理解。
结合 «c.lui x10, 1 # x10 = 0x00001000» 等实际代码理解该场景。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。