PicoRV32的配置选项,有以下:
module picorv32 #(
parameter [ 0:0] ENABLE_COUNTERS = 1,
parameter [ 0:0] ENABLE_COUNTERS64 = 1,
parameter [ 0:0] ENABLE_REGS_16_31 = 1,
parameter [ 0:0] ENABLE_REGS_DUALPORT = 1,
parameter [ 0:0] LATCHED_MEM_RDATA = 0,
parameter [ 0:0] TWO_STAGE_SHIFT = 1,
parameter [ 0:0] BARREL_SHIFTER = 0,
parameter [ 0:0] TWO_CYCLE_COMPARE = 0,
parameter [ 0:0] TWO_CYCLE_ALU = 0,
parameter [ 0:0] COMPRESSED_ISA = 0,
parameter [ 0:0] CATCH_MISALIGN = 1,
parameter [ 0:0] CATCH_ILLINSN = 1,
parameter [ 0:0] ENABLE_PCPI = 0,
parameter [ 0:0] ENABLE_MUL = 0,
parameter [ 0:0] ENABLE_FAST_MUL = 0,
parameter [ 0:0] ENABLE_DIV = 0,
parameter [ 0:0] ENABLE_IRQ = 0,
parameter [ 0:0] ENABLE_IRQ_QREGS = 1,
parameter [ 0:0] ENABLE_IRQ_TIMER = 1,
parameter [ 0:0] ENABLE_TRACE = 0,
parameter [ 0:0] REGS_INIT_ZERO = 0,
parameter [31:0] MASKED_IRQ = 32'h 0000_0000,
parameter [31:0] LATCHED_IRQ = 32'h ffff_ffff,
parameter [31:0] PROGADDR_RESET = 32'h 0000_0000,
parameter [31:0] PROGADDR_IRQ = 32'h 0000_0010,
parameter [31:0] STACKADDR = 32'h ffff_ffff
)
ENABLE_COUNTERS :使能计数器,缺省设置为1。
ENABLE_COUNTERS64:使能计数器,缺省设置为1。PicoRV32中计数器。如果只使能ENABLE_COUNTERS,则计数器为32位,如果使能ENABLE_COUNTERS64则计数器 为64位。计数器可配置为32位和64位,
配置为32位时,ENABLE_COUNTERS=1,ENABLE_COUNTERS64=0,支持指令RDCYCLE,RDTIME,RDINSTRET
配置为64位时,ENABLE_COUNTERS=1,ENABLE_COUNTERS64=1,支持指令RDCYCLEH,RDTIMEH,RDINSTRETH
禁用计数器,ENABLE_COUNTERS=0,ENABLE_COUNTERS64=1'bx,如果出现读计数器的指令,会导致硬件异常,和未实现指令异常一样。在RV32E这个功能是可选的。
ENABLE_REGS_16_31 :,缺省设置为1。是否使能x16-x31寄存器,在RV32E架构体系中不包含x16-x31寄存器。不使能这些寄存器可以节省面积。对于FPGA来说如果使用双口RAM来实现寄存器,FPGA中的RAM块都很大,32个32位寄存器为32x32bit=1024bit,例如altera的ram块M9K,远远大于1024bit。所以在使用FPGA实现的时候,使能此选项不会导致面积大幅度增加。
ENABLE_REGS_DUALPORT:缺省设置为1。使用双端口RAM实现寄存器,如果操作数1和操作数2都为寄存器,这样就可以在一个周期同时取出寄存器1和寄存器2,如果不使能此选项则需要两个周期取出操作数1和操作数2。此选项可以提高CPI,从而提高处理器性能。
LATCHED_MEM_RDATA:缺省设置为0,
TWO_STAGE_SHIFT:缺省设置为1。默认情况先移位操作分成两个步骤,第一先以4bit为单位移位,第二,以1bit为单位移位,这种方式加快了移位操作,但是添加额外的面积。禁用此选项,减小面积,但是对应的速度降低。
BARREL_SHIFTER:桶形移位器,缺省设置为0。
TWO_CYCLE_COMPARE:缺省设置为0,添加寄存器把长的组合逻辑打散。
TWO_CYCLE_ALU:缺省设置为0,在ALU添加寄存器,降低时序要求。
COMPRESSED_ISA:缺省设置为0,支持RV32C指令集,即压缩指令
CATCH_MISALIGN:缺省设置为1,捕获存储器访问的地址未对齐异常。
CATCH_ILLINSN:缺省设置为1,捕获非法指令异常。
ENABLE_PCPI:缺省设置为0,协处理器接口选择。
ENABLE_MUL:缺省设置为0,使能乘法指令,RV32M
ENABLE_FAST_MUL:缺省设置为0,使能快速乘法指令,RV32M
ENABLE_DIV:缺省设置为0,使能除法指令,RV32M,支持指令DIV[U],REM[U]
乘法指令和除法指令的支持都是通过pcpi接口实现
乘法指令配置,支持指令MUL[H[SU|U]]
ENABLE_FAST_MUL=1,ENABLE_MUL=x :使能快速乘法模块
ENABLE_FAST_MUL=0,ENABLE_MUL=1:使能普通乘法模块
ENABLE_FAST_MUL=0,ENABLE_MUL=0:禁止乘法指令
ENABLE_IRQ:缺省设置为0,使能中断
ENABLE_IRQ_QREGS:缺省设置为1,支持IRQ的4个寄存器q0-q3.支持getq,setq指令。如果不支持q0-q3寄存器,则发生中断时,picorv32的寄存器
x3(gp)用于存储中断返回地址,中断屏蔽字在x4(tp).
ENABLE_IRQ_TIMER:缺省设置为1,支持定时器的指令。
ENABLE_TRACE:缺省设置为0。
REGS_INIT_ZERO:缺省设置为0,把CPU的寄存器上电默认设置为0,便于仿真。
MASKED_IRQ:中断屏蔽,每一位屏蔽一个中断,总共32个中断
LATCHED_IRQ:
PROGADDR_RESET:上电第一条指令所在的地址
PROGADDR_IRQ:中断处理函数的地址
STACKADDR:当此值不是0xffff_ffff的时候,寄存器x2(栈指针)将在复位的时候载入此值,这个值必须16字节对齐。