模块和端口

1、模块

模块内部的5个组成是:变量声明 数据流语句 低层模块实例 函数和任务 行为语句

SR锁存器

复制代码
`timescale 1ns / 1ps

module SR_latch
    (
        input   wire    Sbar        ,
        input   wire    Rbar        ,
        
        output  wire    Q           ,
        output  wire    Qbar
    );
    
    nand    n1(Q,Sbar,Qbar) ;
    nand    n2(Qbar,Rbar,Q) ;
    
endmodule

tb_sr

复制代码
`timescale 1ns / 1ps



module tb();

    wire    Q,Qbar  ;
    reg     Sbar,Rbar   ;
    
    SR_latch    m1(Sbar,Rbar,Q,Qbar)    ;
    
    initial
    begin
        $monitor($time,"Sbar = %b   Rbar  =  %b   Q  =  %b",Sbar,Rbar,Q)    ;
        Sbar    =   1'b0    ;
        Rbar    =   1'b0    ;
        
        #5
            Rbar    =   1'b1    ;
        #5
            Rbar    =   1'b0    ;
        #5
            Sbar    =   1'b1    ;
    end

endmodule

2、端口

端口就是模块与外界环境交互的接口。

2.1、 端口列表

有端口列表的模块

复制代码
module    fulladd4
            (
                output        sum      ,
                output        c_out    ,

                input         a        ,
                input         b        ,
                input         c_in
            );

没有端口列表的仿真模块

复制代码
module    tb    ;

2.2、 端口申明

|------------|------|
| verilog关键字 | 端口类型 |
| input | 输入 |
| output | 输出 |
| inout | 双向端 |
[端口]

2.3、 端口连接规则

输入端口 必须为 线网数据类型。input可以外界 接 reg 或者 wire。

输出端口 可以为reg或者wire。总体而言 ,输出必须接到线网,不能接到reg。

inout端口 必须为 wire。

verilog 运行位宽不同,但是会给出 warn。

2.4、 端口 与 外部信号的连接

顺序端口连接

命名端口连接

这两种方式不能混用。

3、层次命名

如下,可以用 . 分隔。

复制代码
stimulus.Qbar.Q
相关推荐
博览鸿蒙29 分钟前
FPGA 工程中常见的基础硬件问题
fpga开发
GateWorld4 小时前
FPGA 实现无毛刺时钟切换
fpga开发·实战·无毛刺时钟
Seraphina_Lily6 小时前
从接口选型到体系结构认知——谈 CPU–FPGA–DSP 异构处理系统与同构冗余设计
fpga开发
Seraphina_Lily8 小时前
CPU–FPGA–DSP 异构系统中的总线接口选型——为什么 CPU 用 eLBC,而 DSP 用 XINTF?
fpga开发
GateWorld8 小时前
FPGA开发十年心路
fpga开发
ALINX技术博客1 天前
【ALINX 教程】FPGA Multiboot 功能实现——基于 ALINX Artix US+ AXAU25 开发板
fpga开发·fpga
Genevieve_xiao1 天前
【verilog】如何一小时成为verilog高手(并非
fpga开发
从此不归路1 天前
FPGA 结构与 CAD 设计(第3章)上
ide·fpga开发
Aaron15881 天前
基于VU13P在人工智能高速接口传输上的应用浅析
人工智能·算法·fpga开发·硬件架构·信息与通信·信号处理·基带工程
碎碎思1 天前
在 FPGA 上实现并行脉冲神经网络(Spiking Neural Net)
人工智能·深度学习·神经网络·机器学习·fpga开发