ZIP

RISC-V ZIP 指令详解

指令手册I-type

RV32 位交错(Zbkb),仅 RV32 定义。

指令语法

zip rd, rs1
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数所在的寄存器。
立即数 imm:12 位有符号立即数,符号扩展后与 rs1 进行运算。
Zbkb位操作

指令行为说明

ZIP(Zbkb,RV32-only)把源寄存器低 16 位和高 16 位交错到目标寄存器:对 i=0..15,rd[2*i]=rs1[i],rd[2*i+1]=rs1[i+16]。它是 UNZIP 的逆操作,常用于 32 位架构上的 SHA3 位交错优化。

快速理解与检索要点

ZIP 是 Zbkb 密码位操作指令;页面按官方 B 扩展的操作定义校对。

官方只给出 RV32 编码和语义。
该类指令重排位/字节字段,不访问内存。

常见使用场景

位操作与掩码

结合 «zip a0, a1» 等实际代码理解该场景。

信号处理与DSP

结合 «zip a0, a1» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

ZIP 仅在 RV32 定义;RV64 没有该指令。
偶数位来自源低半,奇数位来自源高半;不要与字节 shuffle 混淆。
该指令仅 RV32 定义;RV64 没有对应形式。

常见问题

ZIP 是否访问内存?

不访问。它只在整数寄存器内重排位字段或查表。

ZIP 属于哪个扩展?

它属于 Zbkb 密码位操作扩展。