mervin_li的个人空间 https://blog.eetop.cn/1582944 [收藏] [复制] [分享] [RSS]

空间首页 动态 记录 日志 相册 主题 分享 留言板 个人资料

日志

数字后端debug通用思路探索

热度 27已有 16342 次阅读| 2024-8-7 21:21 |个人分类:后端项目经验|系统分类:芯片设计

后端工作主观上来看,是一个容易上手,却很难精通的岗位,因此经验对于快速debug就显的尤为重要。为什么这么说呢?众所周知,后端实现过程中的细节非常多,不同制程都有各自需要注意的特点,不同类型的设计,不同规模的设计也都有各自特殊注意的点,而要掌握这么多的知识本身就是一个非常耗费精力和时间的过程。那么,提高debug的效率,就可以让我们的工作进行的更顺利。如果有足够的背景知识以及丰富的经验的话,分析问题的效率高也是顺利成章的事情。但是,项目的需要,和人员资历的限制,不可能让我们万事俱备才开始后端工作。而后端工作容易上手的特点,就给了广大工程师一个台阶,好迈入岗位的大门。那么,在有限的条件下,如何能够提高debug的效率呢?个人结合多年的工作经验,进行了一些通用性思路的探索和总结。

  • 遇到问题先分类。

  • 正面查找原理,确定问题根源

  • 破坏问题出现的环境,曲线解决

  • 控制变量法去测试

  • 及时求助相关领域专家

先说问题分类,根据问题出现的位置,阶段,关键字,来进行一个粗略的划分。然后搜集出现问题相关的信息。具体来说,就是在log中搜索相关的关键字,查找是否有相似的信息,异常的提示等。一般而言,大部分的error都会在附近找到相关信息。如果log中没找到直接相关的信息。那可以从输入的数据着手,寻找相关性。

至于正面查找原理这一点,除了准确的基础原理知识外,也可以参考相关手册来确认原理算法。确定好问题的原理,那么就可以顺理成章的对照,修改。当然,这一点短期不容易实现。

第三点思路,破坏问题出现的环境,间接的解决问题,或者说是避免问题发生。这一点容易实现,对背景知识的要求不高,但是存在一定的概率。举例说明,当绕线之后某一个地方出现了奇怪的drc,或者说较复杂的结构,如果从原理去分析,需要仔细测量这个pattern,然后根据drc 规则去分析如何改正。对于大多数非精通的人来说,正面解决有一定的困难,或者说需要花费的时间比较长。而破坏这个drc生存的环境是一个更加快捷的解决办法。于是,可以尝试改变这个drc周围的net的走向,宽度,位置等等,再用工具ecoRoute,大概率可以解决。

控制变量法测试。这个方法比较简单,就是经过简单的分析之后,怀疑是某一个因素造成的,就可以可保持其他的参数不变,只修改这一个参数,重新去执行出现问题的这个步骤。然后,对比结果,是否解决,再做进一步的分析,迭代。

最后一步,就是前面都没有解决的时候,或者同时,借助专业领域的专家的力量,或者有类似经验的同事的建议,进行分析处理。往往事半功倍。

后面会继续探索,希望能整理除一套系统化的方案,赶在AI出手之前,更高效的debug问题。

15

点赞

刚表态过的朋友 (15 人)

发表评论 评论 (4 个评论)

回复 aaronqi 2024-8-11 21:32
高屋建瓴,总结性很强,赞
回复 John_Zhang 2024-8-20 11:27
知识性的往往很快就能掌握,经验性的需要时间的积累
回复 pan2 2024-8-27 18:23
回复 lsh361 2024-9-26 16:59

facelist

您需要登录后才可以评论 登录 | 注册

  • 关注TA
  • 加好友
  • 联系TA
  • 0

    周排名
  • 0

    月排名
  • 0

    总排名
  • 0

    关注
  • 168

    粉丝
  • 61

    好友
  • 220

    获赞
  • 62

    评论
  • 3333

    访问数
关闭

站长推荐 上一条 /2 下一条


小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-11-21 15:21 , Processed in 0.015215 second(s), 9 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
返回顶部