当前位置: 首页 > news >正文

制作单页网站教程视频河南省信息服务平台官网

制作单页网站教程视频,河南省信息服务平台官网,网站建设 页面,品牌建设论文参考文献Verilog基础语法——parameter、localparam与define 写在前面一、localparam二、parameter三、define写在最后 写在前面 在使用Verilog编写RTL代码时#xff0c;如果需要定义一个常量#xff0c;可以使用define、parameter和localparam三种进行定义与赋值。 一、localparam … Verilog基础语法——parameter、localparam与define 写在前面一、localparam二、parameter三、define写在最后 写在前面 在使用Verilog编写RTL代码时如果需要定义一个常量可以使用define、parameter和localparam三种进行定义与赋值。 一、localparam localparam是一种局部常量只在声明该常量的模块中有效不可用于模块与模块之间的参数传递。一般在定义仅用于模块内部的参数时使用localparam比如状态机状态的定义声明。例如 // FSM Sate localparam IDLE 4b0001; localparam INPUT 4b0010; localparam DECODE 4b0100; localparam COMPLETE 4b1000;// FSM always (posedge clk or negedge rst_n) beginif(!rst_n) begincurr_state IDLE;//...endelse begincase(curr_state) IDLE:beginif(start)curr_state INPUT;elsecurr_state IDLE;//... endINPUT :begincurr_state DECODE;//...endDECODE : begincurr_state COMPLETE;//... endALL_COMPLETE:begincurr_state IDLE;enddefault :;endcaseend end二、parameter parameter与localparam相同的是其作用范围仅仅是声明该参数的模块内部而不同的是parameter可以用于模块之间的参数传递一般用于参数化设计。参数化设计是指对于所设计的功能子模块通过修改其内部参数值即可使得该模块适用于其他场景。   这里parameter可以分为在模块头部中声明与在模块内部定义声明两种定义方式需要不同的方式来进行参数传递。 1在模块头部中定义   在模块头部中定义参数是一种常用的做法其格式如下 module counter #(parameter CNT_NUM 8d128 ,parameter DIN_WIDTH 4d8 ,parameter DOUT_WIDTH 5d16 ) (input wire [DIN_WIDTH-1:0] din , output wire [DOUT_WIDTH-1:0] dout );// 模块内部代码// ...endmodule而在模块例化时需要与例化模块输入输出端口一样给参数接入不同的数值即可其格式如下 module top (// 输出输入声明// ... );localparam CNT_NUM 8d100;localparam DIN_WIDTH 4d6;localparam DOUT_WIDTH 5d12; wire [DIN_WIDTH-1:0] counter_din ; wire [DOUT_WIDTH-1:0] counter_dout;// 模块例化counter #(.CNT_NUM (CNT_NUM ), // 参数传递.DIN_WIDTH (DIN_WIDTH ), // 参数传递.DOUT_WIDTH(DOUT_WIDTH) // 参数传递)counter_inst(.din (counter_din ), .dout(counter_dout))// ...endmodule2在模块内部定义   在模块内部定义的paramter其格式如下 module counter (input wire [15:0] din , output wire [7:0] dout );parameter CNT_NUM 8d128 ;parameter DIN_WIDTH 4d8 ;parameter DOUT_WIDTH 5d16 ;// 模块内部代码// ...endmodule在上层模块的例化中可以通过defparam进行修改所例化模块中定义参数的值其格式如下 module top (// 输出输入声明// ... ) ;wire [15:0] counter_din ; wire [7:0] counter_dout;// 模块例化counter counter_inst(.din (counter_din ), .dout(counter_dout));// 格式// defparam 模块例化名称 参数名称 重新设定的参数值// 如果是多层嵌套子模块在模块3中例化模块2在模块2中例化模块1则格式为// defparam 模块3例化名称 模块2例化名称 模块1例化名称 参数名称 重新设定的参数值defparam counter_inst CNT_NUM 8d100;defparam counter_inst DIN_WIDTH 4d6;defparam counter_inst DOUT_WIDTH 5d12; endmodule这种方式的缺点在于该方式声明的parameter无法用于模块输入输出信号位宽的控制因为参数定义声明在模块的内部。 三、define 通过define定义的参数作用范围是整个设计工程文件遇到undef则失效其格式如下 define CNT_NUM 8d128 module counter (// 输出输入声明// ... )// 模块内部代码// ...endmodule也可以将所以define定义声明的参数放在一个单独文件中并在每个模块中使用include包含声明文件以作用于整个工程项目。其格式如下 // para_def.vh // 独立参数声明文件 define CNT_NUM 8d128 define DIN_WIDTH 4d6; define DOUT_WIDTH 5d12; 然后再每个模块的前面使用include包含该参数声明文件即可使用格式如下 // include 路径/参数声明文件名 include F/xxx/RTL/para_def.vh module counter (// 输出输入声明// ... )// 模块内部代码// ...// 使用格式参数名always (posedge clk) beginif(cnt CNT_NUM)elseendendmodule写在最后 在本文中我们学习了Verilog基础语法中三种不同的参数定义方式——localparam、parameter与define其中define定义的参数作用范围最广且支持用于模块之间的参数传递localparam作用范围仅为模块内部且不支持参数传递而parameter是两者的折中作用范围为模块内部但是支持参数传递。在实际代码编写过程中应选择合适的方式对不同参数进行声明使用时可以参考下表。 关键字适用场景localparam仅用于模块内部的参数且在不同场景下无需进行修改parameter仅用于模块内部的参数但是在不同场景下需要进行修改define整个工程文件中都会用到的参数 本文到此结束欢迎评论区交流探讨。
http://www.zqtcl.cn/news/42828/

相关文章:

  • 深圳美食教学网站制作网络设计报告总结
  • 建筑网站知乎按效果付费的网络推广方式
  • 建设网站一般流程百度推广怎么注册账号
  • 商务网站开发代码icp备案查询官网入口
  • 做的网站怎么发布一般通过人
  • 初中生做网站挣钱做网站用旧域名好不好
  • 外贸营销网站制作公司找产品厂家用哪个app
  • 陕西省建设注册中心网站哪里有网站建设哪家好
  • 国家和住房城乡建设部网站门户网站建站方案
  • vs中做网站怎么设置图片标准招聘网站做销售
  • 小程序网址链接提取东莞市网络优化推广公司
  • 潍坊网站设计好处做国际物流在哪些网站找客户
  • 专业网站建设设计装饰wordpress提权
  • 专业做家具的网站有哪些四川绵阳网站建设
  • 做服饰网站苏州cms建站
  • 山东网站策划怎么做产品软文
  • 昆山网站建设秦皇岛北京ifc大厦
  • 威海网站制作wordpress post 请求
  • 长沙大型做网站公司如何建单页网站栏目
  • 做定制网站多少钱东华网站开发
  • 美工做任务网站做app软件开发的公司
  • 关键词那种网站设计兼职网站
  • flash网站建设教程手游app平台推广微信xiala5
  • 安徽企业建站系统平台阿里云网站建设方案
  • 广州电商网站开发广东电白建设集团有限公司网站
  • 企业网站备案网站网站建设在电子商务中的作用的看法
  • 网站建设公司及网络安全法哪些网站比较容易做
  • 巩义便宜网站建设黄页88怎样发信息
  • 淘宝京东拼多多购物券网站怎么做WordPress显示不出广告
  • 模板网站建设合同口碑好的网站建设商家