- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Verilog代码描述对状态机综合的研究
Verilog HDL 代码描述对状态机综合的研究
1 引言
Verilog HDL 作为当今国际主流的HDL 语言,在芯片的前端设计中有着广泛的应用。它的语法丰富,成功
地应用于设计的各个阶段:建模、仿真、验证和综合等。可综合是指综合工具能将Verilog HDL 代码转换
成标准的门级结构网表,因此代码的描述必须符合一定的规则。大部分数字系统都可以分为控制单元和数据
单元两个部分,控制单元的主体是一个状态机,它接收外部信号以及数据单元产生的状态信息,产生控制信号,
因而状态机性能的好坏对系统性能有很大的影响。
有许多可综合状态机的Verilog 代码描述风格,不同代码描述风格经综合后得到电路的物理实现在速度和
面积上有很大差别。优秀的代码描述应当易于修改、易于编写和理解,有助于仿真和调试,并能生成高效的综
合结果。
2 有限状态机
有限状态机(Finite State Machine,FSM)在数字系统设计中应用十分广泛。根据状态机的输出是否与输入
有关,可将状态机分为两大类:摩尔(Moore)型状态机和米莉(Mealy)型状态机。Moore 型状态机的输出仅与
现态有关;Mealy 型状态机的输出不仅与现态有关,而且和输入也有关。图1 是有限状态机的一般结构图,它
主要包括三个部分,其中组合逻辑部分包括状态译码器和输出译码器,状态译码器确定状态机的下一个状态,
输出译码器确定状态机的输出,状态寄存器属于时序逻辑部分,用来存储状态机的内部状态。
图1 状态机的结构框图
2.1 好的状态机标准
好的状态机的标准很多,最重要的几个方面如下:
第一,状态机要安全,是指FSM 不会进入死循环,特别是不会进入非预知的状态,而且由于某些扰动进入非设
计状态,也能很快的恢复到正常的状态循环中来。这里面有两层含义。其一要求该FSM 的综合实现结果无
毛刺等异常扰动,其二要求FSM 要完备,即使受到异常扰动进入非设计状态,也能很快恢复到正常状态。
第二,状态机的设计要满足设计的面积和速度的要求。
第三,状态机的设计要清晰易懂、易维护。
需要说明的是,以上各项标准,不是割裂的,它们有着直接紧密的内在联系。在芯片设计中,对综合结果评判
的两个基本标准为:面积和速度。“面积”是指设计所占用的逻辑资源数量;“速度”指设计在芯片上稳定运行所
能够达到的最高频率。两者是对立统一的矛盾体,要求一个设计同时具备设计面积最小,运行频率最高,这是
不现实的。科学的设计目标应该是:在满足设计时序要求(包含对设计最高频率的要求)的前提下, 占用最小
的芯片面积,或者在所规定的面积下,使设计的时序余量更大,频率更高。另外,如果要求FSM 安全,则很多时
候需要使用“full case”的编码方式,即将状态转移变量的所有向量组合情况都在FSM 中有相应的处理,这经
常势必意味着要多花更多的设计资源,有时也会影响FSM 的频率所以,上述的标准要综合考虑,根据设计的
要求进行权衡。
2.2 状态机描述方法
状态机描述时关键是要描述清楚几个状态机的要素,即如何进行状态转移,每个状态的输出是什么,状态
转移的条件等。具体描述时方法各种各样,最常见的有三种描述方式:
第一,整个状态机写到一个always 模块里面,在该模块中既描述状态转移,又描述状态的输入和输出;
第二,用两个always 模块来描述状态机,其中一个always 模块采用同步时序描述状态转移;另一个模块采用
组合逻辑判断状态转移条件,描述状态转移规律以及输出;
第三,在两个always 模块描述方法基础上,使用三个always 模块,一个always 模块采用同步时序描述状态转
移,一个采用组合逻辑判断状态转移条件,描述状态转移规律,另一个always 模块描述状态的输出(可以用组
合电路输出,也可以时序电路输出)。
一般而言,推荐的FSM 描述方法是后两种。这是因为:FSM 和其他设计一样,最好使用同步时序方式设计,
以提高设计的稳定性,消除毛刺。状态机实现后,一般来说,状态转移部分是同步时序电路而状态的转移条件
的判断是组合逻辑。
第二种描述方法同第一种描述方法相比,将同步时序和组合逻辑分别放到不同的always 模块中实现,这
样做的好处不仅仅是便于阅读、理解、维护,更重要的是利于综合器优化代码,利于用户添加合适的时序约束
条件,利于布局布线器实现设计。在第二种方式的描述中,描述当前状态的输出用组合逻辑实现,组合逻辑很
容易产生毛刺,而且不利于约束,不利于综合器和布局布线器实现高性能的设计。第三种描述方式与第二种相
比,关键在于根据状态转移规律,在上一状态根据输入
您可能关注的文档
- 2.6 图像数据结构与文件格式.pdf
- cy7c68013uart(串口)介绍及示例代码.pdf
- 电路与电子基础教程第十章答案.pdf
- 特点: 外引线排列图 典型参数: tpd=100ns Pd=35mW.pdf
- ASCII算法及表.pdf
- 多进制霍夫曼编码方法及最优性证明.pdf
- 几种典型汉字编码之间转换的原理与实现.pdf
- 5053编码整理.pdf
- 89S51单片机PT2221红外解码汇编代码.pdf
- 改进的算术编码.pdf
- 工会代表大会运行规则及十大制度解读.docx
- 法院合同法案例分析与学习笔记.docx
- 医疗急救口头医嘱管理流程制度.docx
- 幼儿园科学实验教学设计案例.docx
- 2025秋九年级英语全册Unit2Ithinkthatmooncakesaredelicious课时3SectionAGrammarFocus_4c习题课件新版人教新目标版.pptx
- 2025秋九年级英语全册Unit5WhataretheshirtsmadeofSectionA合作探究二课件新版人教新目标版.pptx
- 2025秋九年级英语全册Unit2Ithinkthatmooncakesaredelicious课时4SectionB1a_1d习题课件新版人教新目标版.pptx
- 2025秋九年级英语全册Unit1Howcanwebecomegoodlearners课时3SectionAGrammarFocus_4c习题课件新版人教新目标版.pptx
- 2025秋九年级英语全册Unit5Whataretheshirtsmadeof课时4SectionB1a_1e课件新版人教新目标版.pptx
- 2025秋九年级英语全册Unit3Couldyoupleasetellmewheretherestroomsare课时3SectionAGrammarFocus_4c课件新版人教新目标版.pptx
原创力文档


文档评论(0)