网友经验分享: Verilog设计注意

组合逻辑
1.敏感变量的描述完备性
Verilog中,用always块设计组合逻辑电路时,在赋值表达式右端参与赋值的所有信号都必须在always @(敏感电平列表)中列出,always中if语句的判断表达式必须在敏感电平列表中列出。如果在赋值表达式右端引用了敏感电平列表中没有列出的信号,在综合时将会为没有列出的信号隐含地产生一个透明锁存器。这是因为该信号的变化不会立刻引起所赋值的变化,而必须等到敏感电平列表中的某一个信号变化时,它的作用才表现出来,即相当于存在一个透明锁存器,把该信号的变化暂存起来,待敏感电平列表中的某一个信号变化时再起作用,纯组合逻辑电路不可能作到这一点。综合器会发出警告。

Example1:
 input a,b,c;
 reg e,d;
 always @(a or b or c)
    begin
    e=d&a&b; /*d没有在敏感电平列表中,d变化时e不会立刻变化,直到a,b,c中某一个变
化*/
    d=e |c;
    end
    
Example2:
 input a,b,c;
 reg e,d;
 always @(a or b or c or d)
    begin
    e=d&a&b; /*d在敏感电平列表中,d变化时e立刻变化*/
    d=e |c;
    end  
2.条件的描述完备性
如果if语句和case语句的条件描述不完备,也会造成不必要的锁存器。

