- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我仅在VHDL文件中使用以下软件包:
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
...if A<="00001011" then
最佳答案
-将我的comp.lang.vhdl回复复制到此帖子。对不起,有些重复,但有些没有。
所有枚举类型和枚举类型的数组都隐式定义了常规排序关系运算符(>,> =,<,<=)。不幸的是,它没有按数字顺序排序,因此结果可能与预期不符。相反,它是按字典排序的。
首先,您必须查看元素类型,即基本类型为std_ulogic的std_logic。对于枚举类型,例如std_ulogic,左值小于右值,因此,对于std_ulogic(和std_logic):
'U'<'X'<'0'<'1'<'Z'<'W'<'L'<'H'<'-'
对于元素基类型为std_ulogic的等长数组(例如std_logic_vector或std_ulogic_vector),其值仅为0或1,则可以正常工作:
“1010”>“0101”
请注意,字典比较始终会首先比较左元素。因此,对于字符串,以“S”开头的东西总是小于以“T”开头的东西,与长度无关。这对于将字符串排序到字典中非常有用,并且是唯一实际的默认值-如果我们要提供诸如此类的东西。
OTOH,如果您认为事物是数字的,那就不是很好。例如,如果数组的长度不相等,则以下情况成立,因为左参数的前导“1”>右参数的前导“0”。
“100”>“0111”
因此,仅使用“use ieee.std_logic_1164.all”,您就有可能遭受错误地将std_logic_vector视为数字(例如无符号)的错误编码实践。
许多人会争论,永远不要使用std_logic_vector进行数学运算,并且“>”是数学运算。我普遍同意。
那我该怎么办?我该如何保护我的设计和设计团队。首先,您必须决定一项政策以及如何执行它。
1)禁止在std_logic_vector中使用常规排序关系运算符(>,> =,<,<=),并使用lint工具强制实施。但是,这意味着您必须购买并要求使用皮棉工具。
2)禁止将常规排序关系运算符(>,> =,<,<=)与std_logic_vector一起使用,并通过同时使用以下两个包引用来强制实施它。请注意,这通过为每个运算符引用两个定义而产生错误,因此,当使用该表达式时,该表达式将变得模棱两可。注意,这可能是有问题的,因为numeric_std_unsigned是在1076-2008年引入的,综合工具可能尚不支持。
图书馆ieee;
使用ieee.numeric_std_unsigned.all;
使用ieee.std_logic_unsigned.all;
3)放宽规则。我们最大的担忧是设计的正确性。允许将std_logic_vector解释为无符号值,并且可以引用numeric_std_unsigned(首选,但它是VHDL-2008,并且可能尚未由综合工具实现-但是如果不确定是否要提交错误报告)或std_logic_unsigned(不是)首选-这是一个旧的共享软件程序包,它不是IEEE标准,并且可能不属于IEEE库-OTOH,它得到了很好的支持,并且可以与其他程序包(例如numeric_std)配合使用。
这样做的好处是它还允许包含整数的比较:
如果A <= 11则
请注意,有人建议在数字_std_unsigned / std_logic_unsigned中重载“>”和朋友是非法的。在VHDL-2008之前,这是对1076的非常保守的解释。对于VHDL-2008之前具有ISAC决议的VHDL的所有修订版,此问题均已修复,该决议确定显式定义的运算符始终会使隐式定义的运算符超载而不会产生任何歧义。我注意到,即使是VHDL常见问题解答在此问题上也已过时。
4)要正式,但要切合实际。切勿使用std_logic_vector。仅使用数字类型,例如无符号和从软件包ieee.numeric_std中签名。有符号和无符号类型也支持与整数的比较。
我可能遗漏了一些策略。
请注意,VHDL-2008引入了匹配运算符,它们也通过不为没有数字解释的类型定义它们而解决了这个问题。这些运算符是:?=,?/ =,?>,?> =,?<,?<=
关于vhdl - 仅使用std_logic_vector包将std_logic_vector与常量进行比较,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27934208/
同时使用 VHDL-2019 IEEE 规范部分。 5.2.3.1.一般 "However, an implementation shall allow the declaration of any
我正在设计通用移位算术运算符。除了以下面介绍的方式使用 32 位多路复用器(解码器)之外,还有更好的方法来实现它吗? ENTITY isra IS PORT ( clk: in std_lo
描述:我正在尝试编写一个具有 4 个输入和 3 个输出的 LUT(查找表)的 vhdl 模块。我希望我的 3 位输出是一个二进制数,等于输入中 1 的个数。 我的真值表: ABCD|XYZ 0000|
我想使用 vhdl 制作幂函数,其中幂是浮点数,数字是整数(将始终为“2”)。 2^ 一些浮点数。 我使用 ieee 库和(fixed_float_types.all、fixed_pkg.all 和
是否有可能有一个通用的包? 这意味着当我实例化实体时,我提供了一些泛型,包将依赖于它。 我有一个块,我想多次使用,每次使用不同的包(即不同的参数) 我必须使用包,因为我想使用数组数组,而我只能使用包来
使用 VHDL,我希望有一些寄存器在每个寄存器中存储 16 位。 所以我发现 VHDL 有一个内置数组,我想用它在 iy 中的每个元素中存储 16 位,所以我想知道 VHDL 是否将此数组映射到实际寄
在 vhdl 中我可以定义我自己的枚举类型并创建这种类型的信号: type tp is (red,green,blue,yellow); signal sg: tp := red; 但现在我想要一个
我是 VHDL 的新手。 有一行,如下所示: constant TIME_DELTA : time := 100 ns; 这是什么字time在行吗?是不是和integer一样的数据类型?当我在互联网上
A <= 3 * B; 上面语句中的3是一个整数或自然数。如果它是自然数,如果我在那里使用负数怎么办? VHDL 是否将其识别为整数? 最佳答案 整数文字属于匿名预定义类型universal_inte
我为以下 vhdl 代码编写了测试平台: library ieee; USE ieee.std_logic_1164.all; ---USE ieee.std_logic_unsigned.all;
我有使用 Verilog/SystemVerilog 的经验,但我是 VHDL 新手,我试图弄清楚何时应该使用组件实例化或实体实例化。我所说的组件实例化是指在实例化实体组件之前声明实体组件的传统方式。
我一直无法理解如何在 VHDL 中取消引用指针。 我想到的是一个 C 代码,如: int a; int* ptr_a; a = 42; ptr_a=&a; *ptr_a=451;/
我为以下 vhdl 代码编写了测试平台: library ieee; USE ieee.std_logic_1164.all; ---USE ieee.std_logic_unsigned.all;
我想知道VHDL中是否定义了整数溢出。我在 2002 年规范中找不到任何内容。 作为示例(注意,这可能无法编译,它只是一个通用示例...): entity foo is port ( clk
如何组合/捆绑语句以供进一步使用和更好地处理?例如,像这样的一些赋值会在以后的例程调用中多次使用。 ADDR_PC '0'); constant OP_NOP: std
我正在编写一个 IP 核,根据用户选择的通用参数,并非所有 OUT/IN 端口都是必需的。是否可以有可选端口?我知道类似的事情应该是可能的,因为当我使用 Xilinx IP-Cores 时,根据参数,
我有一个数组: type offsets_type is array (4 downto 0) of std_logic_vector (4 downto 0); signal av : of
type有什么区别和 subtype在 VHDL 中,我应该在哪里使用它们? 我的理解是subtype只是主要类型之一的缩小版本,例如 integer :subtype small_integer i
我试图更好地使用 VHDL protected 类型,所以我将以下测试放在一起(当然只是为了说明 - 我的实际用例要复杂得多): type prot_type1 is protected proc
首先,我想声明这是我参加的模拟考试。我知道答案是:cout = 4ns,S = 7ns。只是在寻找一点解释。提前致谢。 对于下面所示的全加器的 VHDL 实现,输出 cout 和 S 何时稳定在它们的
我是一名优秀的程序员,十分优秀!