打印
[RISC-V MCU 应用开发]

从零开始写RISC-V处理器(软件篇:浅谈Verilog)

[复制链接]
2718|15
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主

verilog,确切来说应该是verilog HDL(Hardware Description Language ),从它的名字就可以知道这是一种硬件描述语言。首先它是一种语言,和C语言、C++语言一样是一种编程语言,那么verilog描述的是什么硬件呢?描述电阻?描述电容?描述运算放大器?都不是,它描述的是数字电路里的硬件,比如与、非门、触发器、锁存器等等。

既然是编程语言,那一定会有它的语法,学过C语言的同学再来看verilog得代码,会发现有很多地方是相似的。

verilog的语法并不难,难的是什么时候该用wire类型,什么时候该用reg类型,什么时候该用assign来描述电路,什么时候该用always来描述电路。assign能描述组合逻辑电路,always也能描述组合逻辑电路,两者有什么区别呢?

.

3.1  用always描述组合逻辑电路

我们知道数字电路里有两大类型的电路,一种是组合逻辑电路,另外一种是时序逻辑电路。组合逻辑:输出只是当前输入逻辑电平的函数(有延时),与电路的原始状态无关。当前电路输入信号任何一个发生改变,输出都将发生改变。时序逻辑:输出不仅是当前输入电平的函数,还与目前电路的状态有关。

在verilog中,assign能描述组合逻辑电路,always也能描述组合逻辑电路。对于简单的组合逻辑电路的话两者描述起来都比较好懂、容易理解,但是一旦到了复杂的组合逻辑电路,如果用assign描述的话要么是一大串要么是要用好多个assign,不容易弄明白。但是用always描述起来却是非常容易理解的。

既然这样,那全部组合逻辑电路都用always来描述好了,呵呵,既然assign存在就有它的合理性。用always描述组合逻辑电路时要注意避免产生锁存器,if和case的分支情况要写全。

在tinyriscv中用了大量的always来描述组合逻辑电路,特别是在译码和执行阶段。

.

3.2  数字电路设计中的时序问题

要分析数字电路中的时序问题,就一定要提到以下这个模型。

其中对时序影响最大的是上图中的组合逻辑电路。所以要避免时序问题,最简单的方法减小组合逻辑电路的延时。组合逻辑电路里的串联级数越多延时就越大,实在没办法减小串联级数时,可以采用流水线的方式将这些级数用触发器隔开。

.

3.3  流水线设计

要设计处理器的话,流水线是绕不开的。当然你也可以抬杠说:”用状态机也可以实现处理器啊,不一定要用流水线。”

采用流水线设计方式,不但可以提高处理器的工作频率,还可以提高处理器的效率。但是流水线并不是越长越好,流水线越长要使用的资源就越多、面积就越大。

在设计一款处理器之前,首先要确定好所设计的处理器要达到什么样的性能(或者说主频最高是多少),所使用的资源的上限是多少,功耗范围是多少。如果一味地追求性能而不考虑资源和功耗的话,那么所设计出来的处理器估计就只能用来玩玩,或者做做学术研究。

tinyriscv采用的是三级流水线,即取指、译码和执行,设计的目标就是要对标ARM的Cortex-M3系列处理器。

.

3.4  代码风格

代码风格其实并没有一种标准,但是并不代表代码风格不重要。好的代码风格可以让别人看你的代码时有一种赏心悦目的感觉。哪怕代码只是写给自己看,也一定要养成好的代码风格的习惯。tinyriscv的代码风格在很大程度上沿用了写C语言代码所采用的风格。

下面介绍tinyriscv的一些主要的代码风格。

(1)缩进

统一使用4个空格。

(2)if语句

不管if语句下面有多少行语句,if下面的语句都由begin…end包起来,并且begin在if的最后,如下所示:

(3)case语句

对于每一个分支情况,不管有多少行语句,都由begin…end包起来,如下所示:

(4)always语句

always语句后跟begin,如下所示:

(5)其他

=、==、<=、>=、+、-、*、/、@等符号左右各有一个空格。

,和:符号后面有一个空格。

对于模块的输入信号,不省略wire关键字。

每个文件的最后留一行空行。

if、case、always后面都有一个空格。



使用特权

评论回复

相关帖子

沙发
麻花油条| | 2022-6-15 10:29 | 只看该作者
从零开始写,慢慢学习吧

使用特权

评论回复
板凳
七毛钱| | 2022-6-21 09:51 | 只看该作者
感谢分享,学习学习

使用特权

评论回复
地板
cehuafan| | 2022-7-9 12:17 | 只看该作者
这个有视频教程吗   

使用特权

评论回复
5
modesty3jonah| | 2022-7-9 13:08 | 只看该作者
risc-v和mips有什么不同呢   

使用特权

评论回复
6
hilahope| | 2022-7-9 14:21 | 只看该作者
verilog的太复杂了。  

使用特权

评论回复
7
juliestephen| | 2022-7-9 15:02 | 只看该作者
研究一下这个架构。  

使用特权

评论回复
8
modesty3jonah| | 2022-8-16 20:45 | 只看该作者
这个就高端了。   

使用特权

评论回复
9
duo点| | 2022-8-17 10:39 | 只看该作者
刚刚看别人说写这种构架的芯片很难了

使用特权

评论回复
10
tabmone| | 2022-8-18 18:25 | 只看该作者
有相关的资料可以参考吗   

使用特权

评论回复
11
cemaj| | 2022-8-18 18:54 | 只看该作者
单片机的设计吗   

使用特权

评论回复
12
ghuca| | 2022-8-19 22:28 | 只看该作者
必须用学习verilog吗   

使用特权

评论回复
13
dzfansman| | 2022-8-20 20:15 | 只看该作者
数字逻辑是什么样子的  

使用特权

评论回复
14
macpherson| | 2022-9-5 16:39 | 只看该作者
开发的难度是多少   

使用特权

评论回复
15
sheflynn| | 2022-9-7 20:20 | 只看该作者
fpga开发难吗     

使用特权

评论回复
16
nomomy| | 2022-9-7 21:25 | 只看该作者
从零开始写RISC-V处理器,这个要什么基础   

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

78

主题

124

帖子

0

粉丝