博客
关于我
Verilog基础知识10(verilog中的综合与不可综合 )
阅读量:248 次
发布时间:2019-02-28

本文共 1317 字,大约阅读时间需要 4 分钟。

Verilog设计

一、Verilog中的综合与不可综合

  • 综合工具支持的结构:

    always、assign、begin、end、case、wire、tri、aupply0、supply1、reg、integer、default、for、function、and、nand、or、nor、xor、xnor、buf、not、bufif0、bufif1、notif0、notif1、if、inout、input、instantiation、module、negedge、posedge、operators、output、parameter

  • 综合工具不支持的结构:

    time、defparam、$finish、fork、join、initial、delays、UDP、wait

  • 部分工具支持的结构:

    casex、casez、wand、triand、wor、trior、real、disable、forever、arrays、memories、repeat、task、while

  • 二、Verilog可综合设计

  • 可综合模型的原则:
    (1)不使用initial
    (2)不使用#10
    (3)不使用循环次数不确定的循环语句,如forever、while等
    (4)不使用用户自定义原语(UDP元件)
    (5)尽量使用同步方式设计电路
    (6)除非是关键路径的设计,一般不采用调用门级元件描述设计,建议采用行为语句完成设计
    (7)用always过程块描述组合逻辑,应在敏感信号列表中列出所有输入信号
    (8)所有内部寄存器都应能被复位,在FPGA实现时,应尽量使用器件全局复位端作为系统总复位
    (9)对时序逻辑描述建模,尽量使用非阻塞赋值方式;对组合逻辑描述建模,可以用阻塞赋值或非阻塞赋值,但同一过程块中不应混合使用
    (10)一个以上always过程块不能对同一个变量进行赋值,且同一变量不能同时使用阻塞式和非阻塞式赋值
    (11)如果不打算将变量推导为锁存器,必须在if语句或case语句的所有条件分支中对变量进行明确赋值
    (12)避免同时使用上升沿和下降沿触发的触发器
    (13)同一个变量不能受多个时钟控制,也不能受两种不同的时钟条件或时钟沿控制
    (14)避免在case语句的分支项中使用x值或z值
  • 不可综合语句:

  • initial
  • events
  • real
  • time
  • force和release
  • assign和deassign(对reg数据类型)
  • fork和join
  • primitives(非门级原语)
  • table
  • 同时在敏感列表中包含posedge和negedge
  • 同一个reg变量被多个always块驱动
  • 延时(以#开头)
  • 与X、Z进行比较
  • 三、RTL级建模

  • 可综合RTL建模要求逻辑语句能被综合工具识别
  • 组合逻辑描述:
    使用assign直接描述逻辑结构或表达式,或使用always语句块描述复杂逻辑
    组合逻辑单元包括:与门、或门、非门、异或门、多路器、缓冲器、加法器等,均可引用标准单元库
  • 时序逻辑描述:
    使用always语句块描述时序逻辑,确保所有敏感信号列出
  • 注:本文旨在提供Verilog可综合设计的基本原则和实践,具体实现需根据项目需求进行调整。

    转载地址:http://focj.baihongyu.com/

    你可能感兴趣的文章
    MySQL数据库与Informix:能否创建同名表?
    查看>>
    MySQL集群解决方案(4):负载均衡
    查看>>
    MySQL高级-视图
    查看>>
    nacos集群搭建
    查看>>
    Nessus漏洞扫描教程之配置Nessus
    查看>>
    Nest.js 6.0.0 正式版发布,基于 TypeScript 的 Node.js 框架
    查看>>
    Netpas:不一样的SD-WAN+ 保障网络通讯品质
    查看>>
    Netty WebSocket客户端
    查看>>
    Netty工作笔记0011---Channel应用案例2
    查看>>
    Netty工作笔记0014---Buffer类型化和只读
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
    查看>>
    Netty常见组件二
    查看>>
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>