【Verilog】期末复习——设计有32个16位存储器的ROM
2024-01-09 10:07:27
系列文章
数值(整数,实数,字符串)与数据类型(wire、reg、mem、parameter)
运算符
数据流建模
行为级建模
结构化建模
组合电路的设计和时序电路的设计
有限状态机的定义和分类
期末复习——数字逻辑电路分为哪两类?它们各自的特点是什么?
期末复习——VerilogHDL描述数字逻辑电路的建模方式有哪三种?它们的特点是?
期末复习——解释下列名词(FPGA、ASIC、IP、RTL、EDA、HDL、FSM)
期末复习——简要说明仿真时阻塞赋值和非阻塞赋值的区别。always语句和initial语句的关键区别是什么?能否相互嵌套?
期末复习——设计带进位输入和输出的8位全加器,包括测试模块
期末复习——举重比赛有三名裁判,当运动员将杠铃举起后,须有两名或两名以上裁判认可,方可判定试举成功,若用A、B、C分别代表三名裁判的意见输入,同意为1,否定为0;F为裁判结果输出
期末复习——设计一个带异步复位端且高电平有效的32分频电路
期末复习——设计带异步清零且高电平有效的4位循环移位寄存器
期末复习——设计11011序列检测器电路
设计有32个16位存储器的ROM
位宽是16位,个数是32个。也就是说数据线有16根,地址线有5根。
module rom(clk,cs_n,addr,dout)
input clk,cs_n;
input[4:0] addr;//地址线是5根
output reg[15:0] dout;//数据是16位的
//定义ROM
reg[15:0] rom[31:0];//reg后紧跟着的是存储器的位数,rom后面的是存储器的个数
//给ROM赋初值
integer i;
initial
begin
for (i=0;i<31;i=i+1)
rom[i]=16'h00000000;
end
//根据地址取单元里的内容
always @(*)
begin
if (cs_n==1) dout<=16'bzzzzzzzz;
else dout<=rom[addr];
end
endmodule
文章来源:https://blog.csdn.net/m0_60511809/article/details/135470901
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!