博客
关于我
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/

    你可能感兴趣的文章
    NodeJs——(11)控制权转移next
    查看>>
    NodeJS、NPM安装配置步骤(windows版本)
    查看>>
    NodeJS、NPM安装配置步骤(windows版本)
    查看>>
    nodejs与javascript中的aes加密
    查看>>
    nodejs中Express 路由统一设置缓存的小技巧
    查看>>
    nodejs中express的使用
    查看>>
    Nodejs中的fs模块的使用
    查看>>
    NodeJS使用淘宝npm镜像站的各种姿势
    查看>>
    nodejs包管理工具对比:npm、Yarn、cnpm、npx
    查看>>
    NodeJs单元测试之 API性能测试
    查看>>
    nodejs图片转换字节保存
    查看>>
    nodejs在Liunx上的部署生产方式-PM2
    查看>>
    nodejs字符与字节之间的转换
    查看>>
    NodeJs学习笔记001--npm换源
    查看>>
    NodeJs学习笔记002--npm常用命令详解
    查看>>
    nodejs学习笔记一——nodejs安装
    查看>>
    NodeJS实现跨域的方法( 4种 )
    查看>>
    nodejs封装http请求
    查看>>
    nodejs常用组件
    查看>>
    nodejs开发公众号报错 40164,白名单配置找不到,竟然是这个原因
    查看>>