当前位置: 首页 > 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 clk

reg [C_ADDR-1:0]    s_init_ram_addr         ;  //初始化写地址
reg                 s_init_ram_wr           ;  //初始化写势能信号

reg                 s_ram_initial_done      ;  //初始化完成标志
always@(posedge i_clk)begin
    if(i_rst)begin
        s_initial_delay_cnt <= 7'd0;
        s_initial_delay_flag <= 1'b0;
    end
    else if(s_initial_delay_cnt == 7'b111_1111)begin//计数器结束条件
        s_initial_delay_cnt <= s_initial_delay_cnt;
        s_initial_delay_flag <= 1'b1;
    end
    else begin
        s_initial_delay_cnt <= s_initial_delay_cnt + 7'd1;
        s_initial_delay_flag <= s_initial_delay_flag;
    end
end

always@(posedge i_clk)begin
    if(i_rst)begin
        s_init_ram_addr <= 7'd0;
        s_init_ram_wr <= 1'b0;
        s_ram_initial_done <= 1'b0;
    end
    else 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;
    end
    else if(s_initial_delay_flag) begin
        s_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}}

相关文章:

  • 通过用户登录案例,详细说明线程的7种状态
  • 物联网 网络安全 概述
  • CloudberryDB(六)SPI拓展功能
  • 网络安全PPDR
  • Grafana——如何迁移Grafana到一台新服务器
  • 【人工智能】学会表达自己的需求是用好DeepSeek R1的关键
  • 优选算法《位运算》
  • C++ 虚表(Vtable)和虚基表(Vbtale)与 虚函数 和 虚继承
  • Linux网络 | 多路转接Poll
  • 轻松上手:2025年微服务教程
  • C++中常用的十大排序方法之3——插入排序
  • Redis 04章——持久化
  • PDF工具,个人作品,免费分享
  • sql语句的执行顺序
  • 【etcd】ubuntu22安装,与redis对比的区别
  • android studio 使用maven-publish 插件上传aar到远程maven仓库
  • DeepSeek 15天指导手册——从入门到精通
  • 认识vue-admin
  • 通过例子学 rust 个人精简版 1-1
  • Python 逻辑航道:控制流与循环的易错暗礁躲避 -- 4. 控制流与循环
  • 洗衣机无法有效杀菌
  • 想要“逆转”糖尿病,减少这两处脂肪是关键
  • 人民日报今日谈:坚决克服麻痹思想,狠抓工作落实
  • 贵州省黔西市发生载人游船侧翻事故
  • 准80后遵义市自然资源局局长陈清松任仁怀市委副书记、代市长
  • 哈马斯:愿与以色列达成为期5年的停火协议