[技术求助] 仿真问题

[复制链接]
 楼主| wuhany 发表于 2017-4-22 23:40 | 显示全部楼层 |阅读模式
VHDL 实现正旋信号发生器 仿真总是出现问题,怎么办啊
jlyuan 发表于 2017-4-22 23:40 | 显示全部楼层

什么问题啊?提示什么?
 楼主| wuhany 发表于 2017-4-22 23:41 | 显示全部楼层
library error primaryunit "lpmconponent" denote prefix "lpm"must exit in the library
 楼主| wuhany 发表于 2017-4-22 23:42 | 显示全部楼层
我还没说完呢,呵呵
这个库文件 没找到 还有不知道怎么利用L PM _ROM 核预置正弦查找表在FPGA 上
jlyuan 发表于 2017-4-22 23:43 | 显示全部楼层
程序看看吧
 楼主| wuhany 发表于 2017-4-22 23:45 | 显示全部楼层

LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
USE IEEE.STD_LOGIC_UNSIGNED.ALL;
USE IEEE.STD_LOGIC_ARITH.ALL ;
LIBRARY LPM;
USE LPM.LPMCOMPONENTS.ALL;
ENTITY ddsc IS
GENERIC(
freq_width: INTEGER :=32;
phase_width : INTEGER :=12;
adder_width : INTEGER :=32;
romad_width : INTEGER :=10;
rom_d_width : INTEGER :=10
);
PORT(
clk : IN STD_LOGIC;
freqin : IN STD_LOGIC_VECTOR(freq_width-1 DOWNTO 0) ;
ddsout : OUT STD_LOGIC_VECTOR(rom_d_width-1 DOWNTO 0));
END ENTITY ddsc;
ARCHITECTURE behave OF ddsc IS
SIGNAL acc:STD_LOGIC_VECTOR(adder_width-1 DOWNTO 0);
SIGNAL romaddr :STD_LOGIC_VECTOR(romad_width-1 DOWNTO 0) ;
BEGIN
process (clk)
BEGIN
IF (clk'event and clk ='1') THEN
acc<=acc+freqin;
END IF;
END PROCESS;
romaddr<=acc(phase_width-1 downto phase_width-romad_width) ;
i_rom :lpm_rom
GENERIC MAP (
Lpm_width=>rom_d_width,
Lpm_widthad=>romad_width,
Lpm_addreaa_control=>"NREGISTERED",
Lpm_outdata=>"EGISTERED",
Lpm_file=>"sin_rom.mif")
PORT MAP(
outclock=>clk,
ddress=>romaddr,
q=>ddsout);
END ARCHITECTURE behave;
jlyuan 发表于 2017-4-22 23:46 | 显示全部楼层
不懂,帮顶吧
shimx 发表于 2017-4-22 23:47 | 显示全部楼层
错误告诉你, 你可能什么端口弄错了, 因为那个组件的prefix "lpm"must exit in the library
jiaxw 发表于 2017-4-22 23:48 | 显示全部楼层
重装下调试软件的试试吧
 楼主| wuhany 发表于 2017-4-22 23:50 | 显示全部楼层
嗯,那我按大家的说法挨个排查一下,先结贴啦,谢谢哈
您需要登录后才可以回帖 登录 | 注册

本版积分规则

879

主题

10435

帖子

4

粉丝
快速回复 在线客服 返回列表 返回顶部