Verilog——参数化定义

目录

前言

这个专栏会专门讲一些Verilog的知识,后续会慢慢更新,欢迎关注
Verilog专栏

参数化定义 #( )

定义

verilog 复制代码
module Reg #(WIDTH = 1, RESET_VAL = 0) (  
//位宽默认为1 , 复位值默认为0
  input clk,  //时钟
  input rst,  //复位信号
  input [WIDTH-1:0] din,  //输入值
  output reg [WIDTH-1:0] dout,  //输出值
  input wen
);
  always @(posedge clk) begin
    if (rst) dout <= RESET_VAL;
    else if (wen) dout <= din;
  end
endmodule

实例化

verilog 复制代码
Reg #(8, 255) my_reg (
  .clk(clk),
  .rst(rst),
  .din(data_in),
  .dout(data_out),
  .wen(write_enable)
);
  • WIDTH被设置为8,因此dindout都是8位宽。
  • RESET_VAL被设置为255,所以在复位时,dout的初值为255。
  • 如果实例化时没有传入参数,则使用默认值,即WIDTH=1RESET_VAL=0
相关推荐
不羁的木木4 分钟前
【开源鸿蒙跨平台开发学习笔记】Day08:React Native 开发 OpenHarmony —— RN 与原生调用全解析
笔记·学习·harmonyos
lew-yu4 分钟前
博客摘录「 当前开源旗舰LLM主流架构介绍」2025年12月3日
笔记
('-')5 分钟前
《从根上理解MySQL是怎样运行的》第二十四章笔记
数据库·笔记·mysql
芯片智造7 分钟前
在HKMG工艺中,为什么不能再用多晶硅做栅极?
经验分享·芯片·半导体
LO嘉嘉VE8 分钟前
学习笔记二十四:支持向量机-对偶问题
笔记·学习·支持向量机
小李做物联网8 分钟前
52.1基于单片机stm32物联网嵌入式项目程序开发智体重秤体脂系统
stm32·单片机·嵌入式硬件·物联网·课程设计
爱凤的小光10 分钟前
Git自我学习笔记
笔记·git·学习
森林小狗1 小时前
0基础快速入门SEO笔记
笔记
其美杰布-富贵-李1 小时前
SpaceClaim 流体域建模学习笔记
笔记·学习
遇到困难睡大觉哈哈10 小时前
Harmony os——ArkTS 语言笔记(四):类、对象、接口和抽象类
java·笔记·spring·harmonyos·鸿蒙