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

Genus:设计信息结构以及导航方式(路径种类)

相关阅读

Genushttps://blog.csdn.net/weixin_45791458/category_13003519.html?spm=1001.2014.3001.5482


        Genus使用设计信息结构(Design Information Hierarchy)对数据库进行建模,其中包括各种对象以及其属性,设计信息结构与Linux的目录结构非常相似,如图1所示。

图1 设计信息结构

        当用户启动Genus时会进入设计信息结构的根目录/或者说root,如下面的命令提示符所示。

@genus:root: 1> 

        就像Linux中的ls、cd、pwd命令那样,Genus也提供了很多导航命令用于与设计信息结构进行交互,如下所示。

get_logical_name
get_object_type
set_top_module
vbasename
vcd
vdirname
vdirs
vfind
vls
vname
vpopd
vpushd
vpwd

        下面将以vls命令为例,说明设计信息结构中的导航方式及路径种类,首先在根目录中使用vls命令查看内容,如下所示。

@genus:root: 1> vls
./              designs/        hdl_libraries/  messages/       tech/         
commands/       flows/          libraries/      obj_types/ 

        其中designs目录保存了设计对象,使用vls命令查看其内容,如下所示。

@genus:root: 2> vls ./designs 
root:.designs:
./  

        由于尚未读取设计,此时其为空目录,下面使用read_hdl命令读取设计、read_libs命令读取库、最后使用elaborate命令展开设计,如下所示。

@genus:root: 3> read_hdl test.v
@genus:root: 4> read_libs slow.lib
@genus:root: 5> elaborate top
*****

        此时使用vls命令查看,可以发现designs目录中出现了一个目录top,注意使用了-attribute选项显示属性信息,小括号中的design表示目录top是一个设计对象,如下所示。

@genus:root: 6> vls ./designs -attribute
root:.designs:
Total: 2 items
./                  
top/                 (design)Attributes:arch_filename = test.varch_name = topbase_name = topdont_use_cells_effective = base_cell:HOLDX1entity_filename = test.ventity_name = topescaped_name = tophdl_all_filelist = {default -v2001 {SYNTHESIS} {test.v} {} {}}hdl_filelist = {default -v2001 {SYNTHESIS} {test.v} {} {}}hdl_user_name = toplanguage = Veriloglibrary_name = defaultlp_clock_gating_max_flops = inflp_clock_gating_min_flops = 3name = topobj_type = designsdp_files = verification_directory = fv/top

        Genus中的所有对象都是由目录或文件(如果其不可再分)表示的,例如/designs/top是一个设计对象,/designs/top/nets/clk是一个线网对象,/designs/top/ports/clk是一个端口对象。但不是所有目录都表示对象,例如/designs不是对象,/designs/top/nets不是对象,/designs/top/ports不是对象。

        细心的读者可能注意到了,之前的所有路径都是以相对路径的形式给出的,就像是Linux中的相对路径那样,但设计信息结构的路径种类却更复杂(PS:Genus的手册上对这些路径的用法解释地十分模糊,笔者也是经过了大量的实验进行了总结)。

完整的绝对路径

        完整的绝对路径就是从根目录写起(以/开头)的路径,下面展示了几个完整的绝对路径(它们之中有些是对象,有些不是)。

/designs                                  // 非对象
/designs/top                              // 对象
/designs/top/nets                         // 非对象
/designs/top/ports                        // 非对象
/designs/top/nets/clk                     // 对象
/designs/top/ports/clk                    // 对象
/libraries                                // 非对象
/libraries/base_cells                     // 非对象
/libraries/base_cells/OR2X1               // 对象
/libraries/base_cells/OR2X1/base_pins     // 非对象
/libraries/base_cells/OR2X1/base_pins/A   // 对象

不完整的绝对路径

        如果路径层次较深,使用完整的绝对路径会显得十分臃肿和繁琐,不完整的绝对路径允许在路径中只保留(如有)那些作为对象的层次(对于那些不作为对象的层次,可以任意删减),下面展示了几个不完整的绝对路径(它们之中有些是对象,有些不是)。

/top                // 对象
/top/nets           // 非对象
/top/ports          // 非对象
/top/nets/clk       // 对象
/top/ports/clk      // 对象
/top/clk            // 对象
/base_cells         // 非对象
/base_cells/OR2X1   // 对象
/libraries/OR2X1    // 对象
/OR2X1              // 对象
/OR2X1/base_pins    // 非对象
/OR2X1/base_pins/A  // 对象
/OR2X1/A            // 对象

完整的相对路径

        完整的相对路径就是相对当前目录(以./或../开头)的路径,下面展示了几个完整的相对路径(它们之中有些是对象,有些不是)。

// 假设当前工作目录为/designs
./                                          // 非对象
./top                                       // 对象
./top/nets                                  // 非对象
./top/ports                                 // 非对象
./top/nets/clk                              // 对象
./top/ports/clk                             // 对象
../libraries                                // 非对象
../libraries/base_cells                     // 非对象
../libraries/base_cells/OR2X1               // 对象
../libraries/base_cells/OR2X1/base_pins     // 非对象
../libraries/base_cells/OR2X1/base_pins/A   // 对象

不完整的相对路径

        就像不完整的绝对路径那样,不完整的相对路径允许在路径中只保留(如有)那些作为对象的层次(对于那些不作为对象的层次,可以任意删减),下面展示了几个不完整的绝对路径(它们之中有些是对象,有些不是)。

