- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为数据路径电路实现 FSM Controller 。 Controller 在内部递增计数器。当我模拟下面的程序时,计数器从未更新。
reg[3:0] counter;
//incrementing counter in combinational block
counter = counter + 4'b1;
但是,在创建额外变量 counter_next 时,如 Verilog Best Practice - Incrementing a variable 中所述并且仅在顺序 block 中递增计数器,计数器就会递增。
reg[3:0] counter, counter_next;
//sequential block
always @(posedge clk)
counter <= counter_next;
//combinational block
counter_next = counter + 4'b1;
为什么在前面的情况下计数器没有增加?我还缺少什么吗?
最佳答案
好的。我假设您在第一个示例中遗漏了一些代码,因为它们甚至不应该编译。不过,我想我还是可以为你解释一下这个问题。
在如下所示的 block 中:
always @(*) begin // or always @(counter)
counter = counter + 4'b1;
end
有两个问题。
1) 计数器从未初始化。所有“reg”类型变量在模拟时间开始时都是 X,因此 X 加 1 就是 X。
2) 这就是组合循环。该 block 对“计数器”的变化很敏感,因此即使假设“计数器”初始化为 0,模拟器也会永远循环更新“计数器”,并且模拟时间永远不会提前。即
always block executes -> counter = 1
counter has changed
always block executes -> counter = 2
counter has changed
and so on...
如果您在其中放置 $display 语句,您可以看到此循环的发生。否则,只会出现模拟器挂起并且不会写入任何波形的情况。
第二个示例起作用的原因是您有一个触发器破坏了组合循环。在每个时钟沿,“计数器”都会更新为“counter_next”的当前值。然后组合 block 执行一次(且仅一次)来计算新版本的“counter_next”。
为了完整性,您仍然缺少通过重置子句或初始语句来初始化“计数器”。
reg [3:0] counter;
reg [3:0] counter_next;
always @(*) begin
counter_next = counter + 1;
end
always @(posedge clk or negedge rst_l) begin
if (!rst_l)
counter <= 4'b0;
else
counter <= counter_next;
end
关于hardware - 在verilog中增加计数器变量: combinational or sequential,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14083475/
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
我的 Linux 机器报告“uname -a”输出如下: [root@tom i386]# uname -a Linux tom 2.6.9-89.ELsmp #1 SMP Mon Apr 20 10
我一直在开发一个最初没有在其 list 文件中指定触摸屏要求的应用程序,因此根据文档,假定为 android.hardware.touchscreen。因为该应用不需要高级手势,具有假触摸屏的设备 (
Google 正在通过电子邮件通知 Android 位置权限的更改: We’re making a change on October 15th, 2016 that will affect apps
我有 然后我为新库添加了以下内容: 我是否需要删除旧的 android.hardware.camera 标签,或者我是否仍需要放置它们以避免 PlayStore 过滤掉我的应用程序? 应用的最小
我有一个支持返回到 Android API 19 (KitKat) 的应用程序,并且在内部使用大量相机。 目前,android.hardware.camera2 是使用camera API 的推荐方式
我想为我正在编写的一堆模块创建这个通用包装器。包装器应该能够将这些模块连接到不同类型的 NoC,而无需更改内部模块的行为。 我认为这样做的一种方法是以下。 考虑一个非常简单的模块来包装: module
人们如何以一种抽象的方式思考设计数字逻辑芯片? 我目前正在学习第一章“计算系统的要素”,我已经实现了以下门,从 Nand 开始。 不是 和 或者 异或 多路复用器 多路复用器 16位不 16位和 16
我有以下数据: A = [a0 a1 a2 a3 a4 a5 .... a24] B = [b0 b1 b2 b3 b4 b5 .... b24] 然后我想乘以如下: C = A * B' = [a0
我从事软件/软件编程多年。多年来,我也对硬件编程(电路 + 机器人 + 等)感兴趣。 请从我可以开始硬件编程的地方提供建议。我的目标是将 s/w 和 h/w 结合起来一起工作。 最佳答案 我推荐 Ar
假设 l1 和 l2 缓存请求导致未命中,处理器是否会在访问主内存之前停止? 我听说过切换到另一个线程的想法,如果是的话,用什么来唤醒停滞的线程? 最佳答案 现代 CPU 中同时发生了很多很多事情。当
我们公司的一台服务器有 32 个 CPU,我们有 1000 多个非常大的文件要处理。我不确定同时读取 32 个文件是否是个好主意,这样所有内核也可以同时执行独立计算。谁能简单解释一下硬盘的工作原理?如
我想进入多核编程(不是特定于语言)并且想知道可以推荐哪些硬件来探索这个领域。 我的目标是升级我现有的桌面。 最佳答案 如果可能的话,我建议买一台双路机器,最好是四核芯片。您当然可以获得单插槽机器,但双
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我今天正在分析一个程序,该程序执行大量缓冲网络事件,该程序大部分时间都在 memcpy 中,只是在库管理的网络缓冲区和它自己的内部缓冲区之间来回移动数据。 这让我想到,为什么英特尔没有“memcpy”
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
我想了解Logisim中类似我的6502工作处理器项目的确切中断是什么。 我知道中断会执行以下步骤: 停止处理当前程序 将所有未完成的数据保存到堆栈中 是否“SOMETHING” 加载未完成的数据,让
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 6年前关闭。 Improve this questi
我对 linux 设备驱动程序书中的以下陈述感到有些困惑。 http://www.linuxdriver.co.il/ldd3/ 13.2. USB and Sysfs To help underst
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
我是一名优秀的程序员,十分优秀!