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

    你可能感兴趣的文章
    Perl6 必应抓取(1):测试版代码
    查看>>
    perl学习之内置变量
    查看>>
    perl正则表达式中的常用模式
    查看>>
    Perl的基本語法
    查看>>
    perl输出中文有乱码
    查看>>
    Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). 大数据ssh权限问题 hadoop起不来 hadoopssh错
    查看>>
    PermissionError:Python 中的 [Errno 13]
    查看>>
    PermissionError:[Errno 13] 权限被拒绝:‘/manage.py‘
    查看>>
    Permutation
    查看>>
    return torch._C._broadcast_coalesced(tensors, devices, buffer_size)RuntimeError: NCCL Error 2:unhand
    查看>>
    perspective意思_2020年12月英语四级词汇讲解丨考点归纳:perspective
    查看>>
    PE启动盘和U启动盘(第三十六课)
    查看>>
    PE文件,节头有感IMAGE_SECTION_HEADER
    查看>>
    PE查找文件偏移地址
    查看>>
    PE知识复习之PE的导入表
    查看>>
    pfsense关闭nat
    查看>>
    PFX(Parallel Framework) and Traditional Multithreading
    查看>>
    PGOS:今天动手给电脑装青苹果Win7 X64位系统
    查看>>
    pgpool-II3.1 的内存泄漏(一)
    查看>>
    PgSQL · 特性分析 · PG主备流复制机制
    查看>>