找回密码
 注册
关于网站域名变更的通知
查看: 678|回复: 1
打印 上一主题 下一主题

大神教你如何写代码减少逻辑单元的使用数量(很实用)

[复制链接]
  • TA的每日心情
    开心
    2019-11-20 15:00
  • 签到天数: 2 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2019-5-22 14:10 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x
    大神教你如何写代码减少逻辑单元的使用数量(很实用)
    ! o( i( e  ~% j5 d
    ; W3 D9 W$ n# Q2 ?
    一....尽量不要使用"大于""小于"这样的判断语句, 这样会明显增加使用的逻辑单元数量 .看一下报告,资源使用差别很大.
    # t% h2 w7 S! v! n, W0 k     例程:always@(posedge clk)% u/ H& a$ W1 @. H) k6 \
       begin* y9 s) @4 m) i# p9 n5 |9 u
        count1=count1+1;
    7 ?% U  v2 E0 J; u4 g   if(count1==10000000)+ s% p; H, b5 N
         feng=1;    //no_ring. ]# ]2 u4 k/ C% d) f
        else if(count1==90000000)
    2 M" c; q/ b) P. v2 `     begin
    . Z  g3 i* T5 a      feng=0;   //ring
    6 h) a% `9 ]9 }% [: m      count1=0;
    3 @  k2 t( X  g: Q8 O; o% g; a. m    end
    # g( {  k' D' E$ G, a# i9 o2 P- h  B; Dend            //这么写会用107个逻辑单元
    . @% O$ x- f/ r// 如果把这句话if(count1==10000000)改成大于小于,报告中用了135个逻辑单元
    1 T9 D! |( D- y5 o二.....一定要想尽办法减少reg寄存器的长度* C: e; ^& P5 m8 y
         上次把[30:0]改到[50:0],报告里逻辑单元从100多直升到2000多!!!太吓人了,至于为什么我就不知道了哈!
    % h9 N# J$ S: n三....case语句里一定要加default    if一定要加else' s, x' ]: x' @& x
          如果是组合逻辑的设计,不加default或else的话,不能保证所有的情况都有赋值,就会在内部形成一个锁存器,不再是一个纯粹的组合逻辑了,电路性能就会下降.
    4 |" I/ K; ]4 F2 ~2 d3 b* O     例如:case({a,b})6 o: u9 L8 v9 C( H' r
                      2'b11 e=b;8 j$ Y! S& {9 e! n1 |* I' |
                     2'b10   e=a;   
    * W. c6 m, h0 S! Q4 y4 s/ {             endcase
    6 I/ p; J3 v1 E            //不加default,虽然只关心a=1时的结果,但是a=0的时候,e就会保存原来的值,直到a变为1# ?% G5 V8 z5 q5 c3 ~; p
               //那么e要保存原来的值,就要在内部生成锁存器了.7 k$ [* }4 y, c4 i! b/ _1 l
    四....尽量使用Case语句   而不是if--else语句0 h( L5 Q/ Z" C8 ]+ h
          复杂的if--else语句通常会生成优先级译码逻辑,这将会增加这些路径上的组合时延
    : k2 d/ q2 F# ~6 \) R6 d7 ~用来产生复杂逻辑的Case语句通常会生成不会有太多时延的并行逻辑
    2 w5 T' l6 f( `3 k  P7 O五...组合逻辑的always块中,要注意所有的输入全部放入敏感变量表里4 J, |; L# ]) E& v+ s
          比如:always@(a or b)
    1 P$ t3 p# {( m/ V* m. A                         begin
    4 a+ q* q+ W- x' v                                       out=(a&b&c);' w: G- f) {  \3 {1 D
                             end7 e+ o; l6 u; B7 ^7 {
    此时生成的不是纯的组合逻辑,因为当C变化时,    out不会立刻发生变化(需要等到a或b变化,c的变化才会显现),    所以需要生成一个寄存器来保存C的值.
    & s; O! V: h  O. C连续赋值语句的综合:从赋值语句右边提取出逻辑,用于驱动赋值语句左边的net; `7 B8 U1 s3 `0 Z/ [$ m" q
    过程赋值语句的综合:从赋值语句右边提取出的逻辑,用于驱动赋值语句左边的reg型变量。注意:initia语句仅用于仿真,不综合。只有在always中才能被综合。
    0 S6 b& D4 h' K建议组合逻辑用阻塞语句,时序逻辑用非阻塞语句,任何延时控制(如#5)都被综合工具器忽略。一个模块中同一个变量不能既有阻塞赋值,又有非阻塞赋值。
    % B1 M7 ^7 S7 K0 z) t4 Y. P# Ralways语句的综合( u/ s, i+ t; A2 e
    1对于组合逻辑,事件列表必须包括所有always语句中引用的变量,否则会造成综合的结果与设计功能不匹配。. z# V& L, q4 r2 P
    2临时变量可以不用在事件列表中列出。. t2 d3 I# f; F# z1 T
    if语句的综合
    * b! Z( l0 W" ]- {; H特别要注意综合出锁存器。always中,某个变量没有在所有的条件分支中被赋值,就会综合出锁存器。
    ( X4 A2 S7 s& r% R% Ecase语句综合3 W2 ~+ o1 g( ^# s: J, ^+ K
    和if语句一样,不完整的case分支语句也会导致锁存器的综合。
    0 `) ^) T& o0 c$ c' w$ ]- {& J避免方法:
    - m6 O5 Z) A- R9 i1)在case语句前,对要赋值的变量赋予初值0 ]4 E: l. L$ Y. \+ p+ x# ^- @
    always @ (state or a or b) begin0 A( K; c1 l: }+ I& x. s' I
    q =0;' z% z# ?- ]3 M. U
    case(state)
    0 o5 m! u3 p& a$ \0 ~. [9 f" S 3'b000: q =  A & B;0 z" Q9 p5 t4 j/ u
    ……8 H5 \/ V- V1 U: G. I  C- f
    2)使用default分支语句# y# Q. v$ J9 h# E# |" b
    3)使用综合指令,具体用法在case关键字行的注释中插入”synthesis full_case“$ h3 a/ {) T5 F/ d" |7 g
    并行CASE语句
    + L* Z/ W9 {( a' _- t3 d通常情况下case语句和if语句一样会综合出代有优先权解码的硬件电路,从上大侠选项优先级逐渐降低。但如果设计者知道case语句中的所有项是互斥的,这时候就使用”parallel_case"综合指令。
    $ G2 Y1 X9 V! i. I' Z6 malways @(key)
    * X- ?+ N9 z& B# S6 P5 T4 A! ^ case(key)     //synthesis parallel_case. {6 c- R& ^- d1 d( a
        4'b0001: a  = 0;
    . N0 j8 B+ }* X7 J* k1 N) X endcase
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-8-3 16:00 , Processed in 0.109375 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表