0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Interface接口的优势和使用示例

FPGA之家 来源:FPGA之家 2023-09-01 15:38 次阅读

什么引入interface?

将设计和验证从逻辑上和时间上分开,使得两个小组可以相对独立;

IC 设计的复杂度逐渐增加,模块之间的连接也逐渐复杂,传统的 Verilog信号连接方式代码量太大,容易出错,且不易于复用。

Interface的优势

简洁:

1、使用 Interface 在验证中添加、删除和修改信号时只需要修改 Interface 和使用该 Interface 的模块,怎么理解?

c20d68dc-447f-11ee-a2ef-92fbcf53809c.png

如图所示:顶层模块top例化了模块m1和m2,a信号从m2经过顶层模块到m1。假设现需将信号a修改为b,不使用接口的情况下,m1、m2及top模块都应该做出相应的修改;若使用接口,top例化的是接口,接口内的信号修改只需要修改m1、m2相关部分即可。

2、两个块之间有两个以上的信号连接,并且使用特定的协议时,使用接口更利于复用。

硬件域的桥梁:

Interface 是硬件域( module、设计中使用)和软件域( class、验证环境中使用)交互的唯一方式。

定义要点

Interface 的定义与 Module 类似,可以参考 Module 的定义方法;由于接口直接与DUT打交道,因此变量建议声明为四值逻辑logic;同时为了防止验证环境带来的竞争问题,驱动硬件的信号应使用非阻塞赋值;Interface端口列表中只需要定义时钟、复位等公共信号,或者不定义任何端口信号。

使用示例

首先定义interface,然后在顶层例化后作为module的端口列表分别传入DUT和TB中。

c22fc8a0-447f-11ee-a2ef-92fbcf53809c.jpg

接口中的modport

前一个例子中使用了点对点无信号方向的连接方式。在使用该端口的原始网单里包含了方向信息,编译器依次来检查连线错误。也可以通过modport来进一步限定信号传输的方向,避免端口连接的错误。

c24a4158-447f-11ee-a2ef-92fbcf53809c.png

需要注意的是modport中的input和output方向是调用该modport模块的输入输出方向,比如TEST的modport内声明的方向,就是调用它的test模块输入输出。

事实上modport在验证环境中使用并不多,因为下文提到的不但clocking块包含了modport的方向信息,同时clocking块也可作为同步信号的驱动。

接口中的clocking块

clocking 块,用来对同步信号进行采样和驱动,可以避免设计和验证的竞争。clocking block需要指定一个触发时钟,比如posedge clk、negedge clk。

c2704236-447f-11ee-a2ef-92fbcf53809c.png

同若验证环境中需要同步驱动,利用“arb_if.cb.*”的方式利用clocking块中的信号进行驱动即可。

同时可以为clocking块中信号设置建立和保持时间,若未设置建立时间或保持时间时则会默认在clocking事件前1step输入采样,在事件后#0对输出驱动。

c288a704-447f-11ee-a2ef-92fbcf53809c.png

标注的语句表示在时钟上升沿前10ns进行采样,在时钟上升沿2ns后进行驱动。怎么理解?事实上这个步骤主要是为了模拟实际的硬件行为,感兴趣的可以自己画几级触发器来分析,TB对DUT的驱动一侧相当于DUT的上一级触发器,采样DUT数据一侧的TB相当于DUT的下一级寄存器

几点注意:clocking不是interface独有的,module、program也可以声明clocking模块;clocking中列举的信号都是由interface、module、program等声明了clocking的模块定义的,cloking自身不声明信号;一个interface中可以定义多个clocking,同一个变量可以在多个clocking块中被应用,且可以声明不同的输入输出方向。

完结。

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 接口
    +关注

    关注

    33

    文章

    7639

    浏览量

    148485
  • IC设计
    +关注

    关注

    37

    文章

    1264

    浏览量

    102955
  • Verilog
    +关注

    关注

    28

    文章

    1326

    浏览量

    109302
  • Interface
    +关注

    关注

    0

    文章

    102

    浏览量

    38517

原文标题:Interface in systemverilog

