发信人: 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
5}O1@%v4i$pY0标 题: 工作随想(时序是设计出来的)
$}U-M M(d M'b0发信站: 一网深情 (2004年10月30日14:02:44 星期六), 站内信件
y(C@]K/D0 时序是设计出来的
Xk%j,R2|i0 我的boss有在华为及峻龙工作的背景,自然就给我们讲了一些华为及altera做逻辑EDA中国门户网站.dKU1H)e,Q@
的一些东西,而我们的项目规范,也基本上是按华为的那一套去做。在工作这几个月中
1g2j"J7LR'mQ0,给我感触最深的是华为的那句话:时序是设计出来的,不是仿出来的,更不是湊出来EDA中国门户网站kL*d%x:G6~_B
的。
q/a4r$Te i0 在我们公司,每一个项目都有很严格的评审,只有评审通过了,才能做下一步的工EDA中国门户网站 _|H7wx V2T:|+ES:R
作。以做逻辑为例,并不是一上来就开始写代码,而是要先写总体设计方案和逻辑详细EDA中国门户网站V0C/w3gk`
设计方案,要等这些方案评审通过,认为可行了,才能进行编码,一般来说这部分工作EDA中国门户网站h:wc"A(@t[
所占的时间要远大于编码的时间。
7X:cIi3n8p7J1o_0 总体方案主要是涉及模块划分,一级模块和二级模块的接口信号和时序(我们要求
5{p$\&^b|0把接口信号的时序波形描述出来)以及将来如何测试设计。在这一级方案中,要保证在EDA中国门户网站])MlJ&f(nD l
今后的设计中时序要收敛到一级模块(最后是在二级模块中)。什么意思呢?我们在做
+{8px/| M$C"L0详细设计的时候,对于一些信号的时序肯定会做一些调整的,但是这种时序的调整最多EDA中国门户网站(va1q3}0A#i
只能波及到本一级模块,而不能影响到整个设计。记得以前在学校做设计的时候,由于EDA中国门户网站m$ReQ5Ba
不懂得设计时序,经常因为有一处信号的时序不满足,结果不得不将其它模块信号的时
z+gkno"]N#}}0序也改一下,搞得人很郁闷。EDA中国门户网站 \S-G-y1]#}4n
在逻辑详细设计方案这一级的时候,我们已经将各级模块的接口时序都设计出来了EDA中国门户网站 q-a*\zu@
,各级模块内部是怎么实现的也基本上确定下来了。EDA中国门户网站$K?+yPc,g~%e
由于做到这一点,在编码的时候自然就很快了,最重要的是这样做后可以让设计会
M)t3rZdX)k?0一直处于可控的状态,不会因为某一处的错误引起整个设计从头进行。
7A$eu f K Q)m6EZ0EDA中国门户网站2o-u!?5Jv`4~f9w
版权所有,未经作者允许,禁止用于商业性质的转载;如对此文有疑问或想给作者EDA中国门户网站{LrC(H8N S ?
提建议请给作者发email:wangdian@tom.com EDA中国门户网站 iH!UN8_'Fz - hising(2004-11-05 07:29:18)
- 发信人: tony (梦回香格里拉), 信区: SoC
-[fj,TR;n%K `?0标 题: 工作随想(做逻辑的难点在系统结构设计和仿真验证)EDA中国门户网站%z&YA3zD3Ar0l{8B
发信站: 一网深情 (2004年10月30日14:09:24 星期六), 站内信件EDA中国门户网站;oi^^2}1X%p
做逻辑的难点在于系统结构设计和仿真验证
'Z3_X+? WzX1^I0 刚去公司的时候BOSS就和我讲,做逻辑的难点不在于RTL级代码的设计,而在于系统
'g#Ri,a^0LV g0结构设计和仿真验证方面。目前国内对可综合的设计强调的比较多,而对系统结构设计
+D x Mcb,x1v.L7?_9G0和仿真验证方面似乎还没有什么资料,这或许也从一个侧面反映了国内目前的设计水平EDA中国门户网站:T6Z9tN6zp2t
还比较低下吧。
#sV^k;L`0 以前在学校的时候,总是觉得将RTL级代码做好就行了,仿真验证只是形式而已,所
r6~!SQ(d:H'|E0hD0以对HDL的行为描述方面的语法不屑一顾,对testbench也一直不愿意去学--因为觉得画EDA中国门户网站({8t-vU ^7Y'O
波形图方便;对于系统结构设计更是一点都不懂了。EDA中国门户网站9K(yBOaA*x;]4[
到了公司接触了些东西才发现完全不是这样。EDA中国门户网站t cDF&\J#|0iM0~
其实在国外,花在仿真验证上的时间和人力大概是花在RTL级代码上的两倍,现在仿EDA中国门户网站FZu&{s%C'OD5i
真验证才是百万门级芯片设计的关键路径。仿真验证的难点主要在于怎么建模才能完全
(](x-N9kc$@)a0和准确地去验证设计的正确性(主要是提高代码覆盖),在这过程中,验证速度也是很EDA中国门户网站8yG4]!Jw sg
重要的。EDA中国门户网站*R_"V+e?7`{E bf[
验证说白了也就是怎么产生足够覆盖率的激励源,然后怎么去检测错误。我个人认EDA中国门户网站AT/E1[rO:k sn!@
为,在仿真验证中,最基本就是要做到验证的自动化。这也是为什么我们要写testbencEDA中国门户网站aj-Mo+P{
h的原因。在我现在的一个设计中,每次跑仿真都要一个小时左右(这其实算小设计)。
!U6l2XL?0由于画波形图无法做到验证自动化,如果用通过画波形图来仿真的话,一是画波形会画
h'} ni"i J0死(特别是对于算法复杂的、输入呈统计分布的设计),二是看波形图要看死,三是检EDA中国门户网站`3_ Uv oLw
错率几乎为零。
)Ow.r5o2?+J~X0 那么怎么做到自动化呢?我个人的水平还很有限,只能简单地谈下BFM(bus funct
$d[9N3kJg0ion model,总线功能模型)。EDA中国门户网站{2JW.`? j}l
以做一个MAC的core为例(背板是PCI总线),那么我们需要一个MAC_BFM和PCI_BFMEDA中国门户网站&B^({g-~6y/\?Ea
及PCI_BM(PCI behavior model)。MAC_BFM的主要功能是产生以太网帧(激励源),随
)I9M-~teH%[+n~!}0机的长度和帧头,内容也是随机的,在发送的同时也将其复制一份到PCI_BM中;PCI_BFMEDA中国门户网站XS#c b] N$c
的功能则是仿PCI总线的行为,比如被测收到了一个正确帧后会向PCI总线发送一个EDA中国门户网站 v0i+ZJ5Yyn
请求,PCI_BFM则会去响应它,并将数据收进来;PCI_BM的主要功能是将MAC_BFM发送出
)b-@zn:v0Rl0t0来的东西与PCI_BFM接收到的东西做比较,由于它具有了MAC_BFM的发送信息和PCI_BFM的
#P`F#R:b]0接收信息,只要设计合理,它总是可以自动地、完全地去测试被测是否工作正常,EDA中国门户网站_]4t,@6h!PC
从而实现自动检测。EDA中国门户网站#CJ4x GB_ v l$L
华为在仿真验证方面估计在国内来说是做的比较好的,他们已建立起了比较好的验EDA中国门户网站qB+]1iI_I5s|%e
证平台,大部分与通信有关的BFM都做好了,听我朋友说,现在他们只需要将被测放
5Ldf,GEO+N/T5L5|0在测试平台中,并配置好参数,就可以自动地检测被测功能的正确与否。EDA中国门户网站x M.DUfQ
在功能仿真做完后,由于我们做在是FPGA的设计,在设计时已经基本保证RTL级代码EDA中国门户网站3~%{Z0e4t.y:E;i*C+\
在综合结果和功能仿真结果的一致性,只要综合布局布线后的静态时序报告没有违反时EDA中国门户网站 ZFP.ow
序约束的警告,就可以下到板子上去调试了。事实上,在华为中兴,他们做FPGA的设计
Ja,lb&M!R}2I0时也是不做时序仿真的,因为做时序仿真很花时间,且效果也不见得比看静态时序分析
w D%_ k-`$GG#V0报告好。
o}U9Ka;h,gO0 当然了,如果是ASIC的设计话,它们的仿真验证的工作量要大一些,在涉及到多时EDA中国门户网站A4S4`+|M xT[-@Y J
钟域的设计时,一般还是做后仿的。不过在做后仿之前,也一般会先用形式验证工具和EDA中国门户网站5LB"JaWk vj
通过静态时序分序报告去查看有没有违反设计要求的地方,这样做了之后,后仿的工作EDA中国门户网站-~c)]8ERuZ[[
量可以小很多。EDA中国门户网站;rl ]7Pfpv
在HDL语言方面,国内语言很多人都在争论VHDL和verilog哪个好,其实我个人认为
"Q!l$jn'u_'N0这并没有多大的意义,外面的大公司基本上都是用verilog在做RTL级的代码,所以还是
vU&C5j.w8n0建议大家尽量学verilog。在仿真方面,由于VHDL在行为级建模方面弱于verilog,用VHEDA中国门户网站s.J"k&j |
DL做仿真模型的很少,当然也不是说verilog就好,其实verilog在复杂的行为级建模方EDA中国门户网站#Q,?WKT'}
面的能力也是有限的,比如目前它还不支持数组。在一些复杂的算法设计中,需要高级EDA中国门户网站#T&|%ST po5O7y
语言做抽象才能描述出行为级模型。在国外,仿真建模很多都是用System C和E语言,用
5a[ q%UOqY0verilog的都算是很落后的了,国内华为的验证平台好像是用System C写。EDA中国门户网站 WI:X(F6G ~
在系统结构设计方面,由于我做的设计还不够大,还谈不上什么经验,只是觉得必
H|6s3bg9X-_}V0须要具备一些计算机系统结构的知识才行。划分的首要依据是功能,之后是选择合适的
#N){}RD J h)x0总线结构、存储结构和处理器架构,通过系统结构划分要使各部分功能模块清晰,易于EDA中国门户网站0Y*?@1VZw ?8BL
实现。这一部分我想过段时间有一点体会了再和大家分享,就先不误导大家了。EDA中国门户网站YYj%re.^A.f'i
EDA中国门户网站U*c-Gfs wi
版权所有,未经作者允许,禁止用于商业性质的转载;如对此文有疑问或想给作者
?wBCJ}r$~0提建议请给作者发email:wangdian@tom.com - hising(2004-11-05 07:29:48)
- [这个贴子最后由hising在 2004/11/08 12:29pm 第 1 次编辑]
;|1M7G%v)_0Nl:_0EDA中国门户网站H!I)a j%@U2Z
发信人: tony (梦回香格里拉), 信区: SoC
!P(Z:D&]L_ }.Z0标 题: 工作随想(规范很重要)
^"l u,S _ U:c0发信站: 一网深情 (2004年10月30日14:12:16 星期六), 站内信件EDA中国门户网站d.R)se2tn.ESC
规范很重要EDA中国门户网站7sx8H?:m/J
工作过的朋友肯定知道,公司里是很强调规范的,特别是对于大的设计(无论软件EDA中国门户网站"b])Q!s s
还是硬件),不按照规范走几乎是不可实现的。逻辑设计也是这样:如果不按规范做的
&jH(A]Me.Q0话,过一个月后调试时发现有错,回头再看自己写的代码,估计很多信号功能都忘了,EDA中国门户网站;c4n8w%r&d~)c$X vm
更不要说检错了;如果一个项目做了一半一个人走了,接班的估计得从头开始设计;如EDA中国门户网站|WOd!I lv-S;B%IX
果需要在原来的版本基础上增加新功能,很可能也得从头来过,很难做到设计的可重用
!?'e9g%Dav7[Q.X0性。
gw!T8nbH_Hn0 在逻辑方面,我觉得比较重要的规范有这些:EDA中国门户网站n6k5Z?8`R
1.设计必须文档化。要将设计思路,详细实现等写入文档,然后经过严格评审通过
)S/Y5hxdor;zp0后才能进行下一步的工作。这样做乍看起来很花时间,但是从整个项目过程来看,绝对
:| Ahw{9dy0要比一上来就写代码要节约时间,且这种做法可以使项目处于可控、可实现的状态。
Y(H.{l!h0 2.代码规范。
$}:_f_-f0 a.设计要参数化。比如一开始的设计时钟周期是30ns,复位周期是5个时钟周期,我EDA中国门户网站 Bbo7GOM
们可以这么写:EDA中国门户网站(J!Q e4hS+s
parameter CLK_PERIOD = 30;
Y{2o0wX_v0 parameter RST_MUL_TIME = 5;
X"]Z7C(B3XK0 parameter RST_TIME = RST_MUL_TIME * CLK_PERIOD;EDA中国门户网站2h.E'D7qd9}2CpL
...EDA中国门户网站5F4{%HO$X_9O
rst_n = 1'b0;EDA中国门户网站}3?B rvS$C
# RST_TIME rst_n = 1'b1;EDA中国门户网站Fh u6Z0w
...EDA中国门户网站|:U|:I/YN
# CLK_PERIOD/2 clk <= ~clk;
i)Q7_ y5w Y0 如果在另一个设计中的时钟是40ns,复位周期不变,我们只需对CLK_PERIOD进行重EDA中国门户网站/g P%hY K-Wu
新例化就行了,从而使得代码更加易于重用。EDA中国门户网站zq*]`-^ G't1I
b.信号命名要规范化。
4y S/F+w{]m4`9]0 1) 信号名一律小写,参数用大写。
3FQ1V qWi0 2) 对于低电平有效的信号结尾要用_n标记,如rst_n。
LZH.qXb'_!l0 3) 端口信号排列要统一,一个信号只占一行,最好按输入输出及从哪个模块来到哪EDA中国门户网站l/~'{!c)Ci
个模块去的关系排列,这样在后期仿真验证找错时后 方便很多。如:EDA中国门户网站.gTUU| l {:}
module a(EDA中国门户网站8UEd6Ky
//input
e`,~Ji,h7j0 clk,
%D;r2~V*L |%e0 rst_n, //globle signalEDA中国门户网站h ~'Oqc/j}
wren,
u^"C.OJzt0 rden,EDA中国门户网站pHHZ!H Y3]
avalon_din, //related to avalon bus
l;{?Ii;d6U0 sdi, //related to serial port inputEDA中国门户网站;m%r#o|;f+tV
//outputEDA中国门户网站g HE9x5v Z|YF
data_ready,EDA中国门户网站 Qa B+E'_5s a
avalon_dout, //related to avalon bus
2rb(LlA(|XWc0 ...EDA中国门户网站ZFz+W?1C
);EDA中国门户网站,yaO0B0Fr
4) 一个模块尽量只用一个时钟,这里的一个模块是指一个module或者是一个en
h1Fq/u)BD?`0tity。在多时钟域的设计中涉及到跨时钟域的设计中最好有专门一个模块做时钟域的隔
x5j;@:l+O q0|o3W,e0离。这样做可以让综合器综合出更优的结果。
AHdE"xc0 5) 尽量在底层模块上做逻辑,在高层尽量做例化,顶层模块只能做例化,禁止
x9bv/F-[#u0出现任何胶连逻辑(glue logic),哪怕仅仅是对某个信号取反。理由同上。EDA中国门户网站~Hb{Clq
6) 在FPGA的设计上禁止用纯组合逻辑产生latch,带D触发器的latch的是允许的EDA中国门户网站;N,\%V*C/s3byZi$~
,比如配置寄存器就是这种类型。
nat:}r9@a0 7) 一般来说,进入FPGA的信号必须先同步,以提高系统工作频率(板级)。
2Kq)J*K3pCzN0 8) 所有模块的输出都要寄存器化,以提高工作频率,这对设计做到时序收敛也EDA中国门户网站p&\.}~L;l*j
是极有好处的。
]uJtD*[0 9) 除非是低功耗设计,不然不要用门控时钟--这会增加设计的不稳定性,在要
{)~c.uW2b+q @0用到门控时钟的地方,也要将门控信号用时钟的下降沿 打一拍再输出与时钟相与。
5Y#G*q(~&Y,kF0 clk_gate_en -------- ----EDA中国门户网站:{'V.U$`4T;l
-----------------|D Q |------------------| \ gate_clkEDA中国门户网站.bQ)M U5^7t-Hu/|6d
_out
F @x#D.?"h0g`rb0 | | ---------| )--------
d(k ~0{O!abVB%S0-
C;VJ3k2ol'i0 ------o|> | | | /
.@6Y8D zT3o6s0 clk | -------- | ----EDA中国门户网站'~2L0Xu$HSuo
------------------------------------
n8aQJn0 10)禁止用计数器分频后的信号做其它模块的时钟,而要用改成时钟使能的方式EDA中国门户网站x H?l!ri4k
,否则这种时钟满天飞的方式对设计的可靠性极为不利,也大大增加了静态时序分析的
R ha'}&n