前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >用Python提取Verilog网表层次和实例化关系

用Python提取Verilog网表层次和实例化关系

作者头像
ExASIC
发布2021-12-27 10:28:59
8550
发布2021-12-27 10:28:59
举报
文章被收录于专栏:ExASIC

在《用Python写一个stdcell library的parser》中提到用标志位限定正则范围的方法其实很通用。我们知道Verilog网表文件很大,小的也有几十M、几百M,但Verilog网表没有形为级描述,只剩下stdcell和macro的实例化。

Verilog是由一个个module组成的,下面是其中一个module在网表中的样子,我只需要提取module名字、实例化关系。

代码语言:javascript
复制
module rst_filter (
    ...);
    端口声明... 
    wire定义...
    
   FUBS7T rst_n_ext_sync1_reg (.D(rst_n_ext),
       .Q(rst_n_ext_sync1),
       .T(clk));
   FUBS7T rst_n_ext_sync2_reg (.D(rst_n_ext_sync1),
       .Q(rst_n_ext_sync2),
       .T(clk));
   FUDS7T low_filter_cnt_reg_0_ (.D(n39),
       .Q(low_filter_cnt[0]),
       .R(por),
       .T(clk));
   V01S7T U3 (.A(low_filter_cnt[6]),
       .Y(n9));
   V01S7T U4 (.A(low_filter_cnt[4]),
       .Y(n15));
   AN3S7T U5 (.A(low_filter_cnt[0]),
       .B(low_filter_cnt[1]),
       .C(low_filter_cnt[2]),
       .Y(n41));
   N02S7T U6 (.A(n41),
       .B(low_filter_cnt[3]),
       .Y(n17));
   R02S7T U7 (.A(n15),
       .B(n17),
       .Y(n13));
   //...
endmodule

来观察规律:

  • 模块名的规律:module xxx (
  • 实例化的规律:xxx yyy (

所以写正则还是比较简单的。

代码语言:javascript
复制
def read_vlog_netlist(vlog_file):
    vlog_lines = open(vlog_file, 'r').readlines()
    #get inst tree
    module_start = 0
    modules = {}
    for line in vlog_lines:
        module_start_m = re.search('module\s+(\w+)', line)
        inst_m         = re.search('\s+(\w+)\s+(\w+)\s*\(', line)
        module_end_m   = re.search('endmodule', line)
        
        if module_start_m:
            module_start = 1
            module = {}
            
            module_name = module_start_m.group(1)
            module['module_name'] = module_name

            insts = {}
            module['insts'] = insts

            modules[module_name] = module            
            
        if module_end_m:
            module_start = 0

        if inst_m:
            module_name = inst_m.group(1)
            inst_name = inst_m.group(2)
            insts[inst_name] = module_name

    return modules

数据存储结构:

代码语言:javascript
复制
modules = {
    "module1": {
        "module_name": module1,
        "module_inst": {
            "inst1": "stdcell1",
            "inst2": "stdcell2",
            ...
        }
    }
    "module2": {
        ...
    }
    "module3": {
        ...
    }
}

测试一下:

代码语言:javascript
复制
import netlistparser as nl
modules = nl.read_vlog_netlist("digital_pr.v")
print(json.dumps(modules, indent=4))

结果输出如下。是不是效果还不错!

代码语言:javascript
复制
{
    "spr_1": {
        "module_name": "spr_1",
        "insts": {
            "spr_gate806": "V01S7T",
            "spr_gate805": "V01S7T",
            "spr_gate804": "V01S7T",
            "spr_gate803": "V01S7T",
            "spr_gate802": "V01S7T",
            ...
        }
    },
    "gclk_3": {
        "module_name": "gclk_3",
        "insts": {
            "icg": "TLATNTSCAL7T"
        }
    },
    "rst_filter": {
        "module_name": "rst_filter",
        "insts": {
            "rst_n_ext_sync1_reg": "FUBS7T",
            "rst_n_ext_sync2_reg": "FUBS7T",
            "low_filter_cnt_reg_0_": "FUDS7T",
            "low_filter_cnt_reg_9_": "FUDS7T",
            ...
        }
    },
    ...
}

总结:

正则不难,难的是善于总结和灵活应用。定义合理的数据存储结构也是非常重要的,后续操作会简便很多。

分享让工作更轻松

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-12-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 ExASIC 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档