原创 Duplicate Net Names Multiple Top Level Documents

2011-6-22 17:56 4725 5 5 分类: MCU/ 嵌入式
 本人的第一感觉是多张原理图的标识符作用域的设置问题,随后在Project-》Project options中的Options选项下设置了一下Net Identifier Scope(网络标识符作用范围),由原来的Automatic改为Global,随后编译了一下,几十个error全部消失,可见,是网络标识符的作用域的问题,这个问题发生在多张原理图设置中。

   本人上一年发表过一篇有关Altium Designer 标识符的作用域问题的文章,这篇文章中详细阐述了Altium Designer中网络标识符的几种方式:Automatic、Flat、Global、hierarchical四种方式,这四种方式的用法为:

(1)设置为Flat方式,不同页之间只有Port(端口)具有全局属性,即在不同的sheet之间进行同名端口的连接。缺点是难于追踪

(2)设置为Global方式,不同页之间Port和netlabel都具有全局属性,缺点也是难于追踪。

(3)设置为Hierarchical方式,这种适合于分等级的原理图设计中,必须有顶层和底层(每一页),顶层和底层之间是只通过SheetEntry(页入口)和各页的Ports建立对应关系,这种方式适合多页分等级的设计,各页之间的关系比较明晰,也容易追踪。

(4)设置为Automatic方式,根据判据自动判断选择上述三种方式中的一种进行设置,具体是这样:当检查到原理图中具有页符号采用Sheet Entry和/或Ports连接子图,则自动选择HIerarchical方式;若没有Sheet Entry则判断有没有Ports,如果有Ports,则采用Flat方式进行设置作用域范围;如果没有Ports,则自动设置为Global方式。也就是说,若采用Automatic方式,当电路图中有SheetEntry时采用Hierarchical方式;当电路图中有Ports(不管不同页之间有没有同名的netlabel)时采用Flat方式;当电路图中仅有Netlabel时才采用Global方式。

   出现编译错误的原因也就在于Automatic方式时软件采用的判据,如果电路中没有SheetEntry,既有natlabel又有Ports,当设置为Automatic时会按照(4)所述的判据自动设置为Flat方式,由(1)可知是微微Flat方式只有Port在不同页之间具有全局属性,所以软件不认为不同页之间的同名netlabel是连接在一起的,进而出现了“Duplicate Net Names Wire XXX”的错误提示,这里边字面意思是网络名重名,个人认为出现这种错误时,是设计Altium Designer的人人为设定的,不然的话设计软件的难度太大,需要检测有没有netlabel和port,一共有四种情况,况且每一种情况具有包含与被包含的关系。

解决办法:

 (1)将作用域设置为Global方式,这是最简单但比较懒惰的方式,是不同页之间的netlabel和Ports都具有全局属性,然后就可以在不同页之间的同名的Ports之间、同名的Netlabels之间建立连接关系。

(2)采用层次原理图设计,顶层的SheetEntry仅仅和子页的Port之间建立连接关系。

(3)将不同页之间同名netlabel修改为port,然后通过port建立连接关系,作用域设置为Flat或者Global或Hierarchical。

 

备注:当将出现上述错误信息的原理图工程作用域设置为Hierarchical时,尽管很多错误都消失了,但是会有一个“Multiple Top Level Documents”的错误,即多个顶层文档。

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
5
关闭 站长推荐上一条 /3 下一条