在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 1676|回复: 0

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

[复制链接]
发表于 2015-6-15 14:54:08 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x

可综合的语法子集2

本文节选自特权同学的图书《FPGA设计实战演练(逻辑篇)》

配套例程下载链接:http://pan.baidu.com/s/1pJ5bCtt


(1)
参数定义:parameter(特权同学,版权所有)

Parameter用于申明一些常量,主要是便于模块的移植或升级时的修改。(特权同学,版权所有)

一个基本的module,通常一定包括moduleendmodule语法和任意两种端口申明(通常我们所设计的模块一定是有输入和输出的),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之间直接的连线。(特权同学,版权所有)

作为inputinout的信号端口只能是wire型,而output则可以是wire也可以是reg。需要特别说明的是,虽然在代码中我们可以定义信号为wirereg类型,但是实际的电路实现是否和我们预先的一致还要看综合工具的表现。例如reg定义的信号通常会被综合为一个寄存器(rigister),但这有一个前提,就是这个reg信号必须是在某个由特定信号边沿敏感触发的always语句中被赋值。(特权同学,版权所有)

1.jpg

5.1 regwire示例图

Wirereg的一些常见用法示例如下:

// 定义一个wire信号

wire <wire变量名>;


// 给一个定义的wire信号直接连接赋值

// 该定义等同于分别定义一个wire信号和使用assign语句进行赋值

wire <wire变量名> =<常量或变量赋值>;


// 定义一个多bit的wire信号

wire [<最高位>:<最低位>] <wire变量名>;


// 定义一个reg信号

reg <reg变量名>;


// 定义一个赋初值的reg信号

reg <reg变量名> =<初始值>;


// 定义一个多bit的reg信号

reg [<最高位>:<最低位>] <reg变量名>;


// 定义一个赋初值的多bit的reg信号

reg [<最高位>:<最低位>] <reg变量名> = <初始值>;


// 定义一个二维的多bit的reg信号

reg [<最高位>:<最低位>] <reg变量名> [<最高位>:<最低位>];




您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条


小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-12-23 07:17 , Processed in 0.015246 second(s), 8 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表