模块和端口

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
相关推荐
s090713610 小时前
【Zynq 进阶一】深度解析 PetaLinux 存储布局:NAND Flash 分区与 DDR 内存分配全攻略
linux·fpga开发·设备树·zynq·nand flash启动·flash分区
Kong_199411 小时前
芯片开发学习笔记·二十——时序报告分析
fpga开发·芯片开发
凌盛羽15 小时前
使用python绘图分析电池充电曲线
开发语言·python·stm32·单片机·fpga开发·51单片机
尤老师FPGA16 小时前
LVDS系列44:Xilinx Ultrascale系 ADC LVDS接口参考方法(六)
fpga开发
化屾为海16 小时前
FPGA之PLL展频
fpga开发
GateWorld17 小时前
FPGA内部模块详解之七 FPGA的“灵魂”加载——配置模块(Configuration)深度解析
fpga开发·fpga config
星华云19 小时前
[FPGA]Spartan6 Uart可变波特率读写JY901P惯导模块
fpga开发·verilog·jy901p·spartan6·惯导
碎碎思19 小时前
基于 Gowin FPGA 的 SDR 开源方案:从硬件到射频全栈打通
fpga开发
S&Z34631 天前
[SZ901]高级功能:远程调试
fpga开发
醇氧1 天前
【学习】冯诺依曼架构和哈弗架构
fpga开发