PT:pt write_change to innovus 脚本

2024-05-10 13:36
文章标签 脚本 change write pt innovus

本文主要是介绍PT:pt write_change to innovus 脚本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

7b0b406f5e7b4f36a876346d5703a6e8.png

6a628bd160cb49099f8a9622849a011d.png

我正在「拾陆楼」和朋友们讨论有趣的话题,你⼀起来吧?

拾陆楼知识星球入口

0e09f6874287495aad250a66f26f9d41.png

#!usr/bin/perl
open rf,"$ARGV[0]";
open wf,">test. tcl";

while (<rf>) {
          s/\[(\D[^\s\]]*)?\]/\\\[$1\\\]/g;
          if (/current _ instances$/) {
                 $curinst = "";
                 $hinst = "";
                 $orient_mark=0;
                 next
          }
          if (/current_instance\s+{(\S+)}/) {
                 $curinst = "$1";
                 $curinst =~s/^{//g;
                 $curinst =~s/}$//g;
                 $hinst ="-hinstGuide ${curinst}
                 $curinst ="${curinst}\/";
                 next
          }
          if (/insert _ buffer\s+\[get_ pins\s+\{(.*)\}\]\s+(\S+)\s+-new_net_names\s+\{(\S+)\}\s+-new_cell_names\s+\{(\S+)\}\s+-location\s+\{(.*)\}\s+-orientation\s+(\S+)/ ) {
                 $term_name = "${curinst}$1";
                 $cell_name = $2;
                 $net_name = $3;
                 $name = $4;
                 $location = $5;
                 $ori2 = $6;
                 if ($ori2 eq "N") {$ori = "R0"}

                 if ($ori2 eq"FS") {$ori = "MX"}

                 if ($ori2 eq "S") {$ori = "R180"}

                 if ($ori2 eq"FN") {$ori = "MY"}

                 print wf "set result [ecoAddRepeater -term $term_name -cell $cell_name -newNetName $net_name -name $name -loc {$location} -bufOrient $ori $hinst]\n"; 

                next

        }

       if (/add buffer_on_route\s+\[get _ net -of (.*)\]\s+-user_specified_buffers\s+\{\s*(.*)\s*\}\s+.*/) {

               $pin = $1;

               $ll = $2;

               $i = 0;

               $inst_list = "";

               $cell_list = "";

               $pt = "";

               $j = 0;

               $pin =~ s/^{//g;

               $pin =~ s/}$//g;

               foreach (split(/\s+/,$ll)) {

                       $i+=1;

                       if ($i==1) {

                               $inst_list="$inst_list $_";

                       } elsif ($i==2) {

                               $cell_list="$cell_list $_";

                       } elsif ($i==3) {

                               $pt="$pt $_";

                       } elsif ($i==4) {

                               $pt="$pt $_";

                       } elsif ($i==5) {

                               $i=0;

                       }

                      $orient_mark=1;

             }

             @cell_list = split(/\s+/,$cell _ list);

             if ( @cell_list > 1) {

                      print wf "set result  [ecoAddRepeater -net [get_object_name [get_net -of ${curinst}$pin]] -cell \"$cell _ list\" -loc \"$pt\" -name \"$inst _ list\"]\n";

             } else {

                      print wf "set result [ecoAddRepeater -net [get_object_name [get_net -of ${curinst}$pin]] -cell \"$cell_ list\" -loc \"$pt\" -name \"$inst_list\" $hinst]\n";

            }

    } elsif (/set_cell_location -coordinates\s+{(.*)}\s+-orientation\s+(\S+)\s+\[get_cells\s+{(.*)}/) {

         $ori2= $2;

         $loc2 = $1;

         $c2 = $3;

        if ($ori2 eq"N") {$ori = "R0"}

        if ($ori2 eq"FS") {$ori = "MX"}

        if ($ori2 eq "S") {$ori = "R180"}

        if ($ori2 eq"FN") {$ori = "MY"}

       @cell_list = split(/\s+/,$cell_list);

       if ($orient_mark && @cell_list > 1) {

                  print wf "dbSet [dbGet -p top.inst.name [lindex \$result $j ]].orient $ori\n";

print wf "dbSet [dbGet -p top.inst.name [lindex \$result $j ]]. pt \"$loc2\"\n";

} else {

print wf "dbSet [dbGet -p top.inst.name ${curinst}$c2]. orient $ori\n";

print wf "dbSet [dbGet -p top.inst.name ${curinst}$c2]. pt \"$loc2\"\n";

}

$j+=3;

} elsif (/size_cell\s{(\S+)}\s+{(\S+)}$/) {

print wf "ecoChangeCell -inst ${curinst}$1 -cell $2\n";

$orient_mark=0;

} else {

$j=0;

print wf $_;

}

close rf;

close wf

 

 

这篇关于PT:pt write_change to innovus 脚本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/976587

相关文章

Linux使用nohup命令在后台运行脚本

《Linux使用nohup命令在后台运行脚本》在Linux或类Unix系统中,后台运行脚本是一项非常实用的技能,尤其适用于需要长时间运行的任务或服务,本文我们来看看如何使用nohup命令在后台... 目录nohup 命令简介基本用法输出重定向& 符号的作用后台进程的特点注意事项实际应用场景长时间运行的任务服

如何使用 Bash 脚本中的time命令来统计命令执行时间(中英双语)

《如何使用Bash脚本中的time命令来统计命令执行时间(中英双语)》本文介绍了如何在Bash脚本中使用`time`命令来测量命令执行时间,包括`real`、`user`和`sys`三个时间指标,... 使用 Bash 脚本中的 time 命令来统计命令执行时间在日常的开发和运维过程中,性能监控和优化是不

bat脚本启动git bash窗口,并执行命令方式

《bat脚本启动gitbash窗口,并执行命令方式》本文介绍了如何在Windows服务器上使用cmd启动jar包时出现乱码的问题,并提供了解决方法——使用GitBash窗口启动并设置编码,通过编写s... 目录一、简介二、使用说明2.1 start.BAT脚本2.2 参数说明2.3 效果总结一、简介某些情

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

fzu 2277 Change 线段树

Problem 2277 Change Time Limit: 2000 mSec    Memory Limit : 262144 KB  Problem Description There is a rooted tree with n nodes, number from 1-n. Root’s number is 1.Each node has a value ai.

centos6一键安装vsftpd脚本

centos6一键安装vsftpd脚本 手动安装vsftpd参考教程:Centos下安装Vsftpd的图文教程 vsftpd脚本功能: 1.安装 (命令执行:sh xxx.sh)2.添加ftp用户 (命令执行:sh xxx.sh add)3.卸载vsftpd (命令执行:sh xxx.sh uninstall) 测试环境:centos6 x64 centos6 x86(测试centos7以

Android逆向(反调,脱壳,过ssl证书脚本)

文章目录 总结 基础Android基础工具 定位关键代码页面activity定位数据包参数定位堆栈追踪 编写反调脱壳好用的脚本过ssl证书校验抓包反调的脚本打印堆栈bilibili反调的脚本 总结 暑假做了两个月的Android逆向,记录一下自己学到的东西。对于app渗透有了一些思路。 这两个月主要做的是代码分析,对于分析完后的持久化等没有学习。主要是如何反编译源码,如何找到

Lua 脚本在 Redis 中执行时的原子性以及与redis的事务的区别

在 Redis 中,Lua 脚本具有原子性是因为 Redis 保证在执行脚本时,脚本中的所有操作都会被当作一个不可分割的整体。具体来说,Redis 使用单线程的执行模型来处理命令,因此当 Lua 脚本在 Redis 中执行时,不会有其他命令打断脚本的执行过程。脚本中的所有操作都将连续执行,直到脚本执行完成后,Redis 才会继续处理其他客户端的请求。 Lua 脚本在 Redis 中原子性的原因

CentOs7上Mysql快速迁移脚本

因公司业务需要,对原来在/usr/local/mysql/data目录下的数据迁移到/data/local/mysql/mysqlData。 原因是系统盘太小,只有20G,几下就快满了。 参考过几篇文章,基于大神们的思路,我封装成了.sh脚本。 步骤如下: 1) 先修改好/etc/my.cnf,        ##[mysqld]       ##datadir=/data/loc

PHP抓取网站图片脚本

方法一: <?phpheader("Content-type:image/jpeg"); class download_image{function read_url($str) { $file=fopen($str,"r");$result = ''; while(!feof($file)) { $result.=fgets($file,9999); } fclose($file); re