PicoRV32 笔记 02

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字节对齐。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
江科大STM32笔记是关于STM32单片机的学习笔记,其中涵盖了一些关于按键初始化和按键读取的代码示例。在这些代码中,通过引用中的Key_Init函数来对按键进行初始化,然后通过引用中的Key_GetNum函数来获取按键按下的键码值。代码中使用了STM32的GPIO模块来配置引脚的工作模式和读取引脚的电平状态。此外,引用中提到STM32内部集成了硬件收发电路,可以通过写入控制寄存器CR和数据寄存器DR来实现与外设的通信,并通过读取状态寄存器SR来了解外设电路的当前状态。这些寄存器的使用可以实现对外设的控制和监测,减轻CPU的负担。因此,江科大STM32笔记主要是介绍了STM32单片机的相关知识和编程技巧。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [STM32学习笔记 -- I2C(江科大)](https://blog.csdn.net/weixin_61244109/article/details/131002266)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [STM32江科大学习笔记](https://blog.csdn.net/weixin_38647099/article/details/128337708)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jjinl

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值