完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
|
|
相关推荐
5个回答
|
|
很少有像大型复杂半导体器件的设计和验证那样令人畏惧的工程任务。一个设计师可能负责数百万个门,它将重用、适应和从头开始编码的逻辑。大多数大型设备都是SoC设计,在硬件和软件之间具有深层的嵌入式交互。验证工程师需要了解设计、嵌入式代码、测试台、底层生产软件,甚至可能是一些最终应用程序。
在这种复杂性背后,有一系列丰富的语言来捕获和验证SoC。最常用的是System verilog,用于嵌入式软件和高级模型的硬件和测试平台以及C/C++。有许多库和其他构建块来帮助创建设计和验证环境,最显著的是通用验证方法(UVM)标准。然而,这些库本身非常复杂,有许多选项和变体,因此在编码和调试时很难牢记所有这些。 由于所有这些语言和库的复杂性,SoC团队可能希望在编写代码时获得某种帮助。常规的文本拼写和语法检查已经变得熟练,不仅能发现错误,而且还建议可能的修复方法。鉴于自然语言的定义要比计算机程序严格得多,所以对于SystemVerilog和其他设计和验证语言,期望类似或更好的自动化似乎完全合理。 |
|
|
|
IDE的价值
软件程序员熟悉集成开发环境(IDE)的概念,在IDE中他们可以编写和调试代码。近年来,获得一个IDE已经成为可能,该IDE支持甚至是最大和最复杂的SoC项目的全部硬件和软件创建、验证和调试。IDE可以使用所使用的语言和库在上下文中分析设计和验证代码。 IDE必须支持各种软件编程语言、建模语言、硬件描述语言(如Verilog和Vhdl)、专用验证语言(如e)以及SystemVerilog的设计和验证功能。 |
|
|
|
IDE可以:
|
|
|
|
IDE作为自动校正器
IDE可以建议修复程序并提供键入时自动校正的功能,这一点也就不足为奇了。除了编译器之外,IDE还有强大的分析引擎,可在幕后不断运行。每当工程师进行更改并更新完整设计和验证环境的内部数据库时,它都会重新读取源代码。该数据库必须支持SystemVerilog、Verilog、VHDL、E和C/C++中的输入,将所有设计和验证元素连接到一个结构中,并使跨越所有这些语言的分析得以实现。 利用这个数据库及其库和构建块的知识,IDE对设计人员和验证团队的意图有相当的洞察力。正如语法检查器使用其对自然语言约定的知识来建议更改一样,IDE利用其内部知识来提出更改,以解决它检测到的问题。当然,没有工具可以确切地知道工程师的意图,因此在对代码进行任何更改之前,必须接受建议。 如图1所示,IDE的建议以熟悉的拼写检查开始,包括接受或忽略任何建议的修复的选项。如果接受,将自动对代码进行更改。建议的拼写更改仅针对注释和文本字符串提供,因为不同的语法规则适用于其余代码。第一个屏幕截图和后面的其他截图显示了来自AMIQ EDA的设计和验证工具(DVT)Eclipse IDE的示例。 检测到的问题和建议的解决方案的范围远远超出文字处理工具提供的简单拼写检查。因为IDE编译了完整的设计和验证环境,所以它具有完整的代码范围,并且可以识别出大量的不一致性。例如,IDE可以检测标识符中的印刷错误。在图2中,用户输入了对UVM组件的错误引用,IDE建议了一些可能符合用户意图的实际名称。建议列表中的第一个条目已被接受,然后在代码中自动更新引用。 如果用户键入了对尚未声明的变量的引用,IDE不仅会检测到这一点,而且会提出修复方法。如图3所示,如果建议被接受,那么声明将自动插入到代码的适当位置。 在另一个键入时自动更正的示例中,图4显示了一个类定义,其中用户调用了一个尚未声明的方法。IDE建议添加一个实现,但是由于它无法知道函数应该做什么,它只在代码中插入一个存根。存根包含一个特殊的“TODO”编译指示来提醒工程师完成实现,并将此完成作为一个条目添加到项目任务列表中。 虽然图4中没有显示,但IDE也可以用类似的方式检测丢失的外部任务或函数实现,并在类范围之外插入存根。 有时被引用的模块存在,但没有特定端口。图5显示了一个实例化已定义模块的示例,尽管实例中的端口之一不在定义中。IDE提供了以下选项:放弃错误、自动更新实例以删除有问题的端口并与定义匹配,或自动更新定义以添加缺少的端口。“添加”选项是屏幕截图中选择的选项。 IDE还可以检测丢失的模块参数并将它们添加到定义中。这些类型的省略在编码的早期阶段经常发生,因为模块和类正在被定义和使用,可能是由不同的工程师执行的。IDE的检查和建议在项目后期更具价值。当定义或实例化被单方面更新时,将发生编译错误。工程师们省去了整理这一问题的麻烦;IDE一输入就会检测到不一致,并提出可能的解决方案。 在编写SystemVerilog(或Verilog)时,有一种特别隐蔽的省略形式:在敏感度列表中缺少一项。只有当列表中至少有一个项更改了其值时,才会评估此类列表中的代码。这是有风险的,因为忽略信号可能会导致在合成过程中插入锁存器,这通常是不可取的。图6显示了一个示例,其中只列出了一个变量('x'),尽管敏感度列表所涵盖的代码中也使用了变量'y'。 在这种情况下,如果“y”的值要更改而“x”没有更改,则两个更新将丢失,“x”和“z”将保留其旧值。这种编码错误在模拟中很难触发和调试,需要大量的回溯来找到错误数据的来源。IDE提供了一个更有效的解决方案,通过查找和报告缺失的变量,并建议将其添加到敏感度列表中。在图6中,建议已被接受,并且“y”已自动添加到列表中。 就像模块定义和实例化一样,敏感度列表和其中的代码在进行单方面更改时可能会变得不一致。有时工程师可能会删除一个变量,但忘记从列表中删除它。这不会导致任何功能错误,但代码看起来很混乱,并且由于不必要的评估,模拟可能会降低效率。如图7所示,IDE还检测敏感度列表中的伪变量,并建议自动删除它们。 在相关的方面,IDE可以检测和报告已声明但从未在代码中实际使用的信号。图8显示了一个这样的信号;IDE提供了放弃警告、删除信号或重命名信号的选择。这里,选择了“remove”选项,因此信号声明被自动删除。图中还显示了IDE的另一项有用检查:检测信号何时被分配了一个值,但该值从未使用。这可能是一个错误,或者只是编码仍在进行中的结果。 |
|
|
|
芯片设计和验证是一项庞大的任务。大量带有许多相似的标识符的代码使它变得复杂。印刷错误、缺少声明和不一致的引用会导致验证失败,并可能导致数小时的繁琐调试。IDE的“键入时自动校正”功能不仅可以发现问题,还可以提出解决方案和自动更新,从而使这项任务变得更加容易。由此产生的效率和项目时间的减少使得使用复杂的IDE成为一个明确的需求。
|
|
|
|
只有小组成员才能发言,加入小组>>
846 浏览 0 评论
1177 浏览 1 评论
2554 浏览 5 评论
2884 浏览 9 评论
移植了freeRTOS到STMf103之后显示没有定义的原因?
2742 浏览 6 评论
keil5中manage run-time environment怎么是灰色,不可以操作吗?
1159浏览 3评论
208浏览 2评论
477浏览 2评论
391浏览 2评论
M0518 PWM的电压输出只有2V左右,没有3.3V是怎么回事?
472浏览 1评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-7 20:26 , Processed in 1.130885 second(s), Total 56, Slave 47 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (威廉希尔官方网站 图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号