首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Synth 8-2715语法错误接近

Synth 8-2715语法错误接近
EN

Stack Overflow用户
提问于 2017-01-16 08:04:42
回答 1查看 1.1K关注 0票数 0

我正在设计一个基本的低燃料探测器,当燃料不足1/3或更低时,它就会打开。我的代码如下:

代码语言:javascript
复制
ENTITY LFDetector_behav IS
PORT (Fuel3, Fuel2, Fuel1, Fuel0: IN std_logic;
     FuelWarningLight: OUT std_logic);
END LFDetector_behav;

ARCHITECTURE Behavior OF LFDetector_behav IS
BEGIN
 PROCESS (Fuel3, Fuel2, Fuel1, Fuel0)
 BEGIN
 FuelWarningLight <= [(NOT(Fuel3)) AND (NOT(Fuel2))] OR [(NOT(Fuel1)) AND (NOT(Fuel0))] AFTER 5.8 ns; 
 END PROCESS; 
END Behavior;

我在我的FuelWarningLight赋值附近得到一个错误,我不明白为什么,我用完全相同的格式创建了其他完美工作的设计。谢谢。

EN

回答 1

Stack Overflow用户

发布于 2017-01-16 13:23:09

我不确定您的错误发生在哪里(synth或sim),但是after关键字是不可合成的。我也不确定你是否打算让它完全组合起来。

可以尝试以下操作:

代码语言:javascript
复制
ARCHITECTURE Behavior OF LFDetector_behav IS
BEGIN
 PROCESS (Fuel3, Fuel2, Fuel1, Fuel0)
 BEGIN
 FuelWarningLight <= ((not Fuel3) AND (not Fuel2)) OR ((not Fuel1) AND (not Fuel0)); 
 END PROCESS; 
END Behavior;

考虑使用时钟进程,如下所示(我实际上还没有对此进行同步,所以如果有任何错误,请道歉)。

代码语言:javascript
复制
ENTITY LFDetector_behav IS
PORT (clk, Fuel3, Fuel2, Fuel1, Fuel0: IN std_logic;
     FuelWarningLight: OUT std_logic);
END LFDetector_behav;

ARCHITECTURE Behavior OF LFDetector_behav IS
BEGIN
 PROCESS (clk)
 BEGIN
  if rising_edge(clk) then
     FuelWarningLight <= ((not Fuel3) AND (not Fuel2)) OR ((not Fuel1) AND (not Fuel0)); 
  end if;
 END PROCESS; 
END Behavior;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41667752

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档