1、专用集成电路设计方法,俞军 Tel:53085050 Email: ,课 程 安 排,专用集成电路 概述 1 周 ASIC的设计流程和设计方法(重点) 设计描述,设计流程 1周 设计策略,综合方法 1周 设计验证,ASIC设计中的考虑因素 1周 深亚微米设计方法和设计技术以及EDA技术的发展 1周,课 程 安 排,专用集成电路的测试方法 Design-for-Test Basics 2 周 可编程ASIC 可编程ASIC器件的结构,资源,分类和开发系统 1周 Xilinx,Altera可编程器件 2周,第一章 专用集成电路概述,1.1通用集成电路和专用集成电路 通用集成电路:市场上能买到的具有
2、通用功能的集成电路 74 系列 ,4000系列 , Memory, CPU 等 专用集成电路ASIC(Application Specific Integrated Circuits) SUN SPARC Workstation 中的9块电路,某些加密电路等,第一章 专用集成电路概述,专用标准电路ASSP(Application-Specific Standard Products) Modem 芯片, DVD decoder , VCD decoder, audio DAC, Motor Servo DSP 等,第一章 专用集成电路概述,1.2集成电路发展简史,第一章 专用集成电路概述,1.
3、4集成电路设计和制造过程 设计过程 制定规范(SPEC) 系统设计(System Design) 电路设计(Circuit Design) 版图设计(Layout Design) 制造过程 制版 掩膜版制造(MASK) 流片(Fab) 光刻,生长,扩散,掺杂,金属化,蒸铝等产生Pn结,NPN结构,MOS 电阻,电容等,第一章 专用集成电路概述,制造过程 测试(Testing) 以Spec和Test Vector 为标准检测制造出的芯片是否满足设计要求 封装(Pakaging) 划片(Cutting) 键合(Wire Bonding) 包封(Pakaging) 形式:DIP, QFP,PLCC,
4、PGA,BGA,FCPGA等,第一章 专用集成电路概述,集成电路功能测试示意图,集成电路设计过程,第一章 专用集成电路概述,1.5ASIC技术现状和发展趋势 摩尔规律: 每十八个月, 集成度增加一倍,速度上升一倍,器件密度上升一倍,第一章 专用集成电路概述,专用集成电路预测与发展 SOC (System on a chip) 工艺(Process)由0.35um,0.25um,0.18um进入0.13um,0.10um即高速,低压,低功耗 EDA设计工具与设计方法必须变革以适应深亚微米工艺的发展 (如 Single Pass , Physical Synthesis 等) 可编程器件向更高密度
5、,更大规模和更广泛的领域发展(如Mixed Signal ) MCM Analog 电路 - 高速,高精度,低功耗,低电压 ASIC产品的发展动向 内嵌式系统 (Embeded System) (自动控制, 仪器仪表) 计算机,通讯结合的系统芯片 (Cable Modem, 1G ) 多媒体芯片 (Mpeg Decoder Encoder, STB , IA ) 人工智能芯片 光集成电路,第二章ASIC设计流程和方法,2.1 概述 设计过程分 电路设计-前端设计 版图设计-后端设计 设计流程(方法)分 自底向上(Bottom Up) 自顶向下(Top Down) 数字集成电路设计 行为方面 结
6、构方面 物理方面,第二章ASIC设计流程和方法,2.1 概述 设计策略 设计描述 自动化设计的综合方法 设计验证方法 深亚微米设计方法和EAD 工具的发展,第二章ASIC设计流程和方法,2.2设计描述 描述方面 行为描述 结构描述 物理描述 设计抽象的层次 系统算法级 寄存器传输级(RTL级) 逻辑级和电路级 最低层的晶体管级电路,第二章ASIC设计流程和方法,2.2.1.硬件描述语言HDL (Hardware Description Language) VHDLVHDL描述能力强,覆盖面广,可用于多种层次的电路描述, VHDL的硬件描述与工艺技术无关,不会因工艺变化而使描述无效。 VHDL支
7、持设计再利用(Reuse)方法,支持超大规模集成电路设计的分解和组合。 可读性好,易于理解,国际标准,具备通用性。,第二章ASIC设计流程和方法,VHDL设计描述由五种基本设计单元组成 设计实体说明(Entity declaration) 结构体(Architecture body) 配置说明(Configuration declaration) 集合元说明(Package dec1aration) 集合元(Package body),第二章ASIC设计流程和方法,ENTITY mux IS GENERIC (m:TIME:=2ns); PORT (in1,in2,sel:IN BIT;out
8、1:OUT BIT); END mux; - 设计实体说明,第二章ASIC设计流程和方法,AECHITECTURE twown1 OF mux IS BEGINIF sel=1 THEN out1=1;ELSE out1=in2 AFTER m; END twown1; - 行为描述,第二章ASIC设计流程和方法,AECHITECTURE twown2 OF mux IS BEGINNOT:Sb=U0(sel);AND2:S1=U1(sel,in1);AND2:S2=U2(Sb,in2);OR:out1=U3(s1,s2); END twown2; - 结构描述1,第二章ASIC设计流程和方法
9、,AECHITECTURE twown3 OF mux IS BEGINNOT:Sb=U0(sel);NAND2:S1=U1(sel,in1);NAND2:S2=U2(Sb,in2);NAND:out1=U3(s1,s2); END twown3; - 结构描述2,VHDL 设计环境,第二章ASIC设计流程和方法,Verilog HDL 能用于行为描述和结构描述,电路描述同时可以包含不同层次,且能和混合模式的模型一起进行模拟 Verilog使用四值逻辑,即0,l,X和Z,其中“X”为不定态,Z为悬空态 使用的基本数据类型是 “与“和 “寄存器“。,第二章ASIC设计流程和方法,2.2.2 行为
10、描述(算法描述) 举例 一位全加器,第二章ASIC设计流程和方法,Verilog-HDL 描述进位算法描述,module carry(co,a,b,c);output co;input a,b,c; wire #10 co=(a&b)|(a&c)|(b&c) end module,第二章ASIC设计流程和方法,2.23结构描述 RTL (register Transfer Level) 级 门级(Gate Level) 开关级(Switch Level) 电路级(Circuit Level) 4位加法器的结构描述,第二章ASIC设计流程和方法,4位加法器的结构描述 module add4(s,
11、c4,ci,a,b);input3:0 a,b;input ci;output3:0 s;output c4;wire2:0 co;add a0 (co0,s0,a0,b0,ci);add a1 (co1,s1,a1,b1,c0);add a1 (co2,s2,a2,b2,c2);add a1 (co4,s3,a3,b3,co2); end module,module add(co,s,a,b,c);input a,b,c;output s,co;sum s1(s,a,b,c);carry c1(co,a,b,c); end module module carry(co,a,b,c);inpu
12、t a,b,c;output co;wire x,y,z;and g1(x,a,b);and g2(y,a,c);and g3(z,b,c)or3 g4(co,x,y,z) end module,第二章ASIC设计流程和方法,开关级描述(1),module carry (co, a, b, c);input a, b, c;output co;wire il, i2, i3, i4, i5, i6;nmos nl (i3, i4, a);nmos n2 (i4, vss, b);nmos n3 (i3, i5, b);nmos n4 (i5, vss, c);nmos n5 (i3, i6,
13、a);nmos n6 (i6, vss, c);nmos n7 (co, vss, i3);pmos pi (il, vdd, a);,pmos p2 (i2, il, b);pmos p3 (i3, i2, c);pmosp4 (il, vdd, b);pmos p5 (i2, il, c);pmos p6 (i3, i2, a);pmos p7 (co, vdd, i3);end module,第二章ASIC设计流程和方法,开关级描述(2),module carry (co, a, b, c); input a, b, c; output co; wire il, i2, i3, i4,
14、en; nmos nl (il, vss, a); nmosn2 (il, vss, b); nmos n3 (en, il, c); nmos n4 (i2, vss, b); nmos ns (en, i2, a); pmospl(i3,vdd,b); . pmos p2 (en, i3, a); pmos p3(cn, i4, c);,pmos p4 (i4, vdd, b); pmos p5 (i4, vdd, a); pmos p6 (co, vdd, en); pmos n6 (co, vss, en); end module,第二章ASIC设计流程和方法,2.2.4 物理描述,m
15、odule add4; input a 3:0, b3:0; input ci; output s 3:0, outpu c4; boundary 0, 0, 100, 400; port port a 0 aluminum width=l origin =0, 25; port b 0 aluminum width=l origin =0, 75; port ci polysilicon width=l,origin =50, 0; port a 0 aluminum width=l add so origin=0,0 add a1 origin=0,100 end module,第二章AS
16、IC设计流程和方法,2.3 设计流程 2.3.1 bottom-Up 自底向上(Bottom-Up)设计是集成电路和PCB板的传统设计方法,该方法盛行于七、八十年 设计从逻辑级开始,采用逻辑单元和少数行为级模块构成层次式模型进行层次设计,从门级开始逐级向上组成RTL级模块,再由若于RTL模块构成电路系统 对于集成度在一万门以内的ASIC设计是行之有效的,无法完成十万门以上的设计 设计效率低、周期长,一次设计成功率低,第二章ASIC设计流程和方法,2.3 设计流程 2.3.2 Top-Down设计 Top-Down流程在EDA工具支持下逐步成为IC主要的设计方法 从确定电路系统的性能指标开始,自
17、系统级、寄存器传输级、逻辑级直到物理级逐级细化并逐级验证其功能和性能,第二章ASIC设计流程和方法,关键技术 首先是需要开发系统级模型及建立模型库,这些行为模型与实 现工艺无关,仅用于系统级和RTL级模拟。 系统级功能验证技术。验证系统功能时不必考虑电路的实现结 构和实现方法,这是对付设计复杂性日益增加的重要技术,目前系统级DSP模拟商品化软件有Comdisco,Cossap等,它们的通讯库、滤波器库等都是系统级模型库成功的例子。 逻辑综合-是行为设计自动转换到逻辑结构设计的重要步骤,第二章ASIC设计流程和方法,Top-Down设计与Bottom-Up设计相比,具有以下优点: 设计从行为到结
18、构再到物理级,每一步部进都进行验证,提高了一次设计的成功率。 提高了设计效率,缩短了ASIC的开发周期,降低了产品的开发成本 设计成功的电路或其中的模块可以放入以后的设计中提高了设计的再使用率(Reuse)。,第二章ASIC设计流程和方法,2.4 设计策略 2.4.1 概述 设计参数 电路性能,包括功能、速度,功耗和应用特性 芯片尺寸 电路的可测性及测试码生成的难易性; 设计周期 成功率(Time to Market) 经济性(Profit) 设计效率(Efficiency),第二章ASIC设计流程和方法,2.4.2 结构设计 层次设计 从高层到低层 从抽象到具体 利于多人同时设计 使设计思想
19、清晰,设计工作简化 规则设计 使一个电路系统变成大量不同的子模块 尽可能地将电路划分成一组相同或相似的模块,尽可能采用规划性结构的设计,达到简化设计的目的。 适用于设计的各个阶段和层次,规则性在电路级的体现;用倒相器和三态缓冲器构成的单元电路,第二章ASIC设计流程和方法,2.4.3 设计协调 模块信号的标准化 信号输入的驱动 输入信号的寄存 输出信号的寄存 模块间的连接关系 串接结构 迭代结构 条件选择,第二章ASIC设计流程和方法,2.4.4模块定时 采用公共时钟(同步时序) 结构清晰 较易验证 可测性好 关键路径,第二章ASIC设计流程和方法,2.5综合方法 2.5.1概述 对芯片高性能
20、,高密度,高可靠性,设计周期的要求 包含三个层次 行为综合 逻辑综合 版图综合,第二章ASIC设计流程和方法,2.5.3逻辑综合和逻辑优化 综合过程是将VHDL描述转换成非优化约布尔等式的描述,也就是门级描述,读转换过程是综合软件自动完成的,其过程不受用户控制。 RTL级描述-一般使用HDL硬件描述语言,从描述语句和结构特征来分析可归纳为以下几种情况: 使用if then-else和case语句来控制流程; 反复迭代 层次 字宽、位向量和位场 串行和并行操作 算术、逻辑运算和比较操作 寄存器的规定和分配。,ENTITY counter ISPORT (clk: IN STD_LOGIC;rs:
21、 IN STDJLOGIC;count_out: OUT STD_LOGIC_VECTOR(0 TO 2)END counter;ARCHITECTURE behav OF counter ISsignal next_count: STD_LOGIC_VECTOR( 2 DOWNTO 0)BEGINIF rs= 0 THENcount_out next_count next_count next_count next_count next_count next_count = “000“;END CASE;,count_out = next_count AFTER 10ns;END IF;EN
22、D PROCESS; END behav;,六位约翰逊计数器VHDL描述,第二章ASIC设计流程和方法,约束条件(Constrain)-芯片面积(Area),延时(Delay),功耗(Power Consumption)和可测性(Testbility)等 属性描述-规定电路的负载数或驱动能力(Load),输入信号定时(Timing), 实际上也是Constrain. 综合库(Synthesis Library)-包含可综合单元的全部信息-逻辑功能(Function),定时关系(Timing),输入的负载数(Capacitance), 输出扇出数(Load),单元的面积(Area),LIBRAR
23、Y ( ABC ) CELL ( and2 ) area: 5pin (al, a2)direction: input;capacitance: 1; pin (ol)direction: “ al*a2“;timing ( )intrinsic_rise: 0.37;,intrinsic_fall: 0.56;rise_resistance: 0.1234;fall_resistance: 0.4567;ralated_pin: “ al, a2“;,两输入端与非门的综合库描述,第二章ASIC设计流程和方法,逻辑优化-在给定综合库的情况下,对于逻辑描述所形成的门电路网络进行优化,优化的目标是
24、根据电路速度和面积等约束条件进行协调,简化和改善电路的逻辑设计优化过程分两个阶段进行,它们是: 与工艺无关的逻辑优化阶段:运用代数和布尔代数技术对电路进行优化(运用两极极小化过程) 结合综合库,与目标工艺对照阶段:根据制造工艺的要求,将已筒化的逻辑描述转换成综合库耍求的表达形式,也就是用相应的单元符号,包括标准单元或FPGA元件符号以及其它物理实现的逻辑符号替代已简化的描述,第二章ASIC设计流程和方法,门级映射(Mapping)及门级网表-利用综合库单元的逻辑功能及定时信息,进行门级映射并产生门级网表。该网表是逻辑综合和优化的结果,是电路面积和速废目标的体现.门级映射过程是根据优化的布尔描述
25、,综本库以及用户的约束条件,得到一个以综合库单元为基础的优化网表,该综合库单元是与物理实现的工艺参数紧密结合的,第二章ASIC设计流程和方法,EDA市场上著名的逻辑综合软件有 Synopsys软件和Ambit软件,作为逻辑综合软件应谅具有以下功能: 支持RTL级VHDL或Verilog HDL,这是最低限度的要求 能支持多种目标工艺,例如多种 CMOS工艺、FPGA或其它实现工艺 具有自动扫描插入能力 满足ATPG(测试码自动生成)集成的要求 支持对超大规模ASlC进行自动布局布线的集成要求 除了逻辑综合以外还有测试综合软件,这是运用编译的方法,使逻辑门设计产生自动测试链,以提高电路测试覆盖率
26、的方法,上述第3条功能就是为了测试综合而设置的。,第二章ASIC设计流程和方法,2.5.4版图综合-从电路的逻辑结构到集成电路版图的转换是物理综合的过程,也称为版图综合,实际上就是自动布局布线的过程。按照设计流程,逻辑设计验证完毕接着就可以进行自动的版图设计。 布局算法-布局是放置版图模块的工作,考虑到以后的布线通常是把连接紧密的模块依次放置,目的是使整个版图的面积和电路的工作周期最小,这就是所谓基于Timing的布局。,第二章ASIC设计流程和方法,布局算法-布局是放置版图模块的工作,考虑到以后的布线通常是把连接紧密的模块依次放置,目的是使整个版图的面积和电路的工作周期最小,这就是所谓基于T
27、iming的布局。 MinCut算法和“热退火”算法。 布线算法-布线是根据连接网表对布局后的模块进行连线,布线器的类型分成通道布线、开关箱布线和迷宫(Mage)布线等几种。,第二章ASIC设计流程和方法,2.5.5硅编译器-可以将高级的行为描述转换成低一级的结构性的功能快,也可变为供模拟和生成版图用的数据格式,一旦确定了电路体系结构,硅编译器就可以提供制造这个电路所需的版图。 适用于版图结构规则的RAM、ROM、PLA和通用的数据流等,第二章ASIC设计流程和方法,2.6设计验证(Design Verification) 2.6.1概述 功能验证(Function) 时序验证(Timing)
28、 参数验证(Parameter) 2.6.2模拟(仿真) Simulation 模拟软件是用来验证和预测电路的特性。模拟软件有许多种,主要的特性是适用范围、模拟的精度和速度。,第二章ASIC设计流程和方法,电路级模拟(Circuit Simulation)-电路级分析也就是晶体管级分析,可以看作是最详尽和最精确的模仿真技术电路分析软件典型的代表是SPICE和ASTAP,目前作为软件商品的实用版本是AVANTI 公司的HSPICE 程序。 分析电路的直流(DC)、交流(AC)和瞬态特性(Transient),例如:静态工作点分析、直流传输特性分析、交流小信号分析、瞬态分析以及失真、噪声和直流灵敏
29、度分析,其特点为:,第二章ASIC设计流程和方法,根据电路拓扑结构,以节点电压法为基础,构成描述电路特性的代数一微分方程组 采用数值积分方式,将描述电路特性的代数一微分方程转化为非线性代数方程 以牛顿一莱夫森方法为基础,将非线性代数方程转化为线性代数方程 采用稀疏矩阵技术和高斯消元法、LV分解法等方法求解线性代数方程。 仿真时间通常与Nm成比例,这里N是电路申器件的个数,m数值在1-2 之间 Model 的精度直接影响仿真结果(目前较多使用的MOSFET型Model-Level28,Level48,BSIM3等),第二章ASIC设计流程和方法,八十年代后期以松驰法为基础的第三代电 路分析程序,
30、是采用迭代法求解电路方程,其最大的优点是能够有效地利用电路中的休眠特性,大大提高了分析的速度和规模。商业化软件代表 Star-sim 逻辑模拟-逻辑模拟通常是指门级(Gate Level)模拟,目的是要验证 ASIC门级逻辑设计的正确性 功能模拟-验证ASIC逻辑功能的正确性(单位延时或0延时 时序模拟-同时考虑器件延迟和连线延迟的功能模拟 故障模拟-故障模拟是为了检验测试向量的有效性,为以后的芯片测试作准备,第二章ASIC设计流程和方法,逻辑模拟系统,第二章ASIC设计流程和方法,逻辑模拟算法-逻辑模拟算法是根据输入激励向量和逻辑模型求解电路响应的方法,算法还应包括在计算前对电路各元件进行排
31、序以及对各元件输出值计算的方法。模拟算算法应遵循的原则-尽量减少计算的次数,同时又保证一定的计算精度,和出发点。 时间驱动-首先设定了时间步长,每隔一个时间步长就对电路中的每个元件的输出值计算一遍。 事件驱动 -算法能够 跟踪电路的信号活动,仅对输入信号有变化的元件求值,也就是将模拟 时间分割成离散的时间间隔,在给定的时间里仅对可能引起电路状态变 化的那些元件进行模拟,因此它以做到精确定时,且具有较高的性能和 效率。,第二章ASIC设计流程和方法,模拟结果分析 2进制,8进制或16进制的数据文件 c r i o l s n u k t t 0 0 0 L 1 0 0 H 1 0 0 H 波形图
32、 商业化软件:Cadence Verilog-XL Aldec,第二章ASIC设计流程和方法,第二章ASIC设计流程和方法,RTL级模拟 RTL级功能模拟是对于RTL级描述进行的,电路采用行为描述,激励文件也比较简洁,而且这些与实现的逻辑结构无关,因此模拟速度快,效率高。 硬件模拟(Quickturn, Aptix) 采用软件模拟的优点是灵活,方便,且费用少,但不足之处是速度慢、验证不充分(受激励文件限制),书写激励文件颇费功夫。 采用硬件模拟的特点如下: 处理速度比软件方式耍快得多 可将实现的 “硬件模型”放入实际电路系统中去进行实时验证,验证应充分得多 在“硬件模型“实现和模拟控制方面采用
33、软、硬件结合的方式; 可以省却编写激励文件的工作。,第二章ASIC设计流程和方法,2.6.3时序验证(Timing Verification)-时序验证过程是为了检验电路的时序状况,确定和分析影响数字系统时序的关键路径(Critical Path), 找到影响电路速度的因素,进一步改进。 动态时序模拟-动态时序模拟是在逻辑模拟同样的环境下进行的,它与功能模拟的不同之处在于器件模型、模拟算法等方面,动态时序模拟采用精确时延的单元模型 静态时序分析-静态时序分析简称为时序分析,它是一种比较新的时序验证技术。时序 分析的基本思想是首先分析、找出影响电路时序的最坏情况(Worst Case),然后验证
34、此时电路的性能依然能符合定时要求,这样可以确保在其它任何情况下电路都能正常、可靠地工作。,第二章ASIC设计流程和方法,静态时序分析 约束条件 max propagation delay (speed) setup time hold time min clock width,典型的时序电路,第二章ASIC设计流程和方法,动态与静态时序分析比较 动态:速度慢,对于大规模电路很难提供完备的激励,这样会导致验证的不充分,因而不易发现所有的时序错误 静态:不需要任何激励信号,因此速度快、验证充分,它能够找出电路中所有路径的时序错误。但是也正因为没有激励,使静态分析器无从理解电路的功能,以至于会找出实
35、际不存在的“伪路径”,第二章ASIC设计流程和方法,2.6.4 LVS验证( Layout versus Schematic) 2.6.5版图参数提取(Parameter Extraction,反标注(Back Annotation)和后仿真(Post Layout Simulation) 2.6.6 设计规则检查(Design Rule Check)和电学规则检查(Electrical Rule Check) 商业化软件 Cadence Dracula Mentor Graphics Calibra Avanti Hercules,第二章ASIC设计流程和方法,2.7 ASIC 的经济性 A
36、SIC市场价=产品成本/(1-利润比例%) ASIC成本 一次性费用(Nonrecurring Costs)(NRE) $10,000-1,000,000 -设计人员和资源的费用+样品(Prototype)生产中的Mask , testing,packaging的费用 可变成本-ASIC生产制造的费用 C=(W+P)/(N*Yw*Ypa*Yft) ( W+P)-流片费 N-芯片数/每个Wafer Yw-工艺流片成品率 Ypa-封装成品率 Yft-测试成品率 固定成本-设计环境和测试环境的建立,人员培训等基础建设支出,第二章ASIC设计流程和方法,2.7 ASIC 的经济性 不同ASIC类型的成
37、本比较 FPGA MGA CBIC FCC FPGA 用于量少,上市要求快的产品 (NRE 和固定成本低 ,可变成本高(5倍于CBIC) CBIC, FCC 用于产量巨大的产品 ( NRE 和固定成本高, 但可变成本低, 在巨大产量的分摊后,NRE 和固定成本变得不重要),第二章ASIC设计流程和方法,2.7 设计指标-设计指标书的内容如下: ASIC芯片总体说明,包括以下细节: 芯片及标识符; 芯片功能及用途的简要说明; 特性说明; ASIC的封装及管脚说明: 芯片的封装说明及封装图; 管脚名及管脚类型; 管脚功能的简要说明; 管脚信号特性的说明。,第二章ASIC设计流程和方法,ASIC的使
38、用说明: 直流规格: 包括电源电压、管脚电平和管脚接口特性。其中管脚电平,应指明读管脚采用的是TTL或CMOS或ECL类型的电平,同时应指明电压最小、最大值范围。 交流规格: 通常是指ASIC电路的工作频率,包括时钟频率以及输入信号的建立时间和保持时间,输出延迟时间,还包括其它关键信号的定时,例如最小脉冲宽度等。,第二章ASIC设计流程和方法,2.9 ASIC设计的综合因素考虑: ASIC 设计要求 软硬件的折衷 ASIC的实现方式 采用的制造工艺及工艺生产线(Foundry) 测试 封装 开发费用和生产成本 市场,第二章ASIC设计流程和方法,2.10深亚微米设计方法和设计技术 2.10.1
39、深亚微米工艺给集成电路设计带来的新问题 元件模型变化 电路元件延迟减小,互连线延迟增大(5070%,0.35um) 串扰和噪声 时钟线和电源线的影响 功耗和散热问题 铝线的电迁移造成连线断裂 热载流子对ASIC可靠性的影响 逻辑与物理的反复设计问题(0.8um-1次,0.5um-5次,0.35um10次),第二章ASIC设计流程和方法,2.10深亚微米设计方法和设计技术 2.10.2深亚微米设计方法和设计技术的改进 高层次设计规划(Floorplanning) 在行为级验证成功,进入寄存器传输级设计中生成RTL模块的物理抽象,进行预布局,结合物理特征,得到布局、时序及面积以及互连线信息,由此产
40、生的综合优化的约束条件,便综合生成的门级时序得到较好的控制; 经门级功能及时序验证,并生成门级物理抽象,设计规划进 行更精确的布局探索和各模块驱动、延迟的分析计算,并精确地得到关键路径“的延时和电路时序; 在物理级,将门级设计得到的驱动、延迟信息作一规划分析并作为时序驱动布局布线的约束条件。,第二章ASIC设计流程和方法,综合优化技术-进人深亚微米设计阶段,由于互连线延迟超过单元延迟,综合技术必须考虑由此引起的时序问题,改进电路时序特性有以下几点措施: 使用预布局得到的互连线模型替代原来的连线负载模型,原来模型是对指定工艺库单元的扇出和RC树的统计模型,它没有考虑深亚微米连线的种种影响,而互连
41、模型是使用设计规则工具得到的互连特性模型。它能比较精确地反映互连延迟、分布特性及RC特性 使用设计规划工具得到的时序约束和互连线模型去驱动综合优化过程,由此得到满足时序要求的综合结果。在物理级,将门级设计得到的驱动、延迟信息作一规划分析并作为时序驱动布局布线的约束条件,第二章ASIC设计流程和方法,将综合技术与版图设计算法结合起来,产生基于布局的物理综合工具,它将时序约束、逻辑网表和布局拓扑关系一起进行分析、调整。例如,根据电路驱动与负载情况,调整缓冲器和驱动单元的大小私布局;根据时序要求,减少可能存在的长连线及并行走线,减少时钟线的影响,生成较优的时钟树布局。 总之,使布局布线能满足电路的时
42、序要求。 采用行为级综合技术,这种高层次综合的任务是实现从系统级算法描述到底层结果级表示的转换,其核心技术是调度和分配。调度(scheduling)是将操作贼给所指定的控制步,在满足约束条件下使得给定的目标函数(例如控制步数、硬件资源、延迟和功耗)最小。分配是将操作和数据赋给相应的功能单元和寄存器,其目标是便所占用的硬件资源最少。,第二章ASIC设计流程和方法,模拟技术- 模拟是设计的基础,从行为级、RTL级到门级,从逻辑功能摸拟、时序模拟到故障模拟,模拟过程就是验证的过程。对于深亚微米设计,设计的数据巨量增加,电路的时序复杂性等对模拟技术提出更高的要求。总的来说,近年来模拟技术有以下几方面的
43、发展: 传统的线性延迟模型不再适用,需要建立考虑高速、低电压、低功耗以及负载和工艺影响的模型;精碗的模型可以保证电路功能和时序的设计正确,这是ASIC设计过程的核心 门级模拟过程变为先进行单位延迟的功能模拟,得到门级网表,然后使用设计规划工具估算由于互连线、负载、输入信号变化速率等影响产生的延迟信息,再将它们和网表及功能模型一起模拟,得到门级功能和时序结果,第二章ASIC设计流程和方法,采用基于时钟的节拍式 (Cycle-Based)模拟技术,它比传统使用的事件驱动技术耍快几个量级。这种技术通常适用于同步电路的功能验证,但不能作时序验证。Synopsys公司近年推出的CycloneRTL级迷你
44、软件,是利用高层次节拍模拟技术开发的,适用于VLSI的RTL级设计及相应的测试程序进行仿真,由于不需要象常规的将RTL级描述转换为门级描述长时间的编译步骤,使模拟时间大大缩短。 深亚微米电路的时序分析成为设计的中心问题,静态时序分析是解决电路时序问题行之有效的方法,第二章ASIC设计流程和方法,布图技术-布图技术是集成电路芯片物理设计的关键技术,虽然早在八十年代;已经实现了布局布线自动化,但由于深亚微米设计中又出现了时序问题和设计数据量巨大的问题,显然采用以前的布图技术是无法解决: 时序驱动(Timing Driven)和性能驱动(PerformanceDriven)是近几年布图技术发展的方向
45、。对于VLSI芯片设计来说,希望有一种快速的时序驱动,性能驱动的布局布线技术,这样可以在短时间内试探多种布图的可能性,而且可以将快速预布局、预布线得到的结果反馈给综合优化工具,对网表和时序进行优化,这种技术也是物理设计规划工具的基础 进入深亚微米阶段,使用层次化设计和购买知识产权(IP)模块的可能性增多,因此布局布线工具应能灵活地处理模块,能够把IP模块、 第三方厂商提供的模块和设计人员自已开放的模块有机地组合起来,第二章ASIC设计流程和方法,深亚微米的布线设计是一重要课题,金属线的层数已从二、三层上 升到六层左右。因此首先要支持多层布线,可以进行通道式或基于区域的布线,也可以是二者混合型的
46、。通道式布线是一传统方法,它要求单元排列成行,行与行之间留出互连线通道,通道宽度可以调节,以保证100%约有通率。另一种区域布线是假设单元布局固定,在确定的区域内完成布线。前一种方法无法预测芯片大小,后一种方法比较死板苛求两者的优化组合是所谓混合型布线方法。布线还要考虑采用宽线条克服 电迁移问题,避免高频串扰,以及对平行线分布电容计算,对电源线、时钟线也应合理分布,以保证时序要求 总之提高布图质量和布通率,满足时序要求是布图的目标。,第二章ASIC设计流程和方法,内嵌式系统和软硬件协同开发技术-内嵌式式系统是硬件与软件协同设计实现特定要求的系统,在内嵌式系统中,通常包括有微处理器模块、专用电路
47、模块以及存放应用软件代码的ROM、RAM等。在设计过程中需要硬件与软件紧密配合,共同完成一定的电路功能,所以也称为硬软件协同设计 设计重用方法(Design Reuse)-片上系统的设计是极其复杂的,采用设计重用方法是行之有效的。设计重用方法是将 ASIC设计中核心部分的设计可以不用修改或只作少量修改就可用在其它的设计之中。也就是说,对于一些有价值的模块或IP(Intellectual Property),设计一次,可以便用多次。 设计重用在概念上是简单的,但是实现起来也有一定的难度。首先 设计重用方法需要一定的设计环境和设计工具,常规的Top-Down设计方法应作适当扩展。首先要建立设计重用
48、模块的系统级模型及相应的模 块库,也就是用VHDL或Verilog语言编写行为级模型,进行行为级验证然后是综合优化,直到物理设计和工艺制造,经测试和试用证实设计正确无误后,,第二章ASIC设计流程和方法,才能把该模块的行为级模型、RTL级模型等存人重用模块库。因此设计工具应具有对重用模块的建立,修改,调用和管理的功能 也应具有对重用模块和其它方式生成的模块协同设计和界面格式转换的能力。 设计重用的应用一般有两种情况。一种情况是重用模块包含了行为级模块和RTL模块,也就是事先已经把模块的行为级描述综合成适合于某一工艺过程的形式,设计时只需要将ASlC行为级模型分配成专用工艺过程的RTL级描述,然
49、后调用所需的RTL级模块,一起进行逻辑综合.第二种情况是针对某一特定工艺过程,将设计重用模块除了硬件块外还有软件块。软件块是执行特定操作的一般程序。例如微处理机中的微程序,它们通常以代码形式放置在ROM中,这种软件硬化的ROM也称为固件,因此软件块一般以ROM形式出现。,第二章ASIC设计流程和方法,第二章ASIC设计流程和方法,设计重用也是深亚微米设计的主要方法,设计重用也是对IP的再使用,通常可以把设计成功的子模块建成一个核心模块库,以便在以后的ASIC RTL级设计中调用。常用的核心模块可以有MPU、DSP、A/D、D/A、RAM、ROM、输入/输出接口以及加法器、乘法器等。设计重用方法对于超大规模或更大规模的集成电路设计尤其适用。 2.11集成电路 CAD技术发展概况 计算机辅助设计(CAD) 计算机辅助测试(CAT) 计算机辅助工程(CAE) 计算机辅助制造(CAM) 电子设计自动化-EDA(Electronics Design Automation),