RV32C指令集

Risc-V支持16位压缩格式,压缩格式立即数位数更少,能使用的寄存器也比较少,有些指令只能用常用8个整数寄存器(x8-x15)或者(f8-f15)。

每个RVC指令都有对应的32位指令,下表列出所有的RV32C指令。

指令分组 Fmt 16位指令 对应32位指令 机器码
stack-point based loads and stores,这些指令可以使用所有的通用寄存器作为操作数   c.lwsp rd, offset[7:2] lw rd, offset[7:2](x2) 010[12,uimm[5]][11-7,rd!=0][6-2,uimm[4:2|7:6]10
  c.flwsp rd, offset[7:2] flw rd, offset[7:2](x2) 011[12,uimm[5]][11-7,rd][6-2,uimm[4:2|7:6]10
  c.fldsp rd, offset[8:3] fld rd, offset[8:3](x2) 001[12,uimm[5]][11-7,rd][6-2,uimm[4:3|8:6]10
  c.swsp rd, offset[7:2] sw rs2, offset[7:2](x2) 110[12-7,uimm[5:2][7:6]][6-2,rs2]10
  c.fswsp rd, offset[7:2] fsw rs2, offset[7:2](x2) 111[12-7,uimm[5:2][7:6]][6-2,rs2]10
  c.fsdsp rd, offset[8:3] fsd rs2, offset[8:3](x2) 101[12-7,uimm[5:3][8:6]][6-2,rs2]10
register-based loads and stores,此指令只能使用常用的8个寄存器作为操作数,其中c.flw/c.fld的rd和c.fsw/c.fsd 的rs2位通用浮点寄存器   c.lw rd, offset[6:2](rs1) lw rd, offset[6:2](rs1) 010[12-10,uimm[5:3]][9-7,rs1'][6-5,uimm[2|6]][4-2,rd']00
  c.flw rd, offset[6:2](rs1) flw rd, offset[6:2](rs1) 011[12-10,uimm[5:3]][9-7,rs1'][6-5,uimm[2|6]][4-2,rd']00
  c.fld rd, offset[7:3](rs1) fld rd, offset[7:3](rs1) 001[12-10,uimm[5:3]][9-7,rs1'][6-5,uimm[7:6]][4-2,rd']00
  c.sw rs2, offset[6:2](rs1) sw rs2, offset[6:2](rs1) 110[12-10,uimm[5:3]][9-7,rs1'][6-5,uimm[2|6]][4-2,rd']00
  c.fsw rs2, offset[6:2](rs1) fsw rs2, offset[6:2](rs1) 111[12-10,uimm[5:3]][9-7,rs1'][6-5,uimm[2|6]][4-2,rd']00
  c.fsd rs2, offset[7:3](rs1) fsd rs2, offset[7:3](rs1) 101[12-10,uimm[5:3]][9-7,rs1'][6-5,uimm[7:6]][4-2,rd']00
control transfer instruction   c.j offset[11:1] jal x0,offset[11:1] 101[12-2,imm[11|4|9:8|10|6|7|3:1|5]01
  c.jal offset[11:1] jal x1,offset[11:1] 001[imm[11]4|9:8|10|6|7|3:1|5]01
可以使用所有通用寄存器作为操作数 c.jr rs1 jalr x0, rs1, 0 1000[11-7,rs1!=0]0000010
c.jalr rs1 jalr x1,rs1,0 1001[11-7,rs1!=0]0000010
只能使用8个最为常用的通用寄存器作为操作数 c.beqz rs1 offset[8:1] beq rs1, x0, offset[8:1] 110[12-10,imm[8:4:3][9-7,rs1'][6-2,imm[7:6|2:1|5]01
c.bnez rs1 offset[8:1] bne rs1, x0, offset[8:1] 111[12-10,imm[8:4:3][9-7,rs1'][6-2,imm[7:6|2:1|5]01
整数计算指令 可以使用所有通用寄存器作为操作数 c.li rd, imm[5:0] addi rd, x0, imm[5:0] 010[12,imm[5]][11-7,rd!=0][6-2,imm[4:0]]01
c.lui rd, nzuimm[17:12] lui rd, nzuimm[17:12] 011[12,imm[17]][11-7,rd!=0,2][6-2,nzimm[16:12]]01
c.addi rd, nzimm[5:0] addi rd, rd, nzimm[5:0] ’000[12,nzimm[5]][11-7,rs1/rd!=0][6-2, nzimm[4:0]]01
  c.addi16sp nzimm[9:4] addi x2, x2, nzimm[9:4] ’011[12,nzimm[9]][11-7,2][6-2, nzimm[4|6|8:7|5]]01
只能使用8个最为常用的通用寄存器作为操作数 c.addi4spn rd, nzuimm[9:2] addi rd, x2, nzuimm[9:2] 000[12-5,nzuimm[5:4|9:6|2|3][4-2,rd']00
可以使用所有通用寄存器作为操作数 c.slli rd, shamt[5:0] slli rd, rd, shamt[5:0] 000[12,nxuimm[5]][11-7,rs1/rd!=0][6-2,nzuimm[4:0]]10
只能使用8个最为常用的通用寄存器作为操作数 c.srli rd,rd, shamt[5:0] srli rd, rd,shamt[5:0] ’100[12,nzimm[5]]00[9-7,rs'/rd'][6-2, nzimm[4:0]]01
c.srai rd,shamt[5:0] srai rd, rd,shamt[5:0] ’100[12,nzimm[5]]01[9-7,rs'/rd'][6-2, nzimm[4:0]]01
c.andi rd, imm[5:0] andi rd, rd,shamt[5:0] ’100[12,nzimm[5]]10[9-7,rs'/rd'][6-2, nzimm[4:0]]01
可以使用所有通用寄存器作为操作数 c.mv rd rs2 add rd, x0, rs2 1000[11-7,rd!=0][6-2,rs2!=0]10
c.add rd rs2 add rd, rd, rs2 1001[11-7,rs1/rd!=0][6-2,rs2!=0]10
只能使用8个最为常用的通用寄存器作为操作数 c.and rd rs2 and rd, rd, rs2 100011[9-7,rs1'/rd']11[4-2,rs2']01
c.or rd rs2 or rd, rd, rs2 100011[9-7,rs1'/rd']10[4-2,rs2']01
c.xor rd rs2 xor rd, rd, rs2 100011[9-7,rs1'/rd']01[4-2,rs2']01
c.sub rd rs2 sub rd, rd, rs2 100011[9-7,rs1'/rd']00[4-2,rs2']01
NOP指令 和32位对应的一样 c.nop add x0, x0, 0 ‘0000000000000001
断点指令   c.ebreak ebreak 1001000000000010


image

image

image

image


猜你喜欢

转载自www.cnblogs.com/mikewolf2002/p/9884789.html
今日推荐