共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 跳转至页
回复
打赏帖 | |
---|---|
嵌入式LinuxC语言程序调试和宏使用技巧被打赏50分 | |
让代码中包含最新的编译时间信息被打赏50分 | |
rtthread硬件加密--2crc加密分析被打赏10分 | |
【分享开发笔记,赚取电动螺丝刀】mcxa156使用低功耗定时器适配硬件RTC框架被打赏26分 | |
【STM32F769】AI之与本地deepseek对接被打赏50分 | |
Buck电路工作在CCM模式下电感电流的计算公式是什么?被打赏5分 | |
buck电路工作原理被打赏5分 | |
基于MSPM0L1306的MODBUS-RTU协议通讯实验被打赏100分 | |
我想要一部加热台+多合一调试工具被打赏18分 | |
每周了解几个硬件知识+485硬件知识分享被打赏10分 |