它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
将ra和s0-s11保存到栈并调整sp
CM.PUSH (Zcmp)将{reg_list}中的寄存器(ra及最多12个s寄存器)推入栈帧,并调整sp(减stack_adj)。stack_adj = stack_adj_base + spimm×16。复用c.fsdsp编码,因此与Zcd不兼容。操作可能多次执行(支持故障恢复),sp调整原子提交。属于Zcmp,依赖Zca。
CM.PUSH 是 压缩多寄存器压栈 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 Zc 扩展规则理解。
使用 jal ra, label 或 jalr ra, rs, imm。
结合 «cm.push {ra, s0-s5}, -64 # save ra,s0-s5, sp-=64» 等实际代码理解该场景。
结合 «cm.push {ra, s0-s5}, -64 # save ra,s0-s5, sp-=64» 等实际代码理解该场景。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。