标签:条件 时钟 always 简化 ble 工作量 需要 question 大神
今天诳论坛,突然发现了一个有关latch的问题,由于对D Flip-Flop和Latch还有些疑问,就点击了进去,一看果然有些意思,也挺有学习意义的,于是本文就诞生了。喊出口号~Just note it.
else q<=0;
,会生成latch吗?else q<=0;
,会生成latch吗?论坛上还是有很多的大神和前辈的,几个回答相当不错,有着极强指导意义,让人不禁思考问题,然后开始默默思考人生。噗呜,不多说了,我们来看下参考。(有删减哦,在此谢过原大大提供自己的见解)
老阮(一看名字就知道是个老油条,手动滑稽):
看起来很有道理呢,分析的较为详细了,就此问题详细介绍了两者的区别,很有指导意义啊。
——————————我是各楼主的分隔线——————————
chengroc(英文字母的ID呢,看起来貌似是姓成呢,就叫程先生吧,什么你说两个cheng不一样,哎呀不要在意这些细节,看下面):
程先生简单的说明了下latch和dff呢,虽然并不深入,但对现在的我而言,嗯是够用了,后面我再深入的去看D触发器和锁存器的一些知识点。
——————————我是各楼主的分隔线——————————
walkman416(字母数字组合,好常见的组合方式,就叫他walkman好了):
个人理解: 所谓生成latch其实是针对使用always语句描述一个组合逻辑而言,因为如果描述时序逻辑总是使用时钟或者时钟+复位作为敏感列表条件,所生成的电路总是组合逻辑+DFF;如果是描述组合逻辑,敏感列表中必然没有时钟复位,而是组合逻辑的输入信号。在FPGA设计,避免使用latch,不利于时序分析和仿真。 楼上有提到latch比DFF省资源, 这个在FPGA设计中其实还好, 因为在FPGA中DFF就是一个专用的硬件资源,并且数量也比较多。
使用always描述组合逻辑时,好的习惯是使用always @(*)作为敏感列表, 并且需要检查每个分支都有明确的赋值,从而避免生成latch.
哎呀说的真好,我等下也要总结下呢,walkman,好样的!
else ;
也可以写else q<=q;
,总之补齐就好,这样说不定还有写别的什么好处我不知道呢,后续知道了再补上。always@(*)
作为敏感列表,并且检查每个else或者case分支都有明确的赋值。希望对阅读的你有着帮助,欢迎探讨。如果有什么觉得不对的,一定不要客气的留言回复大力拍砖~
标签:条件 时钟 always 简化 ble 工作量 需要 question 大神
原文地址:http://www.cnblogs.com/airbird/p/6160296.html