// 假设当前工作目录为/designs
./top/clk             // 对象
../base_cells         // 非对象
../base_cells/OR2X1   // 对象
../libraries/OR2X1    // 对象
../OR2X1              // 对象
../OR2X1/base_pins    // 非对象
../OR2X1/base_pins/A  // 对象
../OR2X1/A            // 对象

完整的相对path属性的路径

        与Linux不同的是,当路径不以/或./或../开头时将视为相对path属性,下面展示了几个完整的相对path属性的路径(它们之中有些是对象,有些不是)。

// 假设path属性为/designs
top                                                // 对象
top/nets                                           // 非对象
top/ports                                          // 非对象
top/nets/clk                                       // 对象
top/ports/clk                                      // 对象
top/../../libraries/                               // 非对象
top/../../libraries/base_cells                     // 非对象
top/../../libraries/base_cells/OR2X1               // 对象
top/../../libraries/base_cells/OR2X1/base_pins     // 非对象
top/../../libraries/base_cells/OR2X1/base_pins/A   // 对象

不完整的相对path属性的路径

        就像不完整的绝对路径那样,不完整的相对path属性的路径允许在路径中只保留(如有)那些作为对象的层次(对于那些不作为对象的层次,可以任意删减),下面展示了几个不完整的相对path属性的路径(它们之中有些是对象,有些不是)。

// 假设path属性为/designs
top/clk                      // 对象
top/../../base_cells         // 非对象
top/../../base_cells/OR2X1   // 对象
top/../../libraries/OR2X1    // 对象
top/../../OR2X1              // 对象
top/../../OR2X1/base_pins    // 非对象
top/../../OR2X1/base_pins/A  // 对象
top/../../OR2X1/A            // 对象

指定对象类型的路径

        当使用不完整的路径时,可能会出现一个路径对应多种对象的情况,如下所示。

@genus:root:.messages 7> vls /top/clk
hnet:top/clknet:top/clkport_bus:top/clkport:top/clk
@genus:root:.messages 8> vcd /top/clk
Error   : A single object was expected, but multiple objects were found. [TUI-62] [vcd]: The argument that found multiple objects was '/top/clk'.: Use the 'vfind' command to narrow the list down to a single object.vcd: sets position in object hierarchy 

        对于vls命令,它会考虑所有符合的对象,但对于vcd命令,他只能接受一个对象,就会出现错误。

        使用类型作为前缀可以解决这个问题,但需要注意的是,该方法将会把所有路径视为相对根目录(即使以./开头),下面展示了几个指定对象类型的路径(它们之中有些是对象,有些不是)。

        需要注意的是,如果指定对象类型,如果不会出现一个路径对应多个对象的情况,则允许在路径中只保留最后一层对象名(对于其他层次,可以任意删减,这更加激进)。

// 指定对象类型主要是为了解决不完整路径,因此不展示完整路径的例子
design:/top                  // 对象
net:/top/nets/clk            // 对象
port:/top/ports/clk          // 对象
net:/top/clk                 // 对象
port:/top/clk                // 对象
port:/clk                    // 对象
net:/clk                     // 对象
base_cell:/base_cells/OR2X1  // 对象
base_cell:/libraries/OR2X1   // 对象
base_cell:/OR2X1             // 对象
base_pin:/OR2X1/base_pins/A  // 对象
base_pin:/OR2X1/A            // 对象// base_pin:/A 不允许           
http://www.dtcms.com/a/273871.html

相关文章:

  • Java中的泛型继承
  • 【C语言进阶】带你由浅入深了解指针【第四期】:数组指针的应用、介绍函数指针
  • 【Spring Boot】Spring Boot 4.0 的颠覆性AI特性全景解析,结合智能编码实战案例、底层架构革新及Prompt工程手册
  • mysql的LIMIT 用法
  • 1 APP-OneNET 生成token密钥
  • Ubuntu2404修改国内镜像
  • 我的第一个开源项目|Geex:道阻且长的开源之路
  • docker的学习
  • React中Redux基础和路由介绍
  • 将手工建模模型(fbx、obj)转换为3dtiles的免费工具!
  • threejs案例开发-中国3D国旗动画
  • PostgreSQL 查询库中所有表占用磁盘大小、表大小
  • [Meetily后端框架] 多模型-Pydantic AI 代理-统一抽象 | SQLite管理
  • 共享储能电站在工业用户经济调度中的matlab仿真
  • 需求升级,创新破局!苏州金龙赋能旅游客运新生态
  • Go中使用wire进行统一依赖注入管理
  • 【JavaScript高级】构造函数、原型链与数据处理
  • 3 OneNET-调试器模拟上报数据
  • 深入理解Spring声明式事务的同步管理机制
  • C++ 面向对象 - 对象定义方法汇总
  • MySQL:分析表锁的常见问题
  • Flowable 使用遇到问题
  • Redis Sentinel哨兵集群
  • 碳中和目标下的全球产业链重构:深度解析与未来路径
  • Maui劝退:用windows直接真机调试iOS,无须和Mac配对
  • 单片机显示Unicode字符介绍
  • PDXP、UDP与HDLC协议技术解析:架构、应用与对比研究
  • SpringBoot 拦截器和过滤器的区别
  • 如何高效验证代理IP的可用性与稳定性
  • 瀚高数据库提交数据后,是否需要COMMIT(APP)