- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这个问题适合那些对 VHDL 有深入了解的人。我是一个新手,但到目前为止我一直在使用行为描述生成 VHDL。对我来说,思考起来更容易,因为它类似于编写软件。我知道一个可能的缺点是行为按顺序“执行”,而结构在设计组件/流程中同时执行。
所以我只是好奇,如果我有一个使用 8 位移位寄存器 (SISO) 进程的架构,并且我想创建这些实例(4x8 位移位寄存器)的 4 个实例,我会创建一个组件和流程的 4 个实例?
或者我会生成 4 个进程(彼此并行执行)并用不同的名称调用每个进程吗?
此外,这只是一个一般性问题,旨在就人们使用的良好实践达成共识,您更喜欢哪一个:结构性还是行为性?什么时候是选择其中之一的最佳时机?我猜想它们可能会带来一些好处,即使用允许内部并发与流程中顺序执行的组件来“更快”执行。在我看来,虽然可以通过行为设计来减少设计时间。 >
谢谢!〜老爹
最佳答案
在我看来,如今结构 HDL 的作用仅限于互连经过测试的工作行为 block (或将未经测试的行为 block 连接到其测试平台!) - 我同意您关于行为 VHDL 在设计创建和测试方面的优越性的看法时间。
我也同意编写行为过程在某些方面类似于编写软件(尽管有些人尖叫着事实并非如此)
但是
不要陷入将行为等同于顺序或缓慢的陷阱!
给定您的轮类寄存器,比如说
type reg_type is array(7 downto 0) of bit;
signal s_in, s_out : bit;
process(clk) is
variable reg : reg_type;
begin
if rising_edge(clk) then
s_out <= reg(7);
reg := reg(6 downto 0) & s_in;
end if;
end;
我可以将其简单地并行化,如下所示:
signal p_in, p_out : array(1 to 4) of bit;
process(clk) is
variable reg : array(1 to 4) of reg_type;
begin
if rising_edge(clk) then
for i in reg'range loop
p_out(i) <= reg(i)(7);
reg(i) := reg(i)(6 downto 0) & p_in(i);
end loop;
end if;
end;
(是的,有更简单的方法可以写这个!)值得注意的是,循环不需要更长的时间来运行:它只是生成更多的硬件(用软件术语来说,它是完全展开的)。每次迭代完全独立于其他迭代;如果不是,事情会变得更加复杂。
不必担心结构和行为之间的学术差异。
担心进程中信号分配调度和变量分配调度之间的差异(了解增量周期和延迟分配是什么 - 这是与软件的关键区别之一,并且出现是因为软件只有变量,而不是 VHDL 信号) 。这将解释为什么我在这里颠倒了管道(首先输出) - 因为我使用了一个变量。
担心为什么这么多人教愚蠢的 2 进程状态机,而 1 进程 SM 更简单、更安全。
查找并了解 Mike Treseler 关于单进程模型的页面(我希望它们仍然在线)
关于VHDL 结构与行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13422993/
同时使用 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 何时稳定在它们的
我是一名优秀的程序员,十分优秀!