IP核之RAM

本文详细介绍了RAM的工作原理,包括单端口和双端口的区别,以及如何在Quartus中配置和调用RAM。还提供了单端口和双端口的仿真代码及其效果分析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一.RAM简介

  • RAM(Random Access Memory),即随机存取存储器,可以将数据写入地址,可以随时从任意指定地址读取数据。时钟频率决定了读取速度。

1.单端口

  • 只有一个地址线控制读数据端口和写数据端口

2.双端口

  • 两个地址线分别控制读数据端口和写数据端口(双端口又分为伪双端口和真双端口)

2.1伪双端口

  • 一组读数据和读地址线,一组写数据和写地址线,能同时进行读和写操作,但不能同时对同一地址进行读和写操作。

2.2真双端口

  • 有两组读数据线与读地址线,两组写数据线与写地址线;能同时进行两个端口读,能同时进行两个端口写,也能一个端口读同时另一个端口写。

二.RAM配置(单端口)

  • 右侧IP catelog中输入RAM后选择RAM:1-PORT
    在这里插入图片描述

  • 选择保存的位置和文件名
    在这里插入图片描述

  • 配置数据位大小和深度,以及选择单时钟
    在这里插入图片描述

  • 选中复位信号以及使能信号
    在这里插入图片描述

  • Next后保持默认
    在这里插入图片描述

  • Next后保持默认
    在这里插入图片描述

  • Next后保持默认
    在这里插入图片描述

  • 勾选xxx_inst.v文件
    在这里插入图片描述

  • 完成后Quartus弹窗点击yes即可
    在这里插入图片描述

三.RAM调用(单端口)

  • 在工程文件夹下的子文件夹rtl中新建RAM_test1.v文件,在其中调用我们刚生成的_inst.v文件,其代码如下
module RAM_test1(
    input           clk     ,
    input           rst_n   ,
    input           rden    ,
    input           wren    ,
    input   [7:0]   address ,
    input   [7:0]   data    ,

    output  [7:0]   q
);

    RAM_1port	RAM_1port_inst (
    	.aclr ( ~rst_n ),
    	.address ( address ),
    	.clock ( clk ),
    	.data ( data ),
    	.rden ( rden ),
    	.wren ( wren ),
    	.q ( q )
    );
endmodule
  • 需要注意的是:和PLL一样,IP核异步复位高有效,系统复位低有效。因此例化时需要取反

四.RAM仿真(单端口)

4.1仿真代码

`timescale 1ns/1ns
    
module tb_RAM_test1();

//激励信号定义 
    reg				tb_clk  	;
    reg				tb_rst_n	;
    reg				tb_rden	    ;
    reg             tb_wren     ;
    reg     [7:0]   tb_address  ;
    reg     [7:0]   tb_data     ;

//输出信号定义	 
    wire	[7:0]		tb_q	;

//时钟周期参数定义	
    parameter		CLOCK_CYCLE = 20;   

//模块例化
    RAM_test1 u_RAM_test1(	
        .clk     (tb_clk),
        .rst_n   (tb_rst_n),
        .rden    (tb_rden),
        .wren    (tb_wren),
        .address (tb_address),
        .data    (tb_data),
        .q       (tb_q)
    );

//产生时钟
    initial 		tb_clk = 1'b0;
    always #(CLOCK_CYCLE/2) tb_clk = ~tb_clk;

    integer i,j;
//产生激励
    initial begin
        tb_rst_n = 1'b1;
        #200.1;
        tb_rst_n = 1'b0;
        
        tb_wren = 1'b0;//赋初值
        tb_rden = 1'b0;
        tb_data = 0;
        tb_address = 0;
        #200;
        tb_rst_n = 1'b1;
        #200;

        //写数据
        for(i=0;i<256;i=i+1)begin
            tb_wren = 1'b1;//高电平有效
            tb_address = i;
            tb_data = i * 3;
            #20;
        end
        tb_wren = 1'b0;//写完拉低
        #100;

        //读数据
        for(j=0;j<256;j=j+1)begin
            tb_rden = 1'b1;
            tb_address = j;
            #20;
        end
        tb_rden = 1'b0;//读完拉低
        #200;

        $stop;
    end

endmodule 

4.2仿真效果

  • 写数据
    在这里插入图片描述

  • 读数据
    在这里插入图片描述

  • 我们发现会有两个时钟周期的延时,我们可以通过RAM核配置界面的效果图得知,读出的数据q经历了两个触发器,因此会有两个时钟周期延时
    在这里插入图片描述

五.RAM配置(双端口)

  • 右侧IP catelog中输入RAM后选择RAM:2-PORT
    在这里插入图片描述

  • 选择保存的位置和文件名
    在这里插入图片描述

  • 选择一个读模块,一个写模块
    在这里插入图片描述

  • 配置数据位大小和深度
    在这里插入图片描述

  • 选择读写时钟分开
    在这里插入图片描述

  • 选中复位信号
    在这里插入图片描述

  • Next后保持默认
    在这里插入图片描述

  • Next后保持默认
    在这里插入图片描述

  • 勾选xxx_inst.v文件
    在这里插入图片描述

  • 完成后Quartus弹窗点击yes即可
    在这里插入图片描述

六.RAM调用(双端口)

  • 在工程文件夹下的子文件夹rtl中新建RAM_test2.v文件,在其中调用我们刚生成的_inst.v文件,其代码如下
module RAM_test2(
    input           clk     ,
    input           rst_n   ,
    input   [7:0]   data        ,
    input   [7:0]   rdaddress   ,
    input           rden        ,
    input   [7:0]   wraddress   ,
    input           wrclock     ,
    input           wren        ,
    output  [7:0]   q

);

    RAM_2port	RAM_2port_inst (
	    .data ( data ),
	    .rd_aclr ( ~rst_n ),
	    .rdaddress ( rdaddress ),
	    .rdclock ( clk ),
	    .rden ( rden ),
	    .wraddress ( wraddress ),
	    .wrclock ( wrclock ),
	    .wren ( wren ),
	    .q ( q )
	);

endmodule

七.RAM仿真(双端口)

7.1仿真代码

`timescale 1ns/1ns
    
