模块和端口

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
相关推荐
Js_cold4 小时前
Verilog局部参数localparam
开发语言·fpga开发·verilog
promising-w4 小时前
【FPGA】使用移位实现LED流水灯
fpga开发
爱吃汽的小橘5 小时前
ZYNQ介绍
fpga开发
ThreeYear_s15 小时前
电力电子技术学习路径与FPGA/DSP技术结合方向(gemini生成)
学习·fpga开发
奋斗的牛马19 小时前
FPGA—ZYNQ学习spi(六)
单片机·嵌入式硬件·学习·fpga开发·信息与通信
GateWorld1 天前
FPGA核心约束类型与语法
fpga开发
SKYDROID云卓小助手1 天前
无人设备遥控器之数字图传技术
运维·服务器·单片机·嵌入式硬件·fpga开发
Topplyz1 天前
在FPGA中实现频率计方案详解(等精度测量)
fpga开发·fpga·频率计
whik11941 天前
如何测量FPGA管脚的好坏
fpga开发
XINVRY-FPGA1 天前
XC7Z020-1CLG484I Xilinx AMD FPGA Zynq-7000 SoC
arm开发·嵌入式硬件·网络协议·fpga开发·硬件工程·信号处理·fpga