教学文库网 - 权威文档分享云平台
您的当前位置:首页 > 文库大全 > 幼儿教育 >

数字后端流程二【Astro】

来源:网络收集 时间:2026-04-09
导读: 数字后端软件Astro的使用方法 Astro 是数字后端的布局布线的重要工具,还数字后端设计中,关于 Astro 的设计主要由以下几部分组成: 【1】 新建一个 pnr 文件夹,在其子目录下创建 clf cons in log lib out rpt script tf 以及一个 makefile 文件 【2】 clf

数字后端软件Astro的使用方法

Astro 是数字后端的布局布线的重要工具,还数字后端设计中,关于 Astro 的设计主要由以下几部分组成:

【1】 新建一个 pnr 文件夹,在其子目录下创建 clf cons in log lib out rpt script tf 以及一个

makefile 文件

【2】 clf 文件夹中主要存放工艺延时 功耗 负载 等相关文件以便导入 主要可以有以下几个部分 :

antenna_*lm.clf *.clf.logic *.clf.power *.clf.time 可以由 Foundry 提供的工艺库文件中拷贝

【3】 cons 文件夹中主要存放 Macro PAD Locationa 文件 Pin Location 文件,dbdefine 文件 以及 antenna rules 文件 以便导入设计中使用

【4】 in 文件夹中主要存放有 DC 综合后生成的综合网表 *.sv 文件 时序约束文件 *.sdc 以及 *.sdf 文件,

但是需要对 sdc 文件进行相关修改后才能作为 Astro 布局布线的时序约束参考因此需要有一个 Makefile 文件对其内容进行修改

【5】 lib 文件夹中存放有 standard cell 的工艺库文件(如 silterra18)Foundry 工艺库中拷贝

【6】 tf 文件夹中存放有设计工艺库的技术文件 (如 silterra18_*lm.tf)Foundry 工艺库中拷贝

【7】 script 为了布局布线修改方便常会将运行的 Astro 命令导出到相应的脚本文件中,CTS 前布局一次为一

个脚本, CTS 后优化布局为一个脚本,最后布线以及 check 为一个脚本,存放在 script 文件夹中分别 命名为 pnr_1.scm pnr_2.scm pnr_3.scm

【8】 其余的文件夹分别存放输出的报告和网表以及 gds 文件,其中 log 文件夹中为 Astro 运行报告,rpt 中为

Astro CTS clock skew 分析报告,out 中为 gds 文件和布局布线后网表,以及 Wire RC 参数提取文件

*spef

Antenna_rules 文件是截取 Antenna_rules_*lm.clf 文件的一部分一般只截取 dbAddAntennaLayerRule 的定义 设计 中如下截取:

define

_libId (dbGetCurrentLibId) _libId 4 2 0 0

dbDefineAntennaRule

dbAddAntennaLayerRule _libId 4 "METAL1" 400 '(0.203 0 400.00 2200) dbAddAntennaLayerRule _libId 4 "METAL2" 400 '(0.203 0 400.00 2200) dbAddAntennaLayerRule _libId 4 "METAL3" 400 '(0.203 0 400.00 2200) dbAddAntennaLayerRule _libId 4 "METAL4" 400 '(0.203 0 400.00 2200) dbAddAntennaLayerRule _libId 4 "METAL5" 400 '(0.203 0 400.00 2200) dbAddAntennaLayerRule _libId 4 "METAL6" 400 '(0.203 0 8000.00 30000) dbAddAntennaLayerRule _libId 4 "VIA12" dbAddAntennaLayerRule _libId 4 "VIA23" dbAddAntennaLayerRule _libId 4 "VIA34" dbAddAntennaLayerRule _libId 4 "VIA45" dbAddAntennaLayerRule _libId 4 "VIA56"

20 '(0.203 0 20 '(0.203 0 20 '(0.203 0 20 '(0.203 0 20 '(0.203 0

83.33 83.33 83.33 83.33 83.33

75) 75) 75) 75) 75)

数字后端软件Astro的使用方法

