Verilog模块概念和实例化

模块的概念

模块(module)是verilog最基本的概念,是v设计中的基本单元,每个v设计的系统中都由若干module组成。

1、模块在语言形式上是以关键词module开始,以关键词endmodule结束的一段程序。

2、模块的实际意义是代表硬件电路上的逻辑实体

3、每个模块都实现特定的功能。

4、模块的描述方式有行为建模结构建模之分。

5、模块之间是并行运行的。

6、模块是分层的,高层模块通过调用、连接低层模块的实例来实现复杂的功能。

7、各模块连接完成整个系统需要一个顶层模块(top-module)。

无论多么复杂的系统,总能划分成多个小的功能模块。系统的设计可以按照下面三个步骤进行:

(1)把系统划分成模块;

(2)规划各模块的接口;

(3)对模块编程并连接各模块完成系统设计。

模块的结构

module <模块名>(<端口列表>);

<定义>

<模块条目>

endmodule

其中:

<模块名>是模块唯一的标识符;

<端口列表>是输入、输出和双向端口的列表,这些端口用来与其他模块进行连接。

<定义>是一段程序,用来指定数据对象为寄存器型、存储器型、线型以及过程块,诸如函数块和任务块;

<模块条目>也是一段程序,将上面<定义>和<端口>组合起来,是说明这个模块要做什么的语句;

endmodule之后没有分号。

模块的调用

在做模块划分时,通常会出现这种情形:某个大的模块中包含了一个或多个功能子模块。verilog是通过模块调用或称为模块实例化的方式来实现这些子模块与高层模块的连接的。

调用模块实例的一般形式为:

<模块名><参数列表><实例名>(<端口列表>);

module_nameinstance_name(port_associations) ;

其中参数列表是传递到子模块的参数值,参数传递的典型应用是定义门级时延。

信号端口可以通过位置名称关联;但是关联方式不能够混合使用。

port_expr          //位置关联

.PortName (port_expr)      //名称关联

定义模块:module Design(端口1,端口2,端口3……);

1)引用时,严格按照模块定义的端口顺序来连接,不用标明原模块定义时规定的端口名。

Design u_1(u_1的端口1,u_1的端口2,u_1的端口3,u_1的端口……);//和Design对应

2)引用时用”.”符号,标明原模块定义时规定的端口名:

Design u_2(    .(端口1(u_1的端口1),

.(端口2(u_1的端口2),

.(端口3(u_1的端口3),

……  );  //建议:在例化的端口映射中采用名字关联,这样,当被调用的模块管脚改变时不易出错。

eg.

module and (C,A,B);

input A,B;

output C;

...

and A1 (T3,A,B); //实例化时采用位置关联,T3对应输出端口C,A对应A,B对应B。

and A2 (     .C(T3),

.A(A),

.B(B) );//实例化时采用名字关联,.C是and器件的端口,其与信号T3相连

port_expr 可以是以下的任何类型:

1) 标识符(reg 或net )如 .C(T3),T3 为wire 型标识符。

2) 位选择,如 .C(D[0]),C 端口接到D 信号的第0bit 位。

3) 部分选择,如 .Bus (Din[5:4])。

4) 上述类型的合并,如 .Addr({ A1,A2[1:0]}。

5) 表达式(只适用于输入端口),如 .A (wire Zire = 0 )。

参数传递:引用模块时,注意对运用参数编写的模块的灵活引用。

eg.

module Decoder(A,F);

parameterWidth=1,Polarity=1;

…….

endmodule

引用时:

module Top;

wire[3:0] A4;

wire[4:0] A5;

wire[15:0] F16;

wire[31:0] F32;

Decoderu_D1(A4,F16);    //u_D1使用默认参数,Width为1,Polarity为1

Decode #(4,0) u_D2(A4,F16);   //u_D2的Width为4,Polarity为0

#(4,0)这个参数改变方法是内容对应于被引用的module的,参数的改变还可以像module的引用一样使用”.”:

module_name #( .parameter_name(para_value),.parameter_name(para_value)) inst_name (port map);

悬空端口的处理

在实例化中,可能有些管脚没用到,可在映射中采用空白处理。

eg.

DFF d1 (     .Q(QS),

.Qbar ( ),

.Data (D ) ,

.Preset ( ), // 该管脚悬空

.Clock (CK) ); //名称对应方式。

输入管脚悬空,该管脚输入为高阻 Z,

输出管脚悬空,该管脚废弃不用。

