共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 跳转至页
回复
打赏帖 | |
---|---|
【Cortex-M】Systick Timer使用被打赏10分 | |
分享汽车防盗系统的组成与分类(一)被打赏5分 | |
VOFA+波形显示+JYD-31蓝牙发送和解析不定长数据被打赏10分 | |
【换取手持数字示波器】-STM32F4PWM控制LED灯管亮度被打赏22分 | |
【换取手持数字示波器】STM32F4驱动RPR-0521RS照度、接近一体型传感器被打赏23分 | |
宏定义和const关键字定义被打赏5分 | |
【分享开发笔记,赚取电动螺丝刀】几个单片机I2S外设的BLCK时钟对比被打赏20分 | |
【功率监测与控制系统DIY活动成果贴】DIY功率计与LabVIEW数据采集被打赏100分 | |
【分享开发笔记,赚取电动螺丝刀】使用ESP32S3调试I2S音频模块MAX98357被打赏22分 | |
【Freertos】任务管理被打赏10分 |