dbDefine 文件是为了 Astro 做时钟树综合优化时作准备的,在 CTS 之前需调用该文件,Astro 做时钟树时只对它 默认的 DFF 的时钟管脚做相关处理一般是定义了 clock 但我们设计需要对一些多扇出的复位信号 scan 链信号做处 理就需要专门声明下这也是时钟树需要处理的信号,就在 dbDefine 做这样的声明,一般有同步复位、异步复 位、scan_enable 以及宏单元的 clk 信号,异步复位最常用 需要做 scan 链 才定义 SE,有 Memory 时才定义 clk, 具体设置如下:

(let* (

(selectedlist (geGetSelectedSet (getEditWindow))) )

(for-each (lambda (x) (let* (

(instName (dbFetchObjectField (geGetEditCell) x "name"))

)

(dbDefineSyncPin (geGetEditCell) instName '( ("RN" "nonInvertRise" 0) ("RN" "invertRise" 0)) ) (dbDefineSyncPin (geGetEditCell) instName '( ("SN" "nonInvertRise" 0) ("SN" "invertRise" 0)) ) ;; (dbDefineSyncPin (geGetEditCell) instName '( ("SE" "nonInvertRise" 0) ("SE" "invertRise" 0)) )

;; (dbDefineSyncPin (geGetEditCell) instName '( ("CLK" "nonInvertRise" 0) ("CLK" "invertRise" 0)) )

) )

selectedlist

)

)

tdf 文件定义相关的 PAD 或者是 PIN 的位置信息,坐标描述方法基本一致设计中根据实际的需要略有不同如

下:

tdfPurgePadConstr define define define

step1 offset off

5 50 0

39 0 0 "right" 39 0 0 "right" 39 0 0 "right" 39 0 0 "right"

0 (set! offset(+ step1 offset)) 0 (set! offset(+ step1 offset)) 0 (set! offset(+ step1 offset)) 0 (set! offset(+ step1 offset))

pin "clk" pin "rstn" pin "scan_mode" pin "mic_fm_sel"

在 Astro 布局布线时需要根据 DC 综合时设置生成的时序约束文件对相关 cel(l standard cell)进行布局优化, 通常在 Place 设置时考虑 congestion 和 time 因素,通常考虑关键性的时序路径,满足设计的时序约束条件,而对 于非关键路径的 cell 可以放置的远离些,增加延时,如果将非关键路径的 cell 布局在 关键时序路径布局区域就 会对其产生影响,使其布线拥塞增加布线难度。

数字后端软件Astro的使用方法

而对于 DC 生成的时序约束文件并不是直接就是导入使用,DC 中估算连线延时采用 wire_load_model 的方

法估算,但在 Astro 中我们实际对 cell 进行布线直接提取 wire 连线的 RC 信息计算 net delay 更为精确接近实际设 计,同时对各个时钟的 uncertainty 的定义也不需要了,CTS 后各个时钟负载和延时可以达到最佳平衡 uncertainty 只由 jitter 引起,虽然还是会存在 skew (几乎可以忽略),latency 主要有 2 部分组成 source_latency 和 network_latency 一般设计只考虑 network_latency ,Astro 不需要设置 network_latency ,CTS 后各个 DFF 的 network_latency 的基本平衡了。具体脚本如下:

#!/bin/bash

#echo "Enter the file name(<file>.sdc)" filename = ADPCM_Encoder

run:

#read $(filename)

cp $(filename).sdc $(filename).sdc.bak

echo ":%s/set_wire_load_model/#set_wire_load_model/g" > $(filename).vimrc echo ":%s/-dont_scale//g"

>> $(filename).vimrc

echo ":%s/set_is …… 此处隐藏:11451字,全部文档内容请下载后查看。喜欢就下载吧 ……

数字后端流程二【Astro】.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.jiaowen.net/wenku/1529451.html(转载请注明文章来源)
Copyright © 2020-2025 教文网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:78024566 邮箱:78024566@qq.com
苏ICP备19068818号-2
Top
× 游客快捷下载通道(下载后可以自由复制和排版)
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能出现无法下载或内容有问题,请联系客服协助您处理。
× 常见问题(客服时间:周一到周五 9:30-18:00)