CPLD/FPGA/Verilog_如何写代码减少逻辑单元的使用数量

如何写代码减少逻辑单元的使用数量

工作中遇到的问题,芯片级的资源有限制,没办法只能改进逻辑单元综合电路逻辑。

....尽量不要使用"大于""小于"这样的判断语句, 这样会明显增加使用的逻辑单元数量 .看一下报告,资源使用差别很大.

     例程:always@(posedge clk)
   begin
    count1=count1+1;
   if(count1==10000000)
     feng=1;    //no_ring
    else if(count1==90000000)
     begin
      feng=0;   //ring
      count1=0;
    end
end            //这么写会用107个逻辑单元

// 如果把这句话if(count1==10000000)改成大于小于,报告中用了135个逻辑单元

二.....一定要想尽办法减少reg寄存器的长度

     上次把[30:0]改到[50:0],报告里逻辑单元从100多直升到2000多!!!太吓人了,至于为什么我就不知道了哈!

三....case语句里一定要加default    if一定要加else

      如果是组合逻辑的设计,不加default或else的话,不能保证所有的情况都有赋值,就会在内部形成一个锁存器,不再是一个纯粹的组合逻辑了,电路性能就会下降.

     例如:case({a,b})

                  2'b11 e=b;

                 2'b10   e=a;   

             endcase

            //不加default,虽然只关心a=1时的结果,但是a=0的时候,e就会保存原来的值,直到a变为1

           //那么e要保存原来的值,就要在内部生成锁存器了.

四....尽量使用Case语句   而不是if--else语句

      复杂的if--else语句通常会生成优先级译码逻辑,这将会增加这些路径上的组合时延 
用来产生复杂逻辑的Case语句通常会生成不会有太多时延的并行逻辑

五...组合逻辑的always块中,要注意所有的输入全部放入敏感变量表里

      比如:always@(a or b)

                         begin

                                       out=(a&b&c);

                         end

此时生成的不是纯的组合逻辑,因为当C变化时,    out不会立刻发生变化(需要等到a或b变化,c的变化才会显现),    所以需要生成一个寄存器来保存C的值.

连续赋值语句的综合:从赋值语句右边提取出逻辑,用于驱动赋值语句左边的net

过程赋值语句的综合:从赋值语句右边提取出的逻辑,用于驱动赋值语句左边的reg型变量。注意:initia语句仅用于仿真,不综合。只有在always中才能被综合。

建议组合逻辑用阻塞语句,时序逻辑用非阻塞语句,任何延时控制(如#5)都被综合工具器忽略。一个模块中同一个变量不能既有阻塞赋值,又有非阻塞赋值。

always语句的综合

1对于组合逻辑,事件列表必须包括所有always语句中引用的变量,否则会造成综合的结果与设计功能不匹配。

2临时变量可以不用在事件列表中列出。

if语句的综合

特别要注意综合出锁存器。always中,某个变量没有在所有的条件分支中被赋值,就会综合出锁存器。

case语句综合

和if语句一样,不完整的case分支语句也会导致锁存器的综合。

避免方法:

1)在case语句前,对要赋值的变量赋予初值

always @ (state or a or b) begin

q =0;

case(state)

 3'b000: q =  A & B;

……

2)使用default分支语句

3)使用综合指令,具体用法在case关键字行的注释中插入”synthesis full_case

并行CASE语句

通常情况下case语句和if语句一样会综合出代有优先权解码的硬件电路,从上大侠选项优先级逐渐降低。但如果设计者知道case语句中的所有项是互斥的,这时候就使用”parallel_case"综合指令。

always @(key)

 case(key)     //synthesis parallel_case

    4'b0001: a  = 0;

 endcase

  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CPLD/FPGA是目前应用最为广泛的两种可编程专用集成电路(ASIC), 特别适合于产品的样品开发与小批量生产。本书从现代电子系统设计的角度出发,以全球著名的可编程逻辑器件供应商Xilinx 公司的产品为背景,系统全面地介绍该公司的CPLD/FPGA 产品的结构原理、性能特点、设计方法以及相应的EDA工具软件,重点介绍CPLD/FPGA在数字系统设计、数字通信与数字信号处理等领域中的应用。   本书内容新颖、技术先进、由浅入深,既有关于大规模可编程逻辑器件的系统论述,又有丰富的设计应用实例。对于从事各类电子系统(通信、雷达、程控交换、计算机等)设计的科研人员和应用设计工程师,这是一本具有实用价值的新技术应用参考书。本书也可作为高等院校电子类高年级本科生或研究生的教材或教学参考书。   随着电子技术的不断发展与进步,电子系统的设计方法发生了很大的变化,传统的设计方法正逐步退出历史舞台,而基于EDA技术的芯片设计正在成为电子系统设计的主流。大规模可编程逻辑器件CPLDFPGA是当今应用最广泛的两类可编程专用集成电路(ASIC),电子设计工程师利用它可以在办公室或实验室里设计出所需的专用集成电路,从而大大缩短了产品上市时间,降低了开发成本。此外,可编程逻辑器件还具有静态可重复编程和动态在系统重构的特性,使得硬件的功能可以像软件-样通过编程来修改,这样就极大地提高了电子系统设计的灵活性和通用性。   由于具备上述两方面特点,CPLDFPGA受到了世界范围内广大电子设计工程师的普遍欢迎,应用日益广泛。与此同时,可编程ASIC本身也在近几年得到了迅速的发展,其集成度、工作速度不断提高。目前已有单片可用门数超过300万门。工作频率可达200 MHz以上的可编程ASIC芯片问世。由于结构和工艺的改进,可编程ASIC芯片上包含的资源越来越丰富,可实现的功能越来越强,它们已成为当今实现电子系统集成化的重要手段。   Xilinx公司是全球著名的可编程逻辑器件供应商,也是FPGA器件的发明者,它在多年用户需求的基础上开发了多种性能优越的系列产品,其售后服务周全,用户涉及面广,是开发和研制产品的最佳选择之一”。 本书以Xilinx公司的产品为背景,系统介绍该公司的CPLDFPGA典型产品的结构原理、性能特点、设计方法以及相应的EDA工具软件,详细介绍Foundation Series 开发软件的特点、安装和使用方法,重点介绍CPLD/FPGA在数字系统设计、数字通信与数字信号处理等领域中的应用。除此以外,还对JTAG边界扫描测试电路以及硬件描述语言VHDL的基本概念作了简要的介绍。本书在选材上注重内容新颖、技术先进,并在书中给出了经实践验证的大量设计实例,希望能对读者迅速掌握大规模可编程逻辑器件设计与应用有所帮助。同时,为保证书中实例不受具体器件限制,本书所有实例均采用VHDL语言或Verilog HDL语言编,可以方便地移植到其他公司(如Altera、LarTIce、 Actel 等)的CPLD/FPGA器件中。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值