一、參数映射

參数映射的功能就是实现參数化元件。所谓的”參数化元件“就是指元件的某些參数是可调的,通过调整这些參数从而可实现一类结构类似而功能不同的电路。在应用中。非常多电路都可採用參数映射来达到统一设计。如计数器、分频器、不同位宽的加法器以及不同刷新频率的VGA视频接口驱动电路等。

參数传递

參数传递就是在编译时对參数又一次赋值而改变其值。

传递的參数是子模块中定义的parameter,其传递方法有以下两种。

  • 时钟”#“符号
在同一模块中使用”#“符号。參数赋值的顺序必须与原始模块中进行參数定义的顺序同样,并非一定要给全部的參数都赋予新值,但不同意跳过不论什么一个參数。即使是保持不变的值也要写在对应的位置。
module #(parameter1, parameter2) inst_name(port_map);
module_name #(.parameter_name(para_value), .parameter_name(para_value)) inst_name(port_map);
例:通过”#“字符实现一个模值可调的加1计数器
module cnt(
input clk,
input rst,
output reg[15:0] cnt_o
);
//定义參数化变量
parameter[15:0] Cmax = 1024; always @(posedge clk or negedge rst) begin
if(!rst)
cnt_o <= 0;
else
if(cnt_o == Cmax)
cnt_o <= 0;
else
cnt_o <= cnt_o + 1;
end endmodule
module param_counter(
input clk,
input rst,
output [15:0] cnt_o
); //參数化调用。利用#符号将计数器的模值10传入被调用模块
cnt #10 inst_cnt(
.clk(clk),
.rst(rst),
.cnt_o(cnt_o)
);
endmodule




  • 使用defparamkeyword
defparamkeyword能够在上层模块去直接改动下层模块的參数值。从而实现參数化调用。其语法格式例如以下:
defparam heirarchy_path.paramer_name = value;
这样的方法与例化分开,參数须要写绝对路径来指定。

參数传递时各个參数值的排列次序必须与被调用模块中各个參数的次序保持一致。而且參数值和參数个数也必须同样。

假设仅仅希望对被调用模块内的个别參数进行更改,所有不须要更改的參数值也必须按相应參数的顺序在參数值列表中所有列出(原值拷贝)。
使用defparam语句进行又一次赋值时必须參照原參数的名字生成成分级參数名。
例:通过”defparam“实现一个模值可调的加1计数器。
module param_counter(
input clk,
input rst,
output [15:0] cnt_o
); //參数化调用,利用#符号将计数器的模值10传入被调用模块
cnt inst_cnt(
.clk(clk),
.rst(rst),
.cnt_o(cnt_o)
);
//同过defparam改动參数
defparam inst_cnt.Cmax = 12;
endmodule

二、寄存器类型

寄存器变量,都有“寄存性”,即在接手下一次赋值前。将保持原值不变。寄存器型变量没有强度之分,且全部寄存器类变量都必须明白给出类型说明(无缺省状态)。寄存器数据类型这里仅介绍两种经常使用类型。

  • reg:经常使用的寄存器型变量。用于行为描写叙述中对寄存器类的说明,由过程赋值语句赋值;
  • Integer: 32位带符号整型变量
1、reg寄存器类型
寄存器数据类型reg是最常见的数据类型。寄存器能够取随意长度。reg型数据的缺省值是未知的,reg型数据能够为正值或负值。

但当一个reg型数据是一个表达式中的操作数时,它的值被当无符号值,即正值。

假设一个4位的reg型数据被写入-1,在表达式中运算时,其值被觉得是+15。比如:

reg [3:0] Comb;
Comb = -2; //Comb的值为14(1110),1110是-2的补码

2、integer寄存器类型
整数寄存器包括整数值。

整数寄存器能够作为普通寄存器使用。使用整数型说明形式例如以下:

integer integer1, integer2,......integerN[msb:lsb];
integer Hist[3:6]; //一组四个寄存器
一个整数型寄存器可存储有符号数。而且算术操作符提供2的补码运算结果。整数不能作为向量訪问。比如,对于上面的整数B的说明,B[6]和B[20:10]是非法的。一种截取位值的方法是将整数赋值给一般的reg类型变量,然后从中选取对应的位。例如以下:
reg [31:0] Breg;
integer Bint;
Breg = Bint;
上例说明了假设通过简单的赋值将整数装换为位向量。类型转型自己主动完毕。不必使用特定的函数。

从位向量到整数的转换也能够通过赋值完毕。比如:

