sv中interface的学习心得以及modport

文章介绍了如何在SystemVerilog(SV)中使用interface进行模块间的通信,包括按名称和位置的例化方式,以及interface如何简化端口匹配的复杂性。通过示例展示了使用和不使用interface的仲裁器模型,强调了调用interface信号的不同方式。此外,还提到了modport在定义接口信号方向上的作用,即使不声明默认也为inout和ref,但推荐为代码规范进行声明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

因为是第二次学习interface的知识点,所以如鱼得水。

首先我想从例化开始讲:

就拿小例子来说,按名称例化:

被调用的模块名称  实例名字(自己定义)(.被调用信号(实例端口名),……);

按位置例化:

被调用的模块名称 实例名字 (实例端口名,……)  (!!!注意:要跟被调用的模块的端口信号连接保持一致顺序,没有引用的端口就用空格表示,比如“clk, ,sum”)

接下来我们说到sv中的interface。

首先是展示的通过interface连接的模型:

top模块

可以看到在顶层模块里,模块例化跟接口例化方式一样,但是减少了模块例化时端口信号一个一个匹配的复杂程度(这也是之前我第一次学习概念模糊的地方,不知道是怎么例化的)。

声明接口:

 

使用端口的仲裁器:

 测试文件:

下面是不使用interface的

仲裁器模型:

 测试文件

 

上述代码只要成功运行就行,结果到不重要。

还有强调一下调用方式,如果是调用sig,在模块中是通过A.B.C.sig去调用信号,而使用interface(不能包含层次化设计)调用是直接从根出发($root.top_tb)一层一层引用。

interface是通过把端口捆绑起来,然后你想声明每个端口模块的信号方向,可以在接口声明里使用modport指明方向:

 

 注意要将modport名放在接口名arb.if的后面

如果不声明modport,所有线网都是inout,所有变量传输方向都是ref。其实在一般使用时候,可以省略modport的声明(一般是不会对结果产生影响的,为了规范程序代码,还是可以声明)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值