当前位置: 首页 > news >正文

Spyglass:官方Hands-on Training(一)

相关阅读

Spyglasshttps://blog.csdn.net/weixin_45791458/category_12828934.html?spm=1001.2014.3001.5482


        本文是对Spyglass Hands-on Training中第一个实验的翻译(有删改),Lab文件可以从以下链接获取。Spyglass Hands-on Traininghttps://download.csdn.net/download/qq_43699362/85585058?ops_request_misc=%257B%2522request%255Fid%2522%253A%25225fb1922ab549e363d5c551d14bebd31a%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fdownload.%2522%257D&request_id=5fb1922ab549e363d5c551d14bebd31a&biz_id=1&utm_medium=distribute.pc_search_result.none-task-download-2~download~first_rank_ecpm_v1~rank_v31_ecpm-30-85585058-null-null.269^v2^control&utm_term=Spyglass%20Get%20Start&spm=1018.2226.3001.4451.31


        本教程提供了在多个设计阶段中运行SpyGlass的操作指导,旨在通过实操获得对SpyGlass设置及其结果调试/分析的深入理解,涵盖多个动手练习,每个练习之间是相互依赖的,需要按顺序完成。

实验概述

        图1展示了实验使用设计的模块框图。该设计包含一个USB控制器和一个音频解码器核心(IMA_ADPCM),使用Wishbone总线协议,这些模块通过Wishbone总线矩阵(WB_Connmax)相互连接,然后再通过Wishbone-to-AHB桥接模块(wb2ahb)连接至AMBA AHB总线。顺带一提,该设计是一个混合语言RTL设计,即同时使用Verilog和VHDL。

图1 设计框图

实验目录的内容

        教程目录包含以下子目录:

  • rtl:与设计相关的RTL文件
  • spyglass:实验的工作目录,所有SpyGlass的运行将在该目录下进行
  • doc:包含实验文档(即本手册)
  • tools:实验中会使用到的其他脚本

实验一、Spyglass概述

        实验一的目标是快速开始使用SpyGlass,在其中运行分析并查看结果。由于该案例将用于后续的多个实验,建议将实验一创建的项目文件保存以供以后使用。

        实验一中,为了简便使用图形用户界面(GUI)创建一个项目文件作为起点,之后的实验将继续使用该项目文件以批处理方式(Batch)进行操作。

将设计读入SpyGlass

1、进入名为spyglass的目录。

% cd Training_labs/spyglass

2、使用以下命令启动SpyGlass图形界面(SpyGlass Explorer):

% spyglass

        由于Spyglass是Synopsys收购自Atrenta,最初使用的GUI是Atrenta Console,但目前已经被新的SpyGlass Explorer替代,不再进行任何更新。感兴趣的读者可以通过添加-gui=console选项启动Atrenta Console。

3、此时你将看到以下的主界面窗口:

图1 SpyGlass Explorer

4、点击窗口左栏的Add File(s),打开名为Add File(s)的窗口,在该窗口中添加以下来自rtl目录的两个RTL文件,如图2所示。

rtl/ahb2wb.v  
rtl/wb_subsystem.v

图2 Add File(s)窗口

5、接着点击窗口左栏的Set Options,然后设置顶层设计模块为"wb_subsystem",如图3所示。

图3 设置顶层模块

6、现在选择Design Setup阶段下的Read Design,勾选Synthesize Netlist选项框并点击Run Design Read以启动设计读取(这其实是启动了一个名为Design_Read的目标)。一旦运行完成,就可以查看SpyGlass报告的设计读取错误,如图4所示。

图4 Design_Read的结果

        注意图4在Violations窗口选择Group By Severity,可以看出有三个来自ErrorAnalyzeBBox规则的错误,SpyGlass没有找到这些模块的定义,因此将其标记为黑盒(black box)。

        左边的实例窗口(Instances)使用不同颜色的文件形状标记状态:

  • 黄色:已综合的最底层实例。
  • 黑色:黑盒实例。
  • 绿色:未综合的最底层实例。

使用SpyGlass进行分析

1、选择Goal Setup阶段,并点击lint_rtl目标,使其绿色高亮,所选目标的用途可以在右边的Help窗口中查看,用于检查设计中的基本连接性问题,例如输入悬空、位宽不匹配等,如图5所示。为了简便,实验一只勾选这一个目标,如果有多个目标被勾选,它们将会顺序执行(顺带一提,lint_rtl目标是来自/Guideware/latest/block/rtl_handoff方法的lint子方法,Guideware是Spyglass提供的一些预设的检查参考)。

图5 选择目标