module tb_RAM_test2();

//激励信号定义 
    reg				tb_clk  	;
    reg				tb_rst_n	;
    reg				tb_din0		;
    reg     [7:0]   tb_data     ;
    reg     [7:0]   tb_rdaddress;
    reg     [7:0]   tb_wraddress;
    reg             tb_rden     ;
    reg             tb_wren     ;
    reg             tb_wrclock  ;   
//输出信号定义	 
    wire	[7:0]		tb_q	;

//时钟周期参数定义	
    parameter		CLOCK_CYCLE = 20;   

//模块例化
    RAM_test2 u_RAM_test2(	
        .clk         (tb_clk),
        .rst_n       (tb_rst_n),
        .data        (tb_data),
        .rdaddress   (tb_rdaddress),
        .rden        (tb_rden),
        .wraddress   (tb_wraddress),
        .wrclock     (tb_wrclock),
        .wren        (tb_wren),
        .q           (tb_q)        
    );

//产生时钟
    initial 		tb_clk = 1'b0;
    always #(CLOCK_CYCLE/2) tb_clk = ~tb_clk;
    initial 		tb_wrclock = 1'b0;
    always #(CLOCK_CYCLE/2) tb_wrclock = ~tb_wrclock;
    integer i,j;
//产生激励
    initial begin
        tb_rst_n = 1'b1;
        #200.1;
        tb_rst_n = 1'b0;
        tb_wren = 1'b0;//赋初值
        tb_rden = 1'b0;
        tb_rdaddress = 0;
        tb_wraddress = 0;
        tb_data = 0;
        #200;
        tb_rst_n = 1'b1;
        #200;
        
        //写数据
        for(i=0;i<256;i=i+1)begin
            tb_wren = 1'b1;
            tb_wraddress = i;
            tb_data = i * 3;
            #20;
        end
        tb_wren = 1'b0;
        #100;

        //读数据
        for(j=0;j<256;j=j+1)begin
            tb_rden = 1'b1;
            tb_rdaddress = j;
            #20;
        end
        tb_rden = 1'b0;
        #200;
        
        $stop;
    end

endmodule 

7.2仿真效果

  • 写数据
    在这里插入图片描述

  • 读数据
    在这里插入图片描述

智能网联汽车的安全员高级考试涉及多个方面的专业知识,包括但不限于自动驾驶技术原理、车辆传感器融合、网络安全防护以及法律法规等内容。以下是针对该主题的一些心知识点解析: ### 关于智能网联车安全员高级考试的心内容 #### 1. 自动驾驶分级标准 国际自动机工程师学会(SAE International)定义了六个级别的自动驾驶等级,从L0到L5[^1]。其中,L3及以上级别需要安全员具备更高的应急处理能力。 #### 2. 车辆感知系统的组成与功能 智能网联车通常配备多种传感器,如激光雷达、毫米波雷达、摄像头和超声波传感器等。这些设备协同工作以实现环境感知、障碍物检测等功能[^2]。 #### 3. 数据通信与网络安全 智能网联车依赖V2X(Vehicle-to-Everything)技术进行数据交换,在此过程中需防范潜在的网络攻击风险,例如中间人攻击或恶意软件入侵[^3]。 #### 4. 法律法规要求 不同国家和地区对于无人驾驶测试及运营有着严格的规定,考生应熟悉当地交通法典中有关自动化驾驶部分的具体条款[^4]。 ```python # 示例代码:模拟简单决策逻辑 def decide_action(sensor_data): if sensor_data['obstacle'] and not sensor_data['emergency']: return 'slow_down' elif sensor_data['pedestrian_crossing']: return 'stop_and_yield' else: return 'continue_driving' example_input = {'obstacle': True, 'emergency': False, 'pedestrian_crossing': False} action = decide_action(example_input) print(f"Action to take: {action}") ``` 需要注意的是,“橙点同学”作为特定平台上的学习资源名称,并不提供官方认证的标准答案集;建议通过正规渠道获取教材并参加培训课程来准备此类资格认证考试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值