专栏名称: EETOP
EETOP电子网(中国电子顶级开发网)是国内最顶级的电子行业工程师社区,涉及:嵌入式、智能硬件、半导体集成电路设计及制造等。 为您分享论坛精华内容、行业最新资讯、产品及技术 。 网址:www.eetop.cn bbs.eetop.cn
目录
相关文章推荐
EETOP  ·  国产EDA ... ·  10 小时前  
哎咆科技  ·  iOS 26 紧急更新,修复致命漏洞! ·  昨天  
ZOL中关村在线  ·  华为WATCH ... ·  昨天  
ZOL中关村在线  ·  懂空调的人是如何选空调的?一文让你看懂 ·  2 天前  
EETOP  ·  ESD|DFT|IC设计|数字后端等 ... ·  2 天前  
51好读  ›  专栏  ›  EETOP

一个FPGA工程师的个人工作经历总结

EETOP  · 公众号  · 硬件  · 2017-08-30 12:45

正文

请到「今天看啥」查看全文


a.设计要参数化。比如一开始的设计时钟周期是30ns,复位周期是5个时钟周期,我们可以这么写:

parameter CLK_PERIOD = 30;
parameter RST_MUL_TIME = 5;
parameter RST_TIME = RST_MUL_TIME * CLK_PERIOD;
。。. rst_n = 1‘b0;
# RST_TIME rst_n = 1’b1;
。。. # CLK_PERIOD/2 clk <<= ~clk;


如果在另一个设计中的时钟是40ns,复位周期不变,我们只需对CLK_PERIOD进行重 新例化就行了,从而使得代码更加易于重用。

b.信号命名要规范化。
1) 信号名一律小写,参数用大写。
2) 对于低电平有效的信号结尾要用_n标记,如rst_n。
3) 端口信号排列要统一,一个信号只占一行,最好按输入输出及从哪个模块来到哪 个模块去的关系排列,这样在后期仿真验证找错时后 方便很多。如:


module a(
//input
clk,
rst_n,
//globle signal
wren,
rden,
avalon_din,
//related to avalon bus
sdi,
//related to serial port input
//output
data_ready,
avalon_dout,
//related to avalon bus
。.
);

4)一个模块尽量只用一个时钟,这里的一个模块是指一个module或者是一个en tity。在多时钟域的设计中涉及到跨时钟域的设计中最好有专门一个模块做时钟域的隔 离。这样做可以让综合器综合出更优的结果。
5)尽量在底层模块上做逻辑,在高层尽量做例化,顶层模块只能做例化,禁止出现任何胶连逻辑(glue logic),哪怕仅仅是对某个信号取反。理由同上。
6)在FPGA的设计上禁止用纯组合逻辑产生latch,带D触发器的latch的是允许的 ,比如配置寄存器就是这种类型。
7)一般来说,进入FPGA的信号必须先同步,以提高系统工作频率(板级)。 所有模块的输出都要寄存器化,以提高工作频率,这对设计做到时序收敛也是极有好处的。
8) 除非是低功耗设计,不然不要用门控时钟--这会增加设计的不稳定性,在要用到门控时钟的地方,也要将门控信号用时钟的下降沿 打一拍再输出与时钟相与。
clk_gate_en-----------------|D Q|------------------|\ gate_clk _out||---------| )---------------o|》|||/clk|--------|---
9)禁止用计数器分频后的信号做其它模块的时钟,而要用改成时钟使能的方式,否则这种时钟满天飞的方式对设计的可靠性极为不利,也大大增加了静态时序分析的复杂性。

如FPGA的输入时钟是25M的,现在系统内部要通过RS232与PC通信,要以rs232_ 1xclk的速率发送数据。

不要这样做:

always (posedge rs232_1xclk or negedge rst_n)

begin 。。.

end

而要这样做:

always (posedge clk_25m or negedge rst_n)







请到「今天看啥」查看全文