x
x

FPGA实战演练逻辑篇37:可综合的语法子集2

发布时间:2015-6-15 14:42    发布者:rousong1989
可综合的语法子集2
本文节选自特权同学的图书《FPGA设计实战演练(逻辑篇)》
配套例程下载链接:http://pan.baidu.com/s/1pJ5bCtt
(1)    参数定义:parameter。(特权同学,版权所有)
Parameter用于申明一些常量,主要是便于模块的移植或升级时的修改。(特权同学,版权所有)
一个基本的module,通常一定包括module…endmodule语法和任意两种端口申明(通常我们所设计的模块一定是有输入和输出的),parameter则不一定,但是对于一个可读性强的代码来说也是不可少的。这样一个基本的module如下:
module <模块命名>(<端口命名1>, <端口命名2>, ...);
    // 输入端口申明
    input <端口命名1>;
    input wire <端口命名2>;
    input [<最高位>:<最低位>]<端口命名3>;
    ...
    // 输出端口申明
    output <端口命名4>;
    output [<最高位>:<最低位>]<端口命名5>;
    output reg [<最高位>:<最低位>]<端口命名6>;
    ...
    // 双向(输入输出)端口申明
    inout <端口命名7>;
    inout [<最高位>:<最低位>]<端口命名8>;
    ...
    // 参数定义
    parameter <参数命名1> = <默认值1>;
    parameter [<最高位>:<最低位>]<参数命名2> = <默认值2>;
    ...
    // 具体功能逻辑代码
    ...
endmodule
注:“//”后的内容为注释。(特权同学,版权所有)
(2)    信号类型:wire,reg等。(特权同学,版权所有)
如图5.1所示,在这个简单的电路中,分别定义两个寄存器(reg)锁存当前的输入din。每个时钟clk上升沿到来时,reg都会锁存到最新的输入数据,而wire就是这两个reg之间直接的连线。(特权同学,版权所有)
作为input或inout的信号端口只能是wire型,而output则可以是wire也可以是reg。需要特别说明的是,虽然在代码中我们可以定义信号为wire或reg类型,但是实际的电路实现是否和我们预先的一致还要看综合工具的表现。例如reg定义的信号通常会被综合为一个寄存器(rigister),但这有一个前提,就是这个reg信号必须是在某个由特定信号边沿敏感触发的always语句中被赋值。(特权同学,版权所有)
1.jpg
图5.1 reg和wire示例图
Wire和reg的一些常见用法示例如下:
// 定义一个wire信号
wire ;
// 给一个定义的wire信号直接连接赋值
// 该定义等同于分别定义一个wire信号和使用assign语句进行赋值
wire =<常量或变量赋值>;
// 定义一个多bit的wire信号
wire [<最高位>:<最低位>] ;
// 定义一个reg信号
reg ;
// 定义一个赋初值的reg信号
reg =<初始值>;
// 定义一个多bit的reg信号
reg [<最高位>:<最低位>] ;
// 定义一个赋初值的多bit的reg信号
reg [<最高位>:<最低位>] = <初始值>;
// 定义一个二维的多bit的reg信号
reg [<最高位>:<最低位>] [<最高位>:<最低位>];

本文地址:https://www.eechina.com/thread-150601-1-1.html     【打印本页】

本站部分文章为转载或网友发布,目的在于传递和分享信息,并不代表本网赞同其观点和对其真实性负责;文章版权归原作者及原出处所有,如涉及作品内容、版权和其它问题,我们将根据著作权人的要求,第一时间更正或删除。
您需要登录后才可以发表评论 登录 | 立即注册

厂商推荐

  • Microchip视频专区
  • EtherCAT®和Microchip LAN925x从站控制器介绍培训教程
  • MPLAB®模拟设计器——在线电源解决方案,加速设计
  • 让您的模拟设计灵感,化为触手可及的现实
  • 深度体验Microchip自动辅助驾驶应用方案——2025巡展开启报名!
  • 贸泽电子(Mouser)专区
关于我们  -  服务条款  -  使用指南  -  站点地图  -  友情链接  -  联系我们
电子工程网 © 版权所有   京ICP备16069177号 | 京公网安备11010502021702
快速回复 返回顶部 返回列表