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

ram的使用——初始化很重要

背景

ram是非常常用的ip,前人的经验告诉我们,如果不对ram进行初始化直接读写,不定态在实际上板时会出现不可预知的问题。

我们需要对ram进行初始化写0操作,代码如下。需要注意,复位释放时立马写入可能存在复位抖动的造成ram写入失败的问题,因此可以选择复位后增加一定的延时。

当inital_done信号拉高以后才允许系统开始工作。

 下面是复位初始化ram的代码:

parameter C_ADDR = 10;//ram地址位宽 DEPTH = 1024
parameter C_WIDTH = 10;//ram数据位宽reg                 s_initial_delay_flag    ;  //延迟标志
reg [6:0]           s_initial_delay_cnt     ;  //延迟计数器 128 clkreg [C_ADDR-1:0]    s_init_ram_addr         ;  //初始化写地址
reg                 s_init_ram_wr           ;  //初始化写势能信号reg                 s_ram_initial_done      ;  //初始化完成标志
always@(posedge i_clk)beginif(i_rst)begins_initial_delay_cnt <= 7'd0;s_initial_delay_flag <= 1'b0;endelse if(s_initial_delay_cnt == 7'b111_1111)begin//计数器结束条件s_initial_delay_cnt <= s_initial_delay_cnt;s_initial_delay_flag <= 1'b1;endelse begins_initial_delay_cnt <= s_initial_delay_cnt + 7'd1;s_initial_delay_flag <= s_initial_delay_flag;end
endalways@(posedge i_clk)beginif(i_rst)begins_init_ram_addr <= 7'd0;s_init_ram_wr <= 1'b0;s_ram_initial_done <= 1'b0;endelse if(s_init_ram_addr == {C_ADDR-1{1'b1}})begin//s_init_ram_addr <= s_init_ram_addr;s_init_ram_wr <= 1'b0;s_ram_initial_done <= 1'b1;endelse if(s_initial_delay_flag) begins_init_ram_addr <= s_init_ram_addr + 7'd1;s_init_ram_wr <= 1'b1;s_ram_initial_done <= 1'b0;end
end
//例化ram
//initial data = {C_WIDTH-1{1'b0}}

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

相关文章:

  • doris:最佳实践
  • [创业之路-299]:图解金融体系结构
  • RL--2
  • [JVM篇]分代垃圾回收
  • Dify本地安装
  • python | 两招解决第三方库安装难点
  • stm32mp15x 之 M4 使用 canfd
  • 第七天:数据提取-正则表达式
  • Python入门全攻略(六)
  • MongoDB副本集
  • 登录弹窗效果
  • C++上机_日期问题
  • 应对DeepSeek总是服务器繁忙的解决方法
  • web第三次作业
  • 力扣 438.找到字符串中所有字母异位词
  • 【Python】Python入门——基础语法及顺序语句
  • 2.2 反向传播:神经网络如何“学习“?
  • frp-tool,客户端frp命令行工具
  • 【学术投稿-第五届应用数学、建模与智能计算国际学术会议】CSS伪类选择器深度解析:分类、应用与技巧
  • 常用查找算法整理(顺序查找、二分查找、哈希查找、二叉排序树查找、平衡二叉树查找、红黑树查找、B树和B+树查找、分块查找)
  • Express 中 res 响应方法详解
  • DeepAR:一种用于时间序列预测的深度学习模型
  • 权限模型深度解析:RBAC vs ABAC vs PBAC vs TBAC,如何选择最适合的方案?
  • Windows逆向工程入门之堆栈结构与信息获取
  • 【c++初阶】类和对象②默认成员函数以及运算符重载初识
  • 【做一个微信小程序】校园地图页面实现
  • 成熟开发者需具备的能力
  • 计算机毕业设计--基于深度学习技术(Yolov11、v8、v7、v5)算法的高效人脸检测模型设计与实现(含Github代码+Web端在线体验界面)
  • 力扣做题记录 (二叉树)
  • 机试刷题_字符串的排列【python】