共1条
1/1 1 跳转至页
Re: 如何ALTERA FLEX10K中的EAB,请赐教

仔细看HELP. VHDL和AHDL不一样. 声明是可以COPY的. 应注意的是RAM有
同步和异步两种, 即前者是用时钟的. 但是同步的启动延迟很大, 但适合
PIPELINE操作.
下面给出一个VHDL的简单例子(同步RAM).
---- VHDL ---------------
entity EXAMPLE is
port (
... ;
) ;
end EXAMPLE ;
architecture behave of EXAMPLE is
-- 声明一个部件
COMPONENT lpm_ram_dq
GENERIC (LPM_WIDTH: POSITIVE;
LPM_WIDTHAD: POSITIVE;
LPM_FILE: STRING := "UNUSED") ;
PORT (data: IN STD_LOGIC_VECTOR(LPM_WIDTH-1 DOWNTO 0);
address: IN STD_LOGIC_VECTOR(LPM_WIDTHAD-1 DOWNTO 0);
we: IN STD_LOGIC := '1';
inclock: IN STD_LOGIC := '1';
outclock: IN STD_LOGIC := '1';
q: OUT STD_LOGIC_VECTOR(LPM_WIDTH-1 DOWNTO 0));
signal ex_ram_in, ex_ram_out : std_logic_vector(7 downto 0) ;
signal ex_ram_ad : std_logic_vector(7 downto 0) ;
signal ex_ram_we : std_logic ;
begin
-- 具体配置一个RAM, 注意RAM初始化文件名应与architecture名保持一致.
RAM_EXAMPLE : lpm_ram_dq
GENERIC MAP( LPM_WIDTH => 8,
LPM_WIDTHAD => 8,
LPM_FILE => "EXAMPLE.mif") -- 初始化RAM数据文件
PORT MAP (
data => ex_ram_in, address => ex_ram_ad, we => ex_ram_we,
inclock => clk, outclock => clk, q => ex_ram_out ) ;
END COMPONENT;
-- 对RAM控制信号进行赋值.
ex_ram_we <= 赋值语句 ;
ex_ram_ad <= 赋值语句 ; -- 或者是由另一个计数器配置生成
ex_ram_in <= 赋值语句 ; -- 或者ex_ram_in本身是PIN
-- 下面就可以使用ex_ram_out了. 如
variable_tmp <= ex_ram_out ;
end EXAMPLE ;
关键词: 如何 ALTERA FLEX10K 中的 赐教
共1条
1/1 1 跳转至页
回复
打赏帖 | |
---|---|
【S32K146】S32DS watchdog 配置使用被打赏20分 | |
【Zephyr】使用 IAR 调试 Zephyr 镜像被打赏20分 | |
【Zephyr】MCXN947 Zephyr 开发入门适配shell被打赏20分 | |
【我要开发板】6.联合MATLAB记录数据被打赏50分 | |
【瑞萨RA2E1开发板】:使用ADC功能实现位移传感器采集方案被打赏20分 | |
【nRF7002DK】基于sht30的温湿度计被打赏20分 | |
【nRF7002DK】日志打印被打赏20分 | |
【换取手持示波器】RGB屏幕移植ARM-2D库被打赏35分 | |
【分享开发笔记,赚取电动螺丝刀】分享一下如何解决瑞萨RA2E1使用printf编译报错问题被打赏27分 | |
rtthread硬件加密-5hash加密分析被打赏10分 |