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

verilog实现ram16*8 (vivado)

module ram_16x2 (input clk,        // 时钟信号input we,         // 写使能input en,         // 使能信号input [3:0] addr, // 地址线input [1:0] datain, // 输入数据线output reg [1:0] dataout // 输出数据线
);// 定义存储器数组reg [1:0] mem [15:0];always @(posedge clk) beginif (en) beginif (we) beginmem[addr] <= datain; // 写入数据enddataout <= mem[addr]; // 读取数据endendendmodulemodule ram_16x8 (input clk,          // 时钟信号input we,           // 写使能input en,           // 使能信号input [3:0] addr,   // 地址线input [7:0] datain, // 输入数据线output [7:0] dataout // 输出数据线
);// 输出数据线wire [1:0] dataout0, dataout1, dataout2, dataout3;// 实例化4个16×2位存储器ram_16x2 ram0 (.clk(clk),.we(we),.en(en),.addr(addr),.datain(datain[1:0]),.dataout(dataout0));ram_16x2 ram1 (.clk(clk),.we(we),.en(en),.addr(addr),.datain(datain[3:2]),.dataout(dataout1));ram_16x2 ram2 (.clk(clk),.we(we),.en(en),.addr(addr),.datain(datain[5:4]),.dataout(dataout2));ram_16x2 ram3 (.clk(clk),.we(we),.en(en),.addr(addr),.datain(datain[7:6]),.dataout(dataout3));// 合并4个16×2位存储器的输出数据assign dataout = {dataout3, dataout2, dataout1, dataout0};endmodule

 

http://www.lryc.cn/news/403852.html

相关文章:

  • 框架使用及下载
  • 通用图形处理器设计GPGPU基础与架构(四)
  • 会Excel就会sql?
  • MyBatis-Plus的几种常见用法
  • 【LeetCode】day15:110 - 平衡二叉树, 257 - 二叉树的所有路径, 404 - 左叶子之和, 222 - 完全二叉树的节点个数
  • 【网络安全的神秘世界】Error:Archives directory /var/cache/apt/archives/partial is missing.
  • 网络编程中的TCP和UDP
  • 基于python的时空地理加权回归(GTWR)模型
  • 什么是单例模式,有哪些应用?
  • adb命令操作手机各种开关
  • 【分布式存储系统HDFS】架构和使用
  • Linux 实验一Linux系统安装
  • 【人工智能】深度剖析AI伦理:强化隐私防线,推动算法公平性的核心议题
  • 如何解决微服务下引起的 分布式事务问题
  • 牛客周赛50轮+cf955+abc363
  • 【MySQL】:对库和表的基本操作方法
  • Library not found for -lstdc++.6.0.9
  • 防火墙之双机热备篇
  • 终端里面ifconfig命令无法运行
  • 掌握Python中的文件序列化:Json和Pickle模块解析
  • WordPress 6.6 “Dorsey多尔西”发布
  • 核函数支持向量机(Kernel SVM)
  • 二分查找(折半查找)
  • arcgis紧凑型切片缓存(解决大范围切片,文件数量大的问题)
  • ESP32CAM人工智能教学15
  • Pandas 33个冷知识 0721
  • C++ map和set的使用
  • yarn的安装和配置以及更新总结,npm的对照使用差异
  • 【Git命令】git rebase之合并提交记录
  • 为什么品牌需要做 IP 形象?