Example1:   
 if (a==1'b1) q=1'b1;//如果a==1'b0,q=? q将保持原值不变,生成锁存器!
Example2:
 if (a==1'b1) q=1'b1;
 else         q=1'b0;//q有明确的值。不会生成锁存器!
 
Example3:
   reg[1:0] a,q;
   ....
   case (a)
      2'b00 : q=2'b00;
      2'b01 : q=2'b11;//如果a==2'b10或a==2'b11,q=? q将保持原值不变,锁存器!
   endcase
   
Example4:
   reg[1:0] a,q;
   ....
   case (a)
      2'b00 : q=2'b00;
      2'b01 : q=2'b11;
      default: q=2'b00;//q有明确的值。不会生成锁存器!
   endcase

Verilog中端口的描述
1.端口的位宽最好定义在I/O说明中,不要放在数据类型定义中;
Example1:
module test(addr,read,write,datain,dataout)
input[7:0]  datain;
input[15:0] addr;
input       read,write;
output[7:0] dataout;  //要这样定义端口的位宽!

wire addr,read,write,datain;
reg  dataout;

Example2:
module test(addr,read,write,datain,dataout)
input  datain,addr,read,write;
output dataout;

wire[15:0] addr;
wire[7:0]  datain;
wire       read,write;
reg[7:0]   dataout;   // 不要这样定义端口的位宽!!
2.端口的I/O与数据类型的关系:
     端口的I/O         端 口 的     数 据 类 型
                       module内部     module外部
      input              wire             wire或reg
      output         wire或reg       wire
      inout            wire               wire
3.assign语句的左端变量必须是wire;直接用"="给变量赋值时左端变量必须是reg!

Example:
assign a=b; //a必须被定义为wire!!
********
begin
   a=b; //a必须被定义为reg!
end
 
VHDL中STD_LOGIC_VECTOR 和 INTEGER 的区别例如 A 是INTEGER型,范围从0到255;B是STD_LOGIC_VECTOR,定义为8位。A累加到255时,再加1就一直保持255不变,不会自动反转到0,除非令其为0;而B累加到255时,再加1就会自动反转到0。所以在使用时要特别注意!
1.无置位/清零的时序逻辑
    always @( posedge CLK)
       begin
       Q<=D;
       end
 2.有异步置位/清零的时序逻辑
   异步置位/清零是与时钟无关的,当异步置位/清零信号到来时,触发器的输出立即
   被置为1或0,不需要等到时钟沿到来才置位/清零。所以,必须要把置位/清零信号
   列入always块的事件控制表达式。
    always @( posedge CLK or negedge RESET)
       begin
       if (!RESET)
          Q=0;
       else
          Q<=D;
       end     
 3.同步置位/清零的时序逻辑
    同步置位/清零是指只有在时钟的有效跳变时刻置位/清零,才能使触发器的输出分
    别转换为1或0。所以,不要把置位/清零信号列入always块的事件控制表达式。但是
    必须在always块中首先检查置位/清零信号的电平。    
    always @( posedge CLK )
       begin
       if (!RESET)
          Q=0;
       else
          Q<=D;
       end
            
结构规范性
  在整个芯片设计项目中,行为设计和结构设计的编码是最重要的一个步骤。
  它对逻辑综合和布线结果、时序测定、校验能力、测试能力甚至产品支持都有重要的影响。考虑到仿真器和真实的逻辑电路之间的差异,为了有效的进行仿真测试:

1.避免使用内部生成的时钟
     内部生成的时钟称为门生时钟(gated clock)。如果外部输入时钟和门生时钟同
时驱动,则不可避免的两者的步调不一致,造成逻辑混乱。而且,门生时钟将会增加测试的
难度和时间。
2.绝对避免使用内部生成的异步置位/清零信号
     内部生成的置位/清零信号会引起测试问题。使某些输出信号被置位或清零,无法正常测试。
3.避免使用锁存器
     锁存器可能引起测试问题。对于测试向量自动生成(ATPG),为了使扫描进行,锁存器需要置为透明模式(transparent mode),反过来,测试锁存器需要构造特定的向量,这可非同一般。
4.时序过程要有明确的复位值
    使触发器带有复位端,在制造测试、ATPG以及模拟初始化时,可以对整个电路进行快速复位。
5.避免模块内的三态/双向
     内部三态信号在制造测试和逻辑综合过程中难于处理.

业务联系请加个人微信号:jack_eetop 或 QQ:228265511

全力打造中国电子工程师微信第一品牌!

(0)

相关推荐

  • 凔海笔记之FPGA(四):Verilog HDL语法简单述

    在百度百科中,是这样介绍Verilog HDL的,它是一种硬件描述语言(HDL:Hardware Description Language),以文本形式来描述数字系统硬件的结构和行为的语言,用它可以表 ...

  • 用Verilog设计一个16 位 RISC 处理器

    Verilog Code for 16-bit RISC Processor RISC 处理器是基于其指令集和哈佛型数据通路结构设计的.然后,RISC 处理器在Verilog 中实现并使用 Xilin ...

  • Verilog数字系统基础设计-数据转换器

    绪论在一些应用中,两个电路模块交界处,一个电路模块的输出数据位宽大于另一个模块的输入数据位宽,此时需要进行数据转换.例如,在SATA控制器中,内部数据位宽为32比特,但是与外部物理收发器PHY的接口通 ...

  • 二进制转BCD码需要几步?

    Hi,大家好!我是至芯科技的李老师. 今天讲课的题目比较有意思,它是一个小问题:把二进制变成BCD码需要几步? 请大家思考一下.有同学可能回答需要三步,为什么啊? 因为啊,把大象放进冰箱里需要三步,第 ...

  • 【经验分享】设计必看!容易犯的错误和常被忽略的细节都在这!

    一.机械设计中坚决不能出现的重大错误 1. 违背法律及法规允许的设计 2. 不符合合同内容,或与客户及公司内部会议所决定的事项 3. 无设计根据(不包括经验设计或可行的创新设计.发明设计) 4. 没有 ...

  • 思博网友经验分享帖

    先介绍下我的情况,18年毕业,机械专业,进厂呆了两个月,实在受不了厂里的平淡和无聊,在同学的推荐下进了一家专利所,起初并不了解专利到底是什么,从我进所那天起,师傅就带着编案子,那时我以为这就是专利,我 ...

  • 扁桃体肥大手术怎么做(网友经验分享),顺便分享价格、疼不疼!

    很多人可能不太清楚扁桃体肥大手术怎么做,也不太清楚扁桃体肥大手术价格以及扁桃体肥大手术疼不疼,今天李医生结合一下某网友手术的案例和大家讲解一下这方面的知识. 经验来源于网友分享: 扁桃体切除手术后已经 ...

  • 网友经验分享:这本期刊编辑Nice!影响因子持续上涨

    今天,我们来分析下这本国人友好的期刊The International Journal of Biological Markers,这本刊物是同行评审的开放获取期刊,由美国SAGE出版社负责出版的季刊 ...

  • 专业PPTer设计经验分享

    专业PPTer设计经验分享

  • P&T集团RC构件及PPVC设计经验分享

    由香港理工大学国家钢结构工程技术研究中心香港分中心(简称香港分中心)和香港建筑金属结构协会共同组织的组装合成建筑法(MiC)技术研讨会于 2019 年 7 月 11 日在海景嘉福洲际酒店举行,并有一共 ...

  • 浅谈设计PCB时的经验分享

    在设计PCB时,我们通常会依赖以前在网上通常会找到的经验和技巧.每个PCB设计都可以针对特定应用进行优化,通常,其设计规则仅适用于目标应用.例如,模数转换器PCB规则不适用于RF PCB,反之亦然.但 ...

  • 经验分享:建筑外墙玻璃幕墙节点设计20大忌!

    装饰装修技术联盟 一起学习装饰装修施工技术.装修案例.装修流程.装修材料.装修知识等装修内容 公众号 来源:卡特能幕墙 如有侵权,请联系删除 玻璃幕墙是应用比较广泛的外墙系统,在建筑外墙中的主导地位不 ...

  • 球墨铸铁的凝固特点,以及无冒口铸造设计的经验分享!

    铸造大讲堂 昨天 由球墨铸铁的凝固特点认为球铁件易于出现缩孔缩松缺陷,因而其实现无冒口铸造较为困难.阐述了实现球铁件无冒口铸造工艺所应具备的铁液成份.浇注温度.冷铁工艺.铸型强度和刚度.孕育处理.铁液 ...