前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >用Python写一个stdcell library的parser

用Python写一个stdcell library的parser

作者头像
ExASIC
发布2021-12-27 10:26:38
4800
发布2021-12-27 10:26:38
举报
文章被收录于专栏:ExASICExASIC

有时候我们只关心stdcell library里的逻辑定义:有哪些pin,面积多大,逻辑功能等。我们可以用正则写一个简单的parser。

library里包括了若干个cell的定义,除去时序和功耗信息,大致如下:

代码语言:javascript
复制
cell(A0127T) { 
    cell_footprint : A017T ; 
    area : 23.52 ;
    pin(A) { 
        capacitance : 0.006519 ; 
        direction : input ; 
    }
    pin(Y) { 
          direction : output ; 
          function : "(!(((A|B)&C)|D))" ; 
    }
}

总是以“cell(xxx) {”开头,以“}”结尾。pin的定义与cell定义结构类似,多行内容用大括号括在一起。所以,写正则有一个难点:这些信息分在多行

解决方法:用标志来标记每一种信息的开头和结束,来限定正则的范围。

代码语言:javascript
复制
def read_library(file_name):
    
    cells = {}
    
    lib_lines = open(file_name, 'r').readlines()

    pin_start = 0

    for line in lib_lines:
        cell_s_m = re.search(r'cell\((\w+)\)\s+{', line)
        area_m   = re.search(r'\sarea\s+:\s+(\S+)\s+', line) 
        pin_s_m  = re.search(r'\spin\((\w+)\)\s+{', line)
        dir_m    = re.search(r'\sdirection\s+:\s+(\w+)', line)
        func_m   = re.search(r'\sfunction\s+:\s+"(.*)"', line)
        end_m    = re.search(r'}', line)

        if cell_s_m:
            cell_start = 1
            cell = {}
            cell_name = cell_s_m.group(1)
            cell['cell_name'] = cell_name
            pins = []
            cell['pins'] = pins
            cells[cell_name] = cell

        if area_m:
            area = area_m.group(1)
            cell['area'] = area
        
        if pin_s_m:
            pin_start = 1
            pin = {}
            pin_name = pin_s_m.group(1)
            pin['pin_name'] = pin_name

        if dir_m:
            pin_dir = dir_m.group(1)
            pin['pin_dir'] = pin_dir

        if func_m:
            pin_func = func_m.group(1)
            pin['pin_func'] = pin_func

        if pin_start and end_m:
            pin_start = 0
            pins.append(pin)
            
    return cells

为了方便后续处理,自定义了stdcell library的数据存储结构:

代码语言:javascript
复制
cells = {
    cell1 : {
        'cell_name': 'cell1',
        'area': 2.1,
        'pins': [{
            'pin_name': 'Y',
            'pin_dir': 'output',
            'pin_func': "(!(((A|B)&C)|D))"
        },
        {
            'pin_name': ...
        }]
    }
    cell2: {
        ...
    }
}

测试一下,我们读入stdcell library,并提取出DFF的信息。

代码语言:javascript
复制
import libparser
import json

cells = libparser.read_library("../lib/worst.lib")
print(json.dumps(cells.get("FUDS7T"), indent=4))

输出结果如下:

代码语言:javascript
复制
{
    "cell_name": "FUDS7T",
    "pins": [
        {
            "pin_name": "D",
            "pin_dir": "input"
        },
        {
            "pin_name": "Q",
            "pin_dir": "output",
            "pin_func": "IQ"
        },
        {
            "pin_name": "QC",
            "pin_dir": "output",
            "pin_func": "IQN"
        },
        {
            "pin_name": "R",
            "pin_dir": "input"
        },
        {
            "pin_name": "T",
            "pin_dir": "input"
        }
    ],
    "area": "28"
}

下面的代码可以输出全部cell的信息:

代码语言:javascript
复制
print(json.dumps(cells, indent=4, sort_keys=True))

总结:

设置标志位,在区间里进行正则匹配,可以提高准确性和效率。

分享让工作更轻松

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

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据保险箱
数据保险箱(Cloud Data Coffer Service,CDCS)为您提供更高安全系数的企业核心数据存储服务。您可以通过自定义过期天数的方法删除数据,避免误删带来的损害,还可以将数据跨地域存储,防止一些不可抗因素导致的数据丢失。数据保险箱支持通过控制台、API 等多样化方式快速简单接入,实现海量数据的存储管理。您可以使用数据保险箱对文件数据进行上传、下载,最终实现数据的安全存储和提取。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档