首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >GHDL:操作符没有函数声明“和”

GHDL:操作符没有函数声明“和”
EN

Stack Overflow用户
提问于 2015-03-15 23:14:09
回答 1查看 2.7K关注 0票数 0

下面是我的示例:

代码语言:javascript
复制
library ieee;
use ieee.std_logic_1164.all;
use ieee.numeric_std.all;

entity queue is
    port(
        reset: in std_logic;
        input_ready: out std_logic
    );
end entity;

architecture reference of queue is
    signal queue_size: unsigned(15 downto 0);
begin
    process
    begin
            input_ready <= (reset = '0') and (queue_size < 1024);
    end process;
end architecture;

这一行:

代码语言:javascript
复制
input_ready <= (reset = '0') and (queue_size < 1024);

产生

代码语言:javascript
复制
no function declarations for operator "and"
ghdl: compilation error

跑步时

代码语言:javascript
复制
ghdl -a queue.vhdl

在Arch上使用GHDL 0.32rc1 (20141104) [Dunoon edition]

根据VHDL算子,这两个比较都返回布尔值,并且有两个布尔值的and定义。那我做错什么了?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-15 23:38:40

两个子表达式(reset = '0')(queue_size < 1024)返回一个布尔值。and运算符还返回一个布尔结果,您正试图将该结果分配给std_logic输出。

解决办法:

代码语言:javascript
复制
input_ready <= '1' when (reset = '0') and (queue_size < 1024) else '0';

注:这一行不需要周围的处理。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29067374

复制
相关文章

相似问题

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