Loading

klayout安装及使用教程

klayout

版本:klayout-0.26.9

我的系统环境:Deepin20(可以视为Debian)

修改过的代码地址:https://github.com/stuartofmine/klayout

注意,对源代码有所修改。主要在于解决编译错误和加快编译速度。

需要安装的工具如下:

C ++ :gcc,g ++和make

Qt:libqt4-dev-bin和libqt4-dev,qt4-qmake

Ruby:ruby和ruby-dev

Python:python3和python3-dev

zlib:libz-dev

加速编译:ccache

qmake

进入klayout目录下,打开终端,输入

./build.sh -j8 -ruby /usr/bin/ruby

默认调用qmake,使用-j8设置为八线程。使用-j32设置32线程运行。具体线程数根据内核数而定。注意,这里没有加-debug选项,因此不能用gdb调试。

如果报错提示找不到qmake,输入

sudo apt install qt4-qmake

等待编译完成。

如果提示找不到QString等库,请排查前述的依赖工具是否已安装

编译成功

进入 bin-release目录下

输入,注意,由于shell版本不同,可能需要改为~/.zshrc

vim ~/.bashrc

在目录最后输入

export LD_LIBRARY_PATH=“你的bin-release目录路径”

保存并退出

输入.注意,由于 shell 解释器不同,可能需要改为~/.zshrc

source ~/.bashrc

再输入

./klayout

成功:)

qtcreator

1.在项目-Build中关闭 shadow build。在额外参数一栏,输入:

HAVE_RUBY=1
RUBYVERSIONCODE=20505 
RUBYINCLUDE=/usr/include/ruby-2.5.0 
RUBYINCLUDE2=/usr/include/x86_64-linux-gnu/ruby-2.5.0 
RUBYLIBFILE=/usr/lib/x86_64-linux-gnu/libruby-2.5.so.2.5.0

注意,所用ruby版本为ruby-2.5.0版本,其他版本对上述代码更改版本号即可。

2.在项目-Run-运行配置中修改运行配置为klayout_main。

在Command line arguments一栏输入

-e

-e是为了开启编辑模式,编辑DRC之类的必须开启。

3.当QTcreator使用的qmake为qt5时,应将layMainWindow.h中的

#include <QPrinter>

改为

#include <QtPrintSupport/QPrinter>

同时,需要在lay.pro中添加

QT += printsupport

保存。

4.假如内存不到8G,可能会被中止,使用

sudo fallocate -l 4G /swapfile
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile
sudo cp /etc/fstab /etc/fstab.bak
echo '/swapfile none swap sw 0 0' | sudo tee -a /etc/fstab

来创建交换分区。

5.关闭shadow build后,生成的动态库位于src目录下(若不关闭则生成一个build-klayout-Desktop-xxxxxxxx目录)

与bin-release目录同样的,将src目录加入/.bashrc。注意,由于版本不同,在ubuntu服务器上应为/.zshrc

vim ~/.bashrc

在其末尾添加

export LD_LIBRARY_PATH=“你的src目录路径”

保存并退出,注意,由于 shell 解释器不同,可能需要改为~/.zshrc

source ~/.bashrc

6.如果遇到Makefile错误,提示plugins目录下无法编译完成。形如下图

这是由于src目录下的Makefile进入plugins子项目流程时,没有清除上一次失败构建留下的Makefile,并且一共有三个Makefile需要清除。

暂时对src目录下的Makefile不作修改,打开终端,进入src/plugins目录,输入

rm Makefile */Makefile

即可。

如果不起作用,修改shadow build选项(开启就改为关闭,关闭就改为开启)。

7.点击编译。耗时约十分钟。

8.成功:)

gdb

需要在编译时加入 -debug 选项。操作示例:

gdb ./klayout
b rba.cc:134
Make breakpoint pending on future shared library load? (y or [n]) y
r

以上代码在rba.cc的134行加入了一个断点。

直接使用.drc编译,不开GUI

将你需要的.drc 放在src目录下(关闭shadow build时)

在Qt的项目->run->Command line arguments里内输入

-x set args -d 41 -b -r ./你的drc文件 -zz

这样不会开启GUI界面,但是断点调试之类与之前一致。

使用指南(青春版)

浏览量不小,顺便更新一下使用指南(青春版)。详询官网。
打开klayout后,先通过左上角"file"栏下的"New Layout"新建layout,再通过"Edit"栏下的"Layer"-->"New Layer"新建layer。

通过第二栏的各种Polygon和Box之类,在这个Layer上尽情发挥你熊熊燃烧的艺术才能。需要说明的是,一个Layout里可以有多个Layer。

在"Tools"栏下的"DRC"--->"New DRC Script"里,编辑DRC文件并运行。

再写下去就是各种细节了,请查询官网 klayout.de

posted @ 2021-04-08 10:05  白叶Stuart  阅读(14093)  评论(0编辑  收藏  举报