相关阅读
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.v
arch_name = top
base_name = top
dont_use_cells_effective = base_cell:HOLDX1
entity_filename = test.v
entity_name = top
escaped_name = top
hdl_all_filelist = {default -v2001 {SYNTHESIS} {test.v} {} {}}
hdl_filelist = {default -v2001 {SYNTHESIS} {test.v} {} {}}
hdl_user_name = top
language = Verilog
library_name = default
lp_clock_gating_max_flops = inf
lp_clock_gating_min_flops = 3
name = top
obj_type = design
sdp_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/clk
net:top/clk
port_bus:top/clk
port: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 不允许