integer J;
reg [3:0] Bcq;
J = 6; //J的值为32‘b0000...00110
Bcq = J; //Bcq的值为4'b0110
Bcq = 4'd0101;
J = Bcq; //J的值为32’b0000...00101
J = -6; // J的值为32‘b1111...11010
Bcq = J ; //Bcq的值为4'b1010






















































FPGA编程基础(一)--參数传递与寄存器使用的更多相关文章

  1. ionic新手教程第七课-简要说明几种界面之间的參数传递及优缺点

    截至2016年4月13日19点32分,我公布的ionic新手教程,已经公布6课了, 总訪问量将近6000,平均每节课能有1000的訪问量.当中訪客最多的是第三课有2700的訪客. watermark/ ...

  2. java參数传递机制浅析

    欢迎转载,转载请声明出处! ----------------------------------------- 前言: java语言中,參数的传递仅仅有一种机制.那就是值传递. 举例: 以下将通过几个 ...

  3. c++參数传递

    定义: 形參:指出如今Sub 和Function过程形參表中的变量名.数组名,该过程在被调用前.没有为它们分配内存.其作用是说明自变量的类型和形态以及在过程中的作用.形參能够是除定长字符串变量之外的合 ...

  4. activity之间參数传递&amp;&amp;获取activity返回值&amp;&amp;activity生命周期

    Activity之间參数传递 A activity想将參数传给B activity时能够利用Intent将消息带过去 Intent intent = new Intent(this,BActivity ...

  5. 再次学习javascript中的參数传递

     javascript中的全部函数的參数传递都是依照值传递的,做了以下測试:    function addTen(num){ num +=10; return num; } var count = ...

  6. Fragment进阶(四)-----&gt;參数传递3种写法

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/ ...

  7. 关于mybatis中,批量增删改查以及參数传递的问题

    1.參数传递的问题 大多数情况下,我们都是利用map作为參数,而且大部分情况下都是仅仅有一个參数. 可是,我们也能够利用@param注解,来传入多个參数,此时,mybatis会自己主动将參数封装成ma ...

  8. int 0x13中断的參数传递

    int 0x13中断向量所指向的中断服务程序实质上就是磁盘服务程序. 用途:将指定扇区的代码载入到内存的指定位置. 因此,在使用int 0x13中断时要将參数传递给服务程序: 比如:将指定扇区和载入的 ...

  9. C# 多线程參数传递

    1.通过实体类来传递(能够传递多个參数与获取返回值),demo例如以下: 须要在线程中调用的函数: namespace ThreadParameterDemo { public class Funct ...

随机推荐

  1. 设备类型检测大全---userAgent

    对各种类型的设备的检测,以及所使用的浏览器的类型 function detect(ua) { var os = this.os = {}; var browser = this.browser = { ...

  2. Python爬虫入门:Cookie的使用

    大家好哈,上一节我们研究了一下爬虫的异常处理问题,那么接下来我们一起来看一下Cookie的使用. 为什么要使用Cookie呢? Cookie,指某些网站为了辨别用户身份.进行session跟踪而储存在 ...

  3. 新增加的HTTP状态码 -- 103

    IETF公布了新的HTTP状态码-103, 总结一下就是提前预加载(css.js)文档,提升用户的访问速度. Summary: a new status code that lets the serv ...

  4. struts2 中文乱码问题,自定义过滤器通用解决方法

    问题描述 在JSP中使用form表单向后台action中传递中文参数,后台action接收到参数出现中文乱码.JSP页面统一采用了utf-8编码格式.由于struts2默认采用的编码为utf-8,根据 ...

  5. Socket 的理解及实例

    Socket 的理解及实例Socket 的理解TCP/IP要想理解socket首先得熟悉一下TCP/IP协议族, TCP/IP(Transmission Control Protocol/Intern ...

  6. .net core 依赖注入扩展,实现随处控制反转

    在使用.net core时,依赖注入,主要使用通过构造函数注入.小编将通过扩展方式,实现在类中各个地方可以控制反转,获取实例. 1.首先自定义扩展类 using Microsoft.AspNetCor ...

  7. Python小爬虫

                  网页解析器下载网址: http://www.crummy.com/software/BeautifulSoup/                               ...

  8. [转载] 高性能IO模型浅析

    转载自http://www.cnblogs.com/fanzhidongyzby/p/4098546.html 服务器端编程经常需要构造高性能的IO模型,常见的IO模型有四种: (1)同步阻塞IO(B ...

  9. Ubuntu初始化设置

    1.安装chrome sudo apt-get install chromium-browser sudo apt-get install pepperflashplugin-nonfree sudo ...

  10. Python 标准库 urllib2 的使用细节(转)

    http://www.cnblogs.com/yuxc/archive/2011/08/01/2123995.html http://blog.csdn.net/wklken/article/deta ...