大家好,我是DE2208的学员小S,很荣幸可以有个在这里和大家分享经验的机会。
我的经历可能比较坎坷,我高考之后首先是进入了大专学习,后面开始专升本到一个二本,随后考研到浙大。
一路走来给我的感觉就是,有时候不要怕头铁,只要有了目标就去努力实现,就像现在咱们在修真院学习芯片相关的知识一样,大家都是奔着一份好工作而去,需要付出一些心力。
虽然学历也给我带来了一些波折,但最终结果还是不错的。接下来我简单从以下几个方面分享一下关于数字设计学习浅见。
学习阶段
首先咱们肯定得跟着课程学习相关的基础知识,不论是数电、EDA工具,还是Linux以及Verilog。数电、工具、Linux都是最基本的,还有Verilog的相关知识,FIFO很重要!
就像咱们老师说的一样,在写代码的时候得奔着对电路的理解上去,得知道我的代码映射到电路上是一种什么状态,它是侧重于面积优化还是时序优化。
当然这也不是一蹴而就的事,但我们得有这么一种意识,可以多去网上看看相关的代码与电路的关系。
关于后面的总线、接口协议,我的理解是总线协议一定要好好钻研,一些接口协议了解设计思路就可以,不用太去扣代码细节,因为不同公司哪怕是同一个协议设计思路细节都是不同的。
最后我觉得低功耗设计思路比较重要,需要深入了解一下。
自我补足阶段
在这个阶段咱们已经学习完了相关课程,现在得了解自己到底想从事哪方面的设计。
低功耗、SoC、AI芯片、接口IP协议?
例如接口IP可能咱们得去网上学习一下现阶段的一些高速接口协议,比如DDR、PCIE、SERDES等,可以看想去的公司从事哪方面设计的,针对了解。
求职阶段
投简历就不说了,面试阶段一定要自信,前几次面试肯定会有不足之处的,一定要规划好这几次练习的机会,也可以让咱们修真院的老师进行模拟面试。
面试的话侧重点几乎全在基础,还有就是你项目的设计思路,可能还会让你介绍一些项目的结构。所以写在简历上的一定是你最了解的部分。
关于面试题,我的感觉是主要关于FIFO(空满,假空假满,水线,格雷码),时序分析(建立、保持时间,怎么补偿建立时间不满足的情况,要了解怎么以写代码的方式去解决),低功耗设计,跨时钟域处理等,最后可能还会问项目相关的一些细节问题。
总的来说一定要有一个清晰的对于代码电路的映射概念,不能只关注于代码,比如写always语句块时,咱们大多数只关注于数据信号的打拍,而忽略复位信号,这导致我们一想到D触发器的输入端口,可能就会忘记会有一个复位输入信号,在纸上画D触发器也不会把这个信号画出来。
最后祝大家学习顺利,能够找到一份满意的工作!