发信人: tony (梦回香格里拉), 信区: SoC
标 题: 工作随想(序)
发信站: 一网深情 (2004年10月30日13:59:41 星期六), 站内信件
序
很早之前就想对这几个月工作经历写的东西,一是作为自己的总结,二是自己也很
想将自己这段时间的一些经历和大家分享一下,希望对初学者而言能使得他们能少走一
些弯路。只是公司里的事情很多,最近经常加班,所以一直拖到现在。
能来到这家公司应该是一种缘份--缘起NIOS。当初三月份altera来我们学校建立SO
PC实验室的时候自己还不知道NIOS是什么东西,只是想在altera的FAE讲完NIOS后多问他
几个时序约束的问题,然后拷一份PPT回去。但是想不到因为那一份NIOS的培训资料,我
认识了edacn上的cawan,他给我讲了很多NIOS的东西,之后是丁哥在SOC版帖了位NIOS大
赛的通知,然后我和队友就去报了名,并去川大参加了NIOS的培训,认识了峻龙的FAE-
---也是我现在的boss。在这里要谢谢cawan、丁哥、和我一起参加NIOS竞赛的队友刘科
以及我的BOSS,是他们让我有了这一段的经历。
在公司里的几个月,做的项目其实不多,但是收获还是有一些,我觉得收获最大的是
设计理念的改变,这也是我这段时间最想总结的,我会在后面逐渐阐述。
版权所有,未经作者允许,禁止用于商业性质的转载;如对此文有疑问或想给作者提
建议请给作者发email:wangdian@tom.com
转载:电子科大tony的工作经验--不错,值得学习!
上一篇 / 下一篇 2007-07-27 14:42:55 / 天气: 晴朗 / 心情: 高兴 / 个人分类:技术文章
相关回复
- hising(2004-11-05 07:28:40)
- 发信人: tony (梦回香格里拉), 信区: SoC
J-VxOm7n0标 题: 工作随想(时序是设计出来的)EDA中国门户网站fAYWqq7t
发信站: 一网深情 (2004年10月30日14:02:44 星期六), 站内信件EDA中国门户网站'_'R)b_zG
时序是设计出来的EDA中国门户网站A cR.U6E&u"[(T
我的boss有在华为及峻龙工作的背景,自然就给我们讲了一些华为及altera做逻辑
ZS \ ^_Tm%p*[O0的一些东西,而我们的项目规范,也基本上是按华为的那一套去做。在工作这几个月中
+BU)[4~i y3Q0,给我感触最深的是华为的那句话:时序是设计出来的,不是仿出来的,更不是湊出来
l%a$t`7M Z6`!yL7z0的。
6Z JK)KpL/wq9tt%{;@:t&L0 在我们公司,每一个项目都有很严格的评审,只有评审通过了,才能做下一步的工EDA中国门户网站.ZZ9a'Azo(L ]
作。以做逻辑为例,并不是一上来就开始写代码,而是要先写总体设计方案和逻辑详细EDA中国门户网站)jlPtc
设计方案,要等这些方案评审通过,认为可行了,才能进行编码,一般来说这部分工作EDA中国门户网站s4F.?_ H;e$YWg
所占的时间要远大于编码的时间。EDA中国门户网站-f&GL4R&X
总体方案主要是涉及模块划分,一级模块和二级模块的接口信号和时序(我们要求
3g.BSj0hj"`I&O7B0把接口信号的时序波形描述出来)以及将来如何测试设计。在这一级方案中,要保证在
fC1U&|9a|G)@J0今后的设计中时序要收敛到一级模块(最后是在二级模块中)。什么意思呢?我们在做
3nA1E Ww/I0详细设计的时候,对于一些信号的时序肯定会做一些调整的,但是这种时序的调整最多
ARy#kuC'fZ;u0只能波及到本一级模块,而不能影响到整个设计。记得以前在学校做设计的时候,由于
)xSU-]I jf0不懂得设计时序,经常因为有一处信号的时序不满足,结果不得不将其它模块信号的时EDA中国门户网站J$X,cKeZb
序也改一下,搞得人很郁闷。EDA中国门户网站H8a#d?[r"U#a
在逻辑详细设计方案这一级的时候,我们已经将各级模块的接口时序都设计出来了
%s"i3thh Al h)oM0,各级模块内部是怎么实现的也基本上确定下来了。
q8R9ZzW!dT!sq0 由于做到这一点,在编码的时候自然就很快了,最重要的是这样做后可以让设计会
XZ2?+f&q"a0一直处于可控的状态,不会因为某一处的错误引起整个设计从头进行。
_ nzG3}8R2@3O0EDA中国门户网站&a1@ l8R t*{J1|1|
版权所有,未经作者允许,禁止用于商业性质的转载;如对此文有疑问或想给作者EDA中国门户网站@_ UYR9}"E#n#y}
提建议请给作者发email:wangdian@tom.com
2l"E#cTe0 - hising(2004-11-05 07:29:18)
- 发信人: tony (梦回香格里拉), 信区: SoC
C0m*~*G4{ gi0标 题: 工作随想(做逻辑的难点在系统结构设计和仿真验证)EDA中国门户网站&G,Y*D3grK~8?
发信站: 一网深情 (2004年10月30日14:09:24 星期六), 站内信件
#B Ml*az8r5ko;{d0 做逻辑的难点在于系统结构设计和仿真验证EDA中国门户网站~;U1U4S!m5H;w
刚去公司的时候BOSS就和我讲,做逻辑的难点不在于RTL级代码的设计,而在于系统
(G j } CdjN0结构设计和仿真验证方面。目前国内对可综合的设计强调的比较多,而对系统结构设计
.ML qE;|0和仿真验证方面似乎还没有什么资料,这或许也从一个侧面反映了国内目前的设计水平EDA中国门户网站RK,o WNn"j-n8s
还比较低下吧。EDA中国门户网站Cyf U&?xQ;l
以前在学校的时候,总是觉得将RTL级代码做好就行了,仿真验证只是形式而已,所
9grNa[7F~)L0以对HDL的行为描述方面的语法不屑一顾,对testbench也一直不愿意去学--因为觉得画EDA中国门户网站 tHOG@~-['v
波形图方便;对于系统结构设计更是一点都不懂了。EDA中国门户网站`&v;Pgm5[O
到了公司接触了些东西才发现完全不是这样。
-g_ R8R{I-oO0 其实在国外,花在仿真验证上的时间和人力大概是花在RTL级代码上的两倍,现在仿EDA中国门户网站-_ n W7pSpRv
真验证才是百万门级芯片设计的关键路径。仿真验证的难点主要在于怎么建模才能完全
RnX ]/}0和准确地去验证设计的正确性(主要是提高代码覆盖),在这过程中,验证速度也是很EDA中国门户网站oh6F(N*zj?
重要的。EDA中国门户网站Mk N6T\-w(c+t ?
验证说白了也就是怎么产生足够覆盖率的激励源,然后怎么去检测错误。我个人认EDA中国门户网站h;\'Tv|9mY
为,在仿真验证中,最基本就是要做到验证的自动化。这也是为什么我们要写testbenc
{ [*G yqFOQ0h的原因。在我现在的一个设计中,每次跑仿真都要一个小时左右(这其实算小设计)。EDA中国门户网站5KO1~.}9oG
由于画波形图无法做到验证自动化,如果用通过画波形图来仿真的话,一是画波形会画
d'SYD"d5]aH o4IH0死(特别是对于算法复杂的、输入呈统计分布的设计),二是看波形图要看死,三是检EDA中国门户网站)}"f)y-P@mn
错率几乎为零。EDA中国门户网站|K pe8]/]
那么怎么做到自动化呢?我个人的水平还很有限,只能简单地谈下BFM(bus functEDA中国门户网站0gy-i+B(amSbt
ion model,总线功能模型)。EDA中国门户网站.tN+?-~1Cq
以做一个MAC的core为例(背板是PCI总线),那么我们需要一个MAC_BFM和PCI_BFMEDA中国门户网站~'i&|%O-g0q&I
及PCI_BM(PCI behavior model)。MAC_BFM的主要功能是产生以太网帧(激励源),随
v8p&~fsx0机的长度和帧头,内容也是随机的,在发送的同时也将其复制一份到PCI_BM中;PCI_BFM
2X@s#Y2rG0的功能则是仿PCI总线的行为,比如被测收到了一个正确帧后会向PCI总线发送一个
o2dD`7At.[0请求,PCI_BFM则会去响应它,并将数据收进来;PCI_BM的主要功能是将MAC_BFM发送出EDA中国门户网站{Wa1y_v `k
来的东西与PCI_BFM接收到的东西做比较,由于它具有了MAC_BFM的发送信息和PCI_BFM的EDA中国门户网站p)Q.Z1]?
接收信息,只要设计合理,它总是可以自动地、完全地去测试被测是否工作正常,EDA中国门户网站YD^#nAf;w5w;dL
从而实现自动检测。EDA中国门户网站i#BbcC#S]5N
华为在仿真验证方面估计在国内来说是做的比较好的,他们已建立起了比较好的验EDA中国门户网站rm(i!ME(XH
证平台,大部分与通信有关的BFM都做好了,听我朋友说,现在他们只需要将被测放
(d2{JX@c4GU2N0在测试平台中,并配置好参数,就可以自动地检测被测功能的正确与否。
-Yc L0i1YTd4K0 在功能仿真做完后,由于我们做在是FPGA的设计,在设计时已经基本保证RTL级代码
.|!z#^Yc0在综合结果和功能仿真结果的一致性,只要综合布局布线后的静态时序报告没有违反时
Q,FteLPA0序约束的警告,就可以下到板子上去调试了。事实上,在华为中兴,他们做FPGA的设计EDA中国门户网站)n+V^d"m:cNW(x vd
时也是不做时序仿真的,因为做时序仿真很花时间,且效果也不见得比看静态时序分析
F.uZR@0报告好。EDA中国门户网站wLi%\(U"V&M:cJO0T
当然了,如果是ASIC的设计话,它们的仿真验证的工作量要大一些,在涉及到多时EDA中国门户网站z,]:s&V~^)pz
钟域的设计时,一般还是做后仿的。不过在做后仿之前,也一般会先用形式验证工具和
;}]WJ\Wn3M T&f%A6a0通过静态时序分序报告去查看有没有违反设计要求的地方,这样做了之后,后仿的工作
t(br,IQ-v{&k-D0量可以小很多。
e7iQ9JX'zJ:q3N0 在HDL语言方面,国内语言很多人都在争论VHDL和verilog哪个好,其实我个人认为EDA中国门户网站0MG(}Tn)ch'dh
这并没有多大的意义,外面的大公司基本上都是用verilog在做RTL级的代码,所以还是EDA中国门户网站hqV)iFd;[e
建议大家尽量学verilog。在仿真方面,由于VHDL在行为级建模方面弱于verilog,用VHEDA中国门户网站+r8E/If/g2KU
DL做仿真模型的很少,当然也不是说verilog就好,其实verilog在复杂的行为级建模方EDA中国门户网站:Gk,Pvr{TsY1o
面的能力也是有限的,比如目前它还不支持数组。在一些复杂的算法设计中,需要高级EDA中国门户网站B4V8`|w0Z ]w,N:l'D
语言做抽象才能描述出行为级模型。在国外,仿真建模很多都是用System C和E语言,用
&@p$nbj"G\|~6u0verilog的都算是很落后的了,国内华为的验证平台好像是用System C写。EDA中国门户网站8@t'E]-~*O
在系统结构设计方面,由于我做的设计还不够大,还谈不上什么经验,只是觉得必
r0N!DF%^%CrJ|W0须要具备一些计算机系统结构的知识才行。划分的首要依据是功能,之后是选择合适的