【Verilog】期末复习——设计有32个16位存储器的ROM

系列文章

数值(整数,实数,字符串)与数据类型(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根。

verilog 复制代码
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
相关推荐
156082072198 小时前
在vivado中,国产CH347芯片实现USB转JTAG的操作
fpga开发
数字芯片实验室13 小时前
IP验证最终回归到时序级建模
网络·网络协议·tcp/ip·fpga开发
雨洛lhw13 小时前
三模冗余资源量对比
fpga开发·三模冗余技术
XINVRY-FPGA14 小时前
XC7VX690T-2FFG1761I Xilinx AMD FPGA Virtex-7
arm开发·嵌入式硬件·fpga开发·硬件工程·fpga
FPGA_无线通信17 小时前
FPGA 组合逻辑和时序逻辑
fpga开发
Js_cold18 小时前
Xilinx FPGA温度等级及选型建议
fpga开发·fpga·vivado·xilinx
从此不归路19 小时前
FPGA 结构与 CAD 设计(第5章)上
fpga开发
洋洋Young20 小时前
【Xilinx FPGA】7 Series Clocking 设计
fpga开发·xilinx fpga
1560820721920 小时前
FPGA下AD采集时钟相位的调整
fpga开发
从此不归路20 小时前
FPGA 结构与 CAD 设计(第5章)下
fpga开发