要想做好验证,保证无漏验、零漏测,以下三个要素是必须要具备的:验证工具的掌握、算法/协议的理解、验证的意识。

1)验证工具的掌握

验证工具包括vmm/uvm等验证方法学、sv/sc等验证语言、vcs等验证仿真工具、perl/python等脚本语言,这些东西是做验证要掌握的基本技能。不论你做什么样的芯片,都需要这些东西来支撑你的验证工作。

这些验证工具可以帮助你解决“我们该怎么验”这个问题,当你很好的掌握这些验证工具后,你可以有很多种方法途径去达成你的验证目标。

说实在话,验证工具的东西很多,要想在短时间内全部掌握也不可能,而且很多工具可能在你的验证过程中不会用到。

对验证工具的感悟:不要贪求全部掌握,你可以先看书学习实践,把这些东西都学习一遍;在学习的过程中你肯定会发现一些好东西。

对于那些暂时不知道怎么应用到实践中的东西,你也不要认为它们是没用的,其实只是你不知道用在哪儿而已,在你以后的验证中也许就会发现它的应用场景。当你需要它的时候,也许你已经忘记怎么用了,这个没关系,你可以再回去查阅资料,很快就能解决。

这样做的好处是,当你碰到可以用到它的时候,你至少能想起曾经看到某个东西可以来实现它。如果你从未学习过,那么你根本就不会想起有这个方法可以解决它,这才是可怕的,我都不知道这个问题是可以被解决的。

2)算法/协议的理解

芯片要实现什么,不外乎是xx算法、某某协议,算法/协议才是芯片的魂。验证其实也就是验证的算法/协议实现是否正确。就跟批改作文一样,只有批改者有一定的文学功底,才能更好的评判作文水平。

因此,验证人员对算法/协议理解越深刻越好,要理解算法的原理以及算法的实现结构,只有这样才能找出其中的corner点。

3)验证的意识

验证的意识究竟是什么,给大家的建议是:

对任何东西都要有质疑的态度

手要伸长,延伸到上下游

对问题要刨根问底