2、点击Run Goal(s),一旦运行完成,工具将自动跳转至Analyze Results阶段,还是在Violations窗口选择Group By Severity,可以看出除了之前的三个来自ErrorAnalyzeBBox规则的错误,多了三个InferLatch规则的错误,双击选中第一个规则,相关的RTL代码行将在上方的HDL查看器中被红色高亮显示,如图6所示。

图6 Lint的结果

        可以看出RTL代码中包含了不完整的if语句,这确实是导致Latch产生的原因,同时注意到三个InferLatch规则的左边有NAND门符号,这代表可以查看用于调试的原理图。可以使用快捷键I或者点击Violations窗口上的符号查看原理图,如图7所示。

图7 原理图

        可以看出hready信号综合成了一个锁存器,如果设计意图就是需要hready信号相对于选通信号stb_o被锁存,那么可以该规则进行豁免(waive);如果确实需要修复该问题,可以点击RTL代码行,并按下键盘上的快捷键e(或右键选择Open Editor选项),Spyglass会使用默认文本编辑器(Vim)打开RTL文件并将光标定位到该行,如果想更改默认文本编辑器,可以看下面的博客。

Spyglass:更改默认编辑器https://chenzhang.blog.csdn.net/article/details/143947206

3、保存项目文件,点击File选项栏下的Save Project,然后输入wb_subsystem作为文件名),并退出。

4、使用文本编辑器打开项目文件wb_subsystem.prj,如下所示。

#!SPYGLASS_PROJECT_FILE
#!VERSION 3.0
#  -------------------------------------------------------------------
#  This is a software generated project file. Manual edits to this file could be lost during the next save operation
#  Copyright Synopsys Inc.
#  Last Updated By: SpyGlass SpyGlass_vW-2024.09-SP1
#  Last Updated On Wed Apr 30 17:35:59 2025
#
#  -------------------------------------------------------------------##Data Import Sectionread_file -type verilog ../rtl/ahb2wb.v
#BackRefFile:/home/zhangchen/Training_labs/spyglass/wb_subsystem.prj #LineNumber:13
read_file -type verilog ../rtl/wb_subsystem.v
#BackRefFile:/home/zhangchen/Training_labs/spyglass/wb_subsystem.prj #LineNumber:15##Common Options Sectionset_option projectwdir .
set_option language_mode mixed
set_option designread_enable_synthesis yes
set_option designread_disable_flatten no
set_option top wb_subsystem
set_option active_methodology $SPYGLASS_HOME/GuideWare/latest/block/rtl_handoff##Goal Setup Sectioncurrent_methodology $SPYGLASS_HOME/GuideWare/latest/block/rtl_handoff

        可以看出,其中的Data Import Section包括了一些文件读取的命令,而Common Options Section包括了工作目录、语言模式、顶层设计和方法的设置。在实验二中,需要继续向项目文件中添加额外的命令和选项。

相关文章:

  • MyBatis的SQL映射文件中,`#`和`$`符号的区别
  • MCP的基础知识
  • 软件测试52讲学习分享:深入理解单元测试
  • Rust 学习笔记:枚举与模式匹配
  • MiWi|Microchip开发的专有无线通信协议,适用于低功耗、短距离的无线个人局域网【无线通信小百科】
  • 【AI】DeepSeek 流程图 / 时序图制作,Word 排版错乱问题,文字转直观图形
  • 使用通义千问大模型做结构化输出报错的分析
  • Windows 中搭建 browser-use WebUI 1.4
  • GPU集群搭建步骤
  • Dify 获取天气数据并以echarts图表显示
  • 深入解析词嵌入(Word2Vec、GloVe)技术原理:从词语到向量的转变
  • 三个概念:DataBinding,Dependency Property 与DataTemplate
  • MCP与开源社区的共赢之道:携手推动技术创新
  • iOS RunLoop 深入解析
  • ZStack Cloud 5.3.28正式发布
  • macOS 安装了Docker Desktop版终端docker 命令没办法使用
  • 如何选择合适的铸铁地板?在工业行业靠什么优势稳步前进?(北重)
  • PostgreSQL中的SSL(2)
  • 提高程序灵活性和效率的利器:Natasha动态编译库【.Net】
  • React-Native Android 多行被截断
  • 锦江酒店:第一季度营业收入约29.42亿元,境内酒店出租率同比增长
  • 农业农村部:把住能繁母猪存栏量“总开关”,引导养殖场户优化母猪存栏结构、合理控制产能
  • 中公教育薪酬透视:董监高合计涨薪122万,员工精简近三成
  • 加拿大今日大选:房价、印度移民和特朗普,年轻人在焦虑什么?
  • 加拿大警方:已确认有9人在温哥华驾车撞人事件中遇难
  • 我驻美使馆:中美并没有就关税问题磋商谈判,更谈不上达成协议