ALLEGRO16.3 约束设置

一. 通单端线的线宽设置

    该约束定义为PCS,即physical constraint set,选中physical-->physical constraint set-->all layers,对右边的功能名字点击右键,creat-->physical cset即可创建pcs约束,如下图所示,我的工程名字是newcore。
ALLEGRO16.3 约束设置_第1张图片
    如果需要对每层设置不同的线宽的话,只要把default展开,修改需要单独设置的层的线宽即可。上图中设置最小线宽为4mil,最大为40mil,在走线的时候,默认走的是最小线宽4mil,NECK下的线宽用于NECK MODE下的线宽,一般在bga下面走线的时候有时候两个管脚间距过小,需要使用neck mode,走线时,鼠标右键,选择neck mode即进入neck模式。
    如果需要设置某些线的默认线宽不是4mil的话,比如设置默认电源、地的默认线宽不是4mil,那么可以创建一个PCS,适用于电源和地信号,默认线宽为10mil,如下图
ALLEGRO16.3 约束设置_第2张图片
设置好后,在physical-->net中对GND信号使用PCS_POWER规则,如下图
ALLEGRO16.3 约束设置_第3张图片
 
二. 普通单端线的线距设置
  该约束定义为SCS,即spacing constraint set,选中spacing-->spacing constraint set-->all layers,对右边的功能名字点击右键,creat-->physical cset即可创建pcs约束,如下图所示。
    default是3w间距设置,SCS_5W是5w间距设置,3w或5w都是line to line或者line to shape的,因为line to line和line to shape的平行距离可能较大。而line to hole、line to via、line to pin之类的最小间距仅是非常小的一段,所以这些间距的值可以是很小的,设置5即可。
    如果需要设置某些线对其它线的线间距为5w的话,只要在net-->all layers中对该线应用scs_5w规则即可,如下图,对DDR的时钟线应用了5w规则,注意到这里的DDR_CK0是差分线对,5w规则应用于该差分线对与其他线之间的间距,而不是差分线内两线之间的间距:
ALLEGRO16.3 约束设置_第4张图片
 
三. 差分线线宽、内线距的设置
    这里的内间距指的是差分对内两线的间距,有两个地方可以设置差分线内距,一个是electrical cset,一个而是physical cset中实现,当两个中都有配置的时候,实际规则采用elctrical cset中的设置。
electrial cset:
    在electrical constraint set--routing--differential pair中设置,同时要在electrical constraint set--net--routing--differential pair中的referenced spacing cset中选中,如下图所示:
    图中配置了差分线的线宽为5mil,默认线内距为7mil。需要注意的是min line spacing的设置,若该值空着,差分线内距的DRC规则将按照该差分线的外距来检查,当外距超过7mil的时候,该差分线的走线会有DRC错误。
也就是说若差分线的内距大于外距,min line spacing可以空着,若差分线内距小于外距,Min line spacing需要填写,比如上图填写值为7mil,那么DRC检查差分线内距的时候会按照这个值来检查。
    uncoupled length:一般不需要设置,没有用single trace mode去调节差分线的话,uncoupled length只在引脚附近出现,手动调一下该段uncoupled length即可。
    Min line spacing:内间距最小线距,若实际走线内间距小于这个值,DRC就会出错。
    Primary Gap:默认内间距
    Primary width:默认线宽
    Neck Gap: neck mode模式下默认内间距
    Neck Width:neck mode 模式下默认线宽
physical cset:
    在physical-->physical constraint set-->all layers中,有differential pair的一些设置,如下图所示。
   
四. 差分线外间距的设置
    这里的外间距指的是差分对中任何一线和与其它任何线的线间距,该线间距的设置和普通单端线的线距设置方法一致。可参考第二点的内容
 
五. CLASS规则的应用
    DDR的信号线可以分为时钟线、数据线和地址与控制线这三类。以64bit带宽为例,数据线又按照8bits的宽度分为8组,DDR的硬件设计文档会要求每组数据线的组内间距3w即可,组间间距起码要5w,或者要求组内线和组外线的间距为5w。这里就可以应用class规则了。
    1.net class的创建:
    net class的创建在spacing-->net-->all layers中实现,在右面界面中将需要组成class的线都选中,然后右键creat-->class即可,创建后的class会在net class-class中出现,如下图:
        如图所示,如果没有进一步设置的话,图中的SCS_5W代表组内线与组外所有线的间距为5W,同时组内各线的间距也是5W!!!
    2.net class-class的应用
        如果想设置class DDR_ADDR与class DDR_DBUS0的间距为4w,该两个class与其它信号线的间距不变仍为5W时,步骤如下:
        选中任何一个class-->右键 creat-->class-class,在跳出的框中选中DDR_ADDR和DDR_DBUS0,并确定后,在referenced spacing cset中选择SCS_4W。如下两图所示
ALLEGRO16.3 约束设置_第5张图片 ALLEGRO16.3 约束设置_第6张图片
    3.区分class内和class外间距的应用
        上面的设置完成后,class DDR_ADDR中的任何线与class DDR_DBUS0的任何线的线间距是4w,与其余所有信号线的线间距是5W,同时class DDR_ADDR内部各线的线间距也是5W!!!
如果想修改class DDR_ADDR组内的间距为3W该如何实现呢? 步骤如下:
        选中任何一个class-->右键 creat-->class-class,在跳出的框中选中DDR_ADDR和DDR_ADDR,并在对应的referenced spacing cset中选中SCS_3W,如下两图所示
        如上两图设置后,DDR_ADDR组内各线的线距为8mil,改组与DDR_DBUS0的线距为12mil,与其它任何线的线距为16mil!
六、region规则的应用
    在spacing-->region中创建region,右键create-->region,创建后如下图
在上图中,RGN_MPC8349中的line to line的间距将不再是3w而是2.5w的6mil了。region这个规则比较特殊,创建后还需要将一个具体的region赋值给这个约束的region,操作为:shape-->rectangular,修改options选项如下图
ALLEGRO16.3 约束设置_第7张图片
之后,框中MPC8349芯片下区域即可。
    创建region后,就可以创建region-class规则和region-class-class规则了,region-class规则应用于class的处于region中的部分线段的线宽线距设置,原先应用于class的规则被region-class代替,
region-class-class应用于两个class在region中的部分的class之间间距,原先的net class-class规则被代替。这里不再详述。

你可能感兴趣的:(.net,Class,文档,64bit,pair)