蜂鸟E203学习笔记(二)--蜂鸟E203总体框架

蜂鸟E203总体框架

蜂鸟E203处理器系统如下图所示
在这里插入图片描述

一、蜂鸟E203处理器核设计总览和顶层

1.1 蜂鸟E203处理器核的设计理念

  1. 模块化和可重用性:将处理器分成几个主体模块,每个单元之间的接口简单清晰。
  2. 面积最小化:追求低功耗和小面积,尽可能地服用数据通路以节省面积开销
  3. 结构简单化
  4. 性能不追求极端

1.2 蜂鸟E203处理器核的RTL代码风格

  • 使用标准的DFF模块例化、生成寄存器
  • 推荐使用Verilog中的assign语法替代if-else 和case语法

1.2.1 使用标准的DFF模块例化生成寄存器

wire flg_r
wire flg_nxt = ~flp_r;
wire flg_ena

sirv_gnrl_dfflr #(1) flg_dfflrs(flg_ena, flg_r, flg_nxt ,clk, rst_n);

实际上sirv_gnrl_dfflr 是一个使用Verilog语法的always块编写的DFF模块。
if else无法捕捉不定态,使用这个DFF模块还可以捕捉不定态,一旦输入是不定态就会退出仿真并且报错。

1.2.2 推荐使用assign 语法替代if else 和case语法

verilog的if else和case语法存在两大缺点:

  • 不能传播不定态
  • 会产生优先级的选择电路而非并行选择电路,从而不利于优化时序和面积

对于if-else不能传播不定态,以如下代码为例。假设a的值为X(不定态),按照Verilog语法它会将等效于 a==0 ,从而让out等于 in2 ,最终没有将X传播出去。这种情况可能会在仿真阶段掩盖某些致命的bug,造成芯片功能错误。

if (a)
	out = in1;
else 
	out = in2;

使用assign语法的话,则会将X传播出去,从而让out也等于X。
aassign out = a ? in1:in2;
Veriog的case语句同样不会传播不定态,同时if-else和case也会形成优先级选择电路如

if(sel1)
	out = in1[3:0];
else if (sel2)
	out = in2[3:0];
else if (sel3)
	out = in3[3:0];
else 
	out = in4[3:0];

使用assign的话,假如确实是生成一处有优先级的选择电路则

assign out = sel1 ? in1[3:0]:
			 sel2 ? in2[3:0]:
			 sel3 ? in3[3:0]:
			 		in4[3:0];

而如果要生成并行的选择逻辑,则利用assign语法明确地写成"于或"的逻辑

assign out = ({4{sel1}} & in1[3:0])
			|({4{sel2}} & in2[3:0])
			|({4{sel3}} & in3[3:0])

{ }表示拼接,{第一位,第二位…};
{{ }}表示复制,{4{a}}等同于{a,a,a,a};
&是按位与 |是按位或

1.2.3 注意事项

  • 带reset信号的寄存器面积略大,时序稍微差一些,因此在数据通路上可以使用补带reset的寄存器,而只在控制通路商使用带reset信号的寄存器

1.3 蜂鸟E203模块层次划分

在这里插入图片描述
在这里插入图片描述

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

kelinnn

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

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

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

打赏作者

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

抵扣说明:

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

余额充值