资源描述:
《一个牛人写的文章(关于RTL级设计)》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、一个牛人写的文章(关于RTL级设计)规范很重要工作过的册友肯定知道,公司里是很强调规范的,特别是对于人的设计(无论软件还是硕件),不按照规范走儿乎是不可实现的。逻辑设计也是这样:如果不按规范做的话,过一个月后调试时发现有错,回头再看口己写的代码,估计很多信号功能都忘了,更不要说检错了;如果一个项目做了一半一个人走了,接班的估计得从头开始设计;如果需要在原來的版本基础上增加新功能,很可能也得从头來过,很难做到设计的可重川性。在逻辑方而,我觉得比较重要的规范有这些:1.设计必须文档化。要将设计思路,详细实现等写入文档,然后经过严格评审通过后才能进行下一步的工作。这样做乍看起来很
2、花时间,但是从整个项1=1过程来看,绝对要比一上來就写代码要节约时间,且这种做法可以使项目处于可控、可实现的状态。2.代码规范。比设计要参数化。比如一开始的设计时钟周期是30ns,复位周期是5个时钟周期,我们可以这么写:parameterCLKPERT0D=30;parameterRST_MUL_TIME=5;parameterRST_TIME二RST_MUL_TIME*CLK_PERI0D;rst_n二1'bO;#RST_TTMErst_n=l'bl;•••#CLK_PER10D/2elk<="elk;如果在另一个设计中的时钟是40ns,复位周期不变,我们只需对CLK_P
3、ERIOD进行重新例化就行了,从而使得代码更加易于重用。b.信号命名要规范化。1)信号名一律小写,参数用大写。2)对于低电平冇效的信号结尾要用』标记,如rst_no3)端口信号排列要统一,一个信号只占一行,最好按输入输出及从哪个模块来到哪个模块去的关系排列,这样在后期仿真验证找错时后方便很多。如:modulea(//inputelk,rstn,//globlesignalwren,rden,avalon_din,//relatedtoavalonbussdi,//relatedtoserialportinput//outputdata_ready,avalon_dout,/
4、/relatedtoavalonbus•••);4)一个模块尽量只用一个时钟,这里的一个模块是指一个module或者是一个entityo在多时钟域的设计屮涉及到跨时钟域的设计屮最好有专门一个模块做时钟域的隔离。这样做可以让综合器综合出更优的结果。5)尽量在底层模块上做逻辑,在高层尽量做例化,顶层模块只能做例化,禁止出现任何胶连逻辑(gluelogic),哪怕仅仅是对某个信号取反。理由同上。6)在FPGA的设计上禁止用纯组合逻辑产生latch,带D触发器的latch的是允许的,比如配置寄存器就是这种类型。7)一般来说,进入FPGA的信号必须先同步,以提高系统工作频率(板级)。
5、所冇模块的输出都要寄存器化,以提高工作频率,这对设计做到时序收敛也是极何好处的。9)除非是低功耗设计,不然不要用门控时钟一这会增加设计的不稳定性,在要用到门控时钟的地方,也要将门控信号用时钟的下降沿打一拍再输出与时钟相与。clk_gate_en1qq
6、1gate_clkout
7、
8、1)——o
9、>III/elkII—10)禁止川计数器分频后的信号做其它模块的时钟,而要用改成时钟使能的方式,否则这种时钟满天飞的方式对设计的可靠性极为不利,也人人增加了静态时序分析的复杂性。如FPGA的输入时钟是25M的,现在系统内部要通过RS232与PC通信,要以rs232lxclk的速率发送数
10、据。不要这样做:always(posedgers232_lxclkornegedgerst_n)begin•••end而要这样做:always(posedgeclk_25mornegedgerstn)begin•••elseif(rs232lxclk==1'bl)•••end11)状态机要写成3段式的(这是最标准的写法),即current_state<=next_state;•••always©(currentstate…)•••case(currentstate)•••si:if...nextstate=s2;always@(posedgeelkornegedgerst_
11、n)〈二<=<=else1'bO;//赋默认值1'bO;1'bO;case(current_statc)si:a<=1'bO;//由于上面赋了默认值,这里就不用再对b、c赋值了(b、c在该状态为0,不会产生锁存器,下同)s2:b<=l'bl;s3:c<=l'bl;default:1.ALTERA参考设计准则1)EnsureClock,Preset,andClearconfigurationsarefreeofglitches.2)NeveruseClocksconsistingofmorethanonelevelo