文章出处:【微信号:zhuyandz,微信公众号:FPGA之家】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Flash Interface中AXI Interface和TCM Interface具体有啥区别?

    M7内核的MCU目前只用过H743和H7B0,在配置Cortex Interface时没有这个选项,这两天开始用F767ZGT6,在用CubeMX配置工程时发现F7在这里多了不少项,想问问各位Flash Interface 中AXI I
    发表于 03-20 07:07

    串行外设接口(Serial Peripheral Interface Master) Xilinx提供

    串行外设接口(Serial Peripheral Interface Master) Xilinx提供
    发表于 08-17 10:23

    合并SLaveFIFO接口和GPIFtoStAGGE FX3固件示例出现错误:未定义引用

    你好,我正在合并SLaveFIFO接口和GPIFtoStAGGE FX3固件示例,我得到了下面的错误,请在下面找到并附加固件。帮助我。谢谢您界面,拉链1.8兆字节BMP2.3兆字节 以上来自于百度
    发表于 10-17 16:21

    带LCD的PIC接口示例代码

    来编码LCD。我在寻找示例代码,在那里我可以编写简单的“Hello World”。 以上来自于百度翻译 以下为原文 I am trying to Interface http
    发表于 10-23 15:54

    请问ADC模数转换器的接口Serial LVDS Interface怎么与ARM相连?

    Interface,但是它的接口是Serial LVDS Interface,是不是不能与ARM直接连呢?应该要怎么接呢?请老师指导下!
    发表于 05-21 07:39

    可以获得Cyconsole的EZ-USB接口示例项目吗?

    您好!我愿意参考PC端Windows应用程序的供应商请求。我找不到CySead“EZ-USB接口示例项目”。我想在Windows新应用程序中实现供应商命令功能。你能给我示范项目文件吗? 以上
    发表于 05-22 07:24

    SCSI接口的具体使用和优势

    多任务接口,设有母线仲裁功能。挂在一个SCSI母线上的多个外设可以同时工作。SCSI上的设备平等占有总线。  二、SCSI的优势  (1)可支持多个设备,SCSI-2(FastSCSI)最多可接7个
    发表于 01-07 17:49

    Gowin DDR Memory Interface IP参考设计

    Interface IP 是一个通用的 DDR 内存接口 IP,符合 JESD79F 标准协议,该 IP 为用户提供一个通用的命令接口,使其与内存芯片进行互连,完成用户的访存需求。IP 包含 DDR 内存
    发表于 10-08 07:17

    SWD的接口对比JTAG接口有什么优势

    SWD的接口对比JTAG接口有什么优势
    发表于 10-09 07:09

    什么是BRI (Basic Rate Interface)

    什么是BRI (Basic Rate Interface)  英文缩写: BRI (Basic Rate Interface) 中文译名: 基本速率接口 分  类: 电信设备
    发表于 02-22 11:14 1359次阅读

    IIC_I2C接口_LCD1602转接板原理图_Arduno示例

    IIC I2C 接口 LCD1602转接板原理图 Arduno示例 驱动源码
    发表于 06-21 17:02 58次下载

    使用HDMI接口有哪些好处_HDMI接口优势在哪

    本文首先介绍了HDMI接口的类型,其次介绍了使用HDMI接口的好处,最后介绍了HDMI接口优势及适用范围。
    发表于 04-23 10:52 4w次阅读
    使用HDMI<b class='flag-5'>接口</b>有哪些好处_HDMI<b class='flag-5'>接口</b>的<b class='flag-5'>优势</b>在哪

    C#-Interface接口实现

    C#-Interface接口实现(安徽理士电源技术有限公司招聘信息)-该文档为C#-Interface接口实现讲解文档,是一份还算不错的参考文档,感兴趣的可以下载看看,,,,,,,,,
    发表于 09-28 09:42 3次下载
    C#-<b class='flag-5'>Interface</b><b class='flag-5'>接口</b>实现

    图形引擎服务场景化接口示例代码

    简介 图形引擎服务场景化接口示例代码演示了如何调用SceneView、ARView和FaceView进行图形渲染。 开发准备 1.检查Android Studio开发环境是否就绪。使用Android
    发表于 03-23 10:57 1次下载

    音频XLR(卡侬)接口的原理和优势

    音频XLR(卡侬)接口的原理和优势 音频XLR(卡侬)接口是一种常用于音频设备中的连接接口,它具有许多优势。本文将详细介绍音频XLR(卡侬)
    的头像 发表于 11-28 15:27 1280次阅读