Verilog模块概念和实例化#转载自Jason from Lofter的更多相关文章

  1. 如何将自己写的verilog模块封装成IP核

    如何将自己写的verilog模块封装成IP核 (2014-11-21 14:53:29) 转载▼ 标签: 财经 分类: 我的东东 =======================第一篇========= ...

  2. 利用python自动生成verilog模块例化模板

    一.前言 初入职场,一直忙着熟悉工作,就没什么时间更新博客.今天受“利奇马”的影响,只好宅在家中,写写技术文章.芯片设计规模日益庞大,编写脚本成了芯片开发人员必要的软技能.模块端口动不动就几十上百个, ...

  3. [转]System Verilog的概念以及与verilog的对比

    原文地址: http://blog.csdn.net/gtatcs/article/details/8970489 SystemVerilog语言简介 SystemVerilog是一种硬件描述和验证语 ...

  4. System Verilog的概念以及与verilog的对比

    以下内容源自:http://blog.csdn.net/gtatcs/article/details/8970489 SystemVerilog语言简介 SystemVerilog是一种硬件描述和验证 ...

  5. FPGA小白学习之路(1) System Verilog的概念以及与verilog的对比(转)

    转自CSDN:http://blog.csdn.net/gtatcs/article/details/8970489 SystemVerilog语言简介 SystemVerilog是一种硬件描述和验证 ...

  6. 理解前端模块概念:CommonJs与ES6Module

    前言 现代前端开发每时每刻都和模块打交道.例如,在项目中引入一个插件,或者实现一个供全局使用组件的JS文件.这些都可以称为模块. 在设计程序结构时,不可能把所有代码都放在一起.更为友好的组织方式时按照 ...

  7. Verilog 模块参数重定义(转)

    Verilog重载模块参数: 当一个模块引用另外一个模块时,高层模块可以改变低层模块用parameter定义的参数值,改变低层模块的参数值可采用以下两种方式: 1)defparam 重定义参数语法:d ...

  8. Cesium原理篇:6 Render模块(6: Instance实例化)

    最近研究Cesium的实例化,尽管该技术需要在WebGL2.0,也就是OpenGL ES3.0才支持.调试源码的时候眼前一亮,发现VAO和glDrawBuffers都不是WebGL1.0的标准函数,都 ...

  9. Javascript模块化编程(一):模块的写法 (转载 学习中。。。。)

    转载地址:http://www.ruanyifeng.com/blog/2012/10/javascript_module.html 阮一峰 大神:http://www.ruanyifeng.com/ ...

随机推荐

  1. procdump64+mimikatz获取win用户hash密码

    1.导出lsass.exe procdump64.exe -accepteula -ma lsass.exe lsass.dmp 2.执行mimikatz mimikatz.exe "sek ...

  2. swoole与php协程实现异步非阻塞IO开发

    “协程可以在遇到阻塞的时候中断主动让渡资源,调度程序选择其他的协程运行.从而实现非阻塞IO” 然而php是不支持原生协程的,遇到阻塞时如不交由异步进程来执行是没有任何意义的,代码还是同步执行的,如下所 ...

  3. 利用git工具将自己的代码文件上传到Github

    GitHub 是一个面向开源及私有软件项目的托管平台,作为开源代码库以及版本控制系统,Github拥有超过900万开发者用户.随着越来越多的应用程序转移到了云上,Github已经成为了管理软件开发以及 ...

  4. 玩转PubSubClient MQTT库

    1.前言     在ESP8266学习系列中,博主一直使用HTTP协议.HTTP连接属于短连接,而在物联网应用中,广泛应用的却是MQTT协议.所以,本篇我们将学习Arduino平台上的MQTT实现库 ...

  5. 【MongoDB详细使用教程】四、python操作MongoDB

    目录 1.安装pymongo 2.连接数据库 3.操作数据库 3.1.查 3.2.增 3.3.改 3.4.删 使用第三方库pymongo来实现python对MongoDB的操作 pymongo官方文档 ...

  6. 使用 pdf.js 在网页中加载 pdf 文件

    在网页中加载并显示PDF文件是最常见的业务需求.例如以下应用场景:(1)在电商网站上购物之后,下载电子发票之前先预览发票.(2)电子商务管理系统中查看发布的公文,公文文件一般是PDF格式的文件. 目前 ...

  7. 百万年薪python之路 -- 装饰器

    装饰器 1.1 开放封闭原则 开放封闭原则具体定义是这样: 1.对扩展是开放的 我们说,任何一个程序,不可能在设计之初就已经想好了所有的功能并且未来不做任何更新和修改.所以我们必须允许代码扩展.添加新 ...

  8. python3.x以上 爬虫 使用问题 urllib(不能使用urllib2)

    问题一: python 3.x 以上版本揽括了 urllib2,把urllib2 和 urllib 整合到一起. 并且引入模块变成一个,只有 import urllib # import urllib ...

  9. Spring(五)Spring缓存机制与Redis的结合

    一.Redis和数据库的结合 使用Redis可以优化性能,但是存在Redis的数据和数据库同步的问题. 例如,T1时刻以将 key1 保存数据到 Redis,T2时刻刷新进入数据库,但是T3时刻发生了 ...

  10. Mysql数据库(一)数据库设计概述

    1.数据库的体系结构 1.1 数据库系统的三级模式结构是指模式.外模式和内模式. 1.2 三级模式之间的映射分为外模式/模式映射和模式/内模式映射. 2.E-R图也称“实体-关系图”,用于描述现实世界 ...