BRAM 读写模式分析

本文详细介绍了FPGA开发中BRAMIPcore的各种读写模式,包括nochange、readfirst、writefirst、异步读、伪同步读和真同步读,以及它们在处理读写冲突时的行为差异。
摘要由CSDN通过智能技术生成

FPGA开发中使用BRAM IP core可以配置读写模式,以下分析不同的模式bram行为的不同:
1、no change

        是一种读、写互不干扰的模式,他的HDL code 描述如下

reg    [7:0]    RAM[0:255]    ;

always@(posedge clk)
begin
    if(en == 1'b1)
    begin
        if(we == 1'b1)
        begin
            RAM[addr]    <=    din    ;
        end
        else
        begin
            dout <= RAM[addr]        ;
        end
    end
    else
    begin    
        dout    <=     0    ;
    end
end

 2、read first

发生读写冲突时读优先的操作模式

reg    [7:0]    RAM[0:255]    ;

always@(posedge clk)
begin
    if(en == 1'b1)
    begin
        if(we == 1'b1)
        begin
            RAM[addr]    <=    din    ;
        end
        dout <=    RAM[addr]    ;
    end
    else
    begin
        dout <=     0    ;
    end
end

3、write first

发生读写冲突时、写优先的操作

reg    [7:0]    RAM[0:255]    ;

always@(posedge clk)
begin
    if(en == 1'b1)
    begin
        if(we == 1'b1)
        begin
            RAM[addr]    <=     din    ;
            dout         <=     din    ;
        end
        else
        begin
            dout <= RAM[addr]        ;
        end
    end
    else
    begin
        dout <= 0    ;
    end
end

4、异步读

异步读模式不需要操作 en 信号,当we信号有效时,RAM写入当前的din,无论何时,dout都会根据addr输出bram中的数据,当读写冲突发生的时候,dout会先输出旧的值,写操做完成之后输出写入的值

reg    [7:0]    RAM[0:255]    ;

always@(posedge clk)
begin
    if(we == 1'b1)
    begin
        RAM[addr]    <=    din    ;
    end
    
    assign dout = RAM[addr]    ;

end

5、伪同步读

采用实际上是异步但表现上好似同步的方式读取BRAM中的数据

reg    [7:0]    RAM[0:255]    ;

always@(posedge clk)
begin
    if(we == 1'b1)
    begin
        RAM[addr]    <=    din    ;
    end
    dout <=    RAM[addr]        ;
end

6、真同步读

采用同步的方式从ram中读数据的操作模式

reg    [7:0]    RAM[0:255]    ;

always@(posedge clk)
begin
    if(we == 1'b1)
    begin
        RAM[addr]    <=    din    ;
    end
    addr_lock    <=    addr    ;
end
assign    dout    <=    RAM[addr_lock]    ;

        

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值