首页/文章/ 详情

一个死磕FPGA 9年的大龄工程师的肺腑之言

2小时前浏览17
我做FPGA开发9年多了,算是一个大龄工程师了。期间接触过一些项目管理和技术支持之类的工作,不知道为什么,脱离研发做这些工作我总觉得不踏实,也许天生就适合死磕技术。


就是不知道继续这么死磕下去会怎么样,曾经也很迷茫,生怕随着年龄的增长,精力比不上年轻人,加班熬夜啥的心有余而力不足,会被逐渐淘汰。迷茫啥的就不细谈了,好在我也想了很多,逐渐想明白了很多,我一定要给做FPGA的兄弟姐妹打打气。


我现在最庆幸的事情就是从进入职场到现在一直是FPGA开发,我感觉,做FPGA开发这行经验是很重要的,入门简单,想提升会越来越难。做FPGA开发不只是会写写verilog和VHDL代码这么简单,我记得刚学习verilog的时候,光是要搞明白哪些语句可以综合,哪些语句不可以综合,就花费了很长时间。


硬件开发语言是要映射成数字逻辑电路的,随着做FPGA的时间长了,写代码的时候脑子里都是0/1的翻转,会逐渐映射出一个个与非门、触发器、存储器,以及他们之间的连线,并且时时刻刻考虑怎样设计才能保证面积最小或者延迟最低。功能做对了还要考虑时序的优化,就算你功能设计的再完美,代码写的再简洁,设计的时候没有考虑时序,一切都是花架子、空摆设。


一个成熟的FPGA不仅是熟悉FPGA就好,最基本的接口协议就能罗列一大堆,够你啃很久了,不懂接口协议FPGA就是孤家寡人,没有数据的交互,什么都干不了。如果要用FPGA做算法,还需要学习更高级的语言做仿真和验证,更重要的是要把算法映射到FPGA的硬件资源或者外设,并基于速度、面积和功能做平衡,做优化。还是挺有挑战呢。


FPGA是介于软硬件之间的一朵奇葩。你用它做接口、做通信,它就偏向硬件;你用它做算法、做控制,它就偏向软件。而且随着人工智能、机器视觉的崛起,FPGA更加偏向软件算法的异构,有和GPU一争高下的潜力。想想都有些小激动呢。


所以,正在做和准备做FPGA的兄弟姐妹们,我们已经在路上了,也许你面前沟沟坎坎很难走,甚至有一堵墙遮光蔽日,请你相信前途是光明的,凭着死磕的精神继续走下去,每天都会有收获。


看了以上这位FPGA高手的肺腑之言,你是不是也摩拳擦掌,跃跃欲试了!不过,要进入FGPA领域,或继续提高自己的设计水平,还的先规划一下适合自己的学习进阶之路,看看过来人的经验总结。



   

FPGA入门之道


   


对于新手学习FPGA设计,要从基础开始做,基础牢,才有成为高手的可能。


对于初学者,有以下几步是必须要走的:


第一步:学习了解FPGA结构,FPGA到底是什么东西,芯片里面有什么,不要开始就拿个开发板照着别人的东西去编程。很多开发板的程序写的很烂,我也做过一段时间的开发板设计,我觉得很大程度上,开发板在误人子弟。


不过原厂提供的正品开发板,代码很优秀的,可以借鉴。只有了解了FPGA内部的结构才能明白为什么写Verilog和写C整体思路是不一样的。


   

第二步:掌握FPGA设计的流程。了解每一步在做什么,为什么要那么做。很多人都是不就是那几步吗,有什么奇怪的?呵呵,我想至少有一半以上的人不知道synthesize和traslate的区别吧。


   

了解了FPGA的结构和设计流程才有可能知道怎么去优化设计,提高速度,减少资源,不要急躁,不要去在为选择什么语言和选择哪个公司的芯片上下功夫。语言只是一个表达的方式,重要的是你的思维,没有一个好的指导思想,语言用得再好,不过是个懂语言的人。


   

第三步:开始学习代码了。我建议要学代码的人都去Altera或Xilinx的网站上下原厂工程师的代码学习。不要一开始就走入误区。


   

第四步:template很重要。能不能高效利用fpga资源,一是了解fpga结构,二是了解欲实现的逻辑功能和基本机构,三是使用正确的模板。FPGA内部器件种类相对较单一,用好模板,你的逻辑才能被高效的综合成FPGA擅长表达的结构:)


   

做fpga主要是要有电路的思想,作为初学者,往往对器件可能不是熟悉,那么应该对于数字电路的知识很熟悉吧,fpga中是由触发器和查找表以及互联线等基本结构组成的,其实在我们在代码里面能够看到的就是与非门以及触发器,不要把verilog和c语言等同起来,根本就是不同的东西,没有什么可比性,在写一句程序的时候应该想到出来的是一个什么样的电路,计数器,选择器 ,三态门等等,理解时序,逻辑是一拍一拍的东西。


在设计初期想的不是很清楚的时候可以画画时序图,这样思路会更加的清晰,还有就是仿真很重要,不要写完程序就去往fpga中去加载,首先要仿真,尤其是对比较大型一点的程序,想像自己是在做asic,是没有二次机会的,所以一定要把仿真做好。


还有很多新手对于语言的学习不知道选vhdl好还是verilog好,个人偏好verilog,当然不是说vhdl不好,反正写出来的都是电路,那当然就不要在语言的语法上面花太多的功夫了,verilog 言简意赅assign always case if else 掌握这些几乎可以写出90%的电路了,上面是我的一些愚见,希望对大家有所帮助。



   

FPGA设计者需

修炼的5项基本功


   


成为一名说得过去的FPGA设计者,需要练好5项基本功:仿真、综合、时序分析、调试、验证。


对于FPGA设计者来说,练好这5项基本功,与用好相应的EDA工具是同一过程,对应关系如下:


1. 仿真:Modelsim, Quartus II(Simulator Tool) riple

2. 综合:Quartus II (Compiler Tool, RTL Viewer, Technology Map Viewer, Chip Planner)

3. 时序:Quartus II (TimeQuest Timing Analyzer, Technology Map Viewer, Chip Planner)

4. 调试:Quartus II (SignalTap II Logic Analyzer, Virtual JTAG, Assignment Editor)

5. 验证:Modelsim, Quartus II(Test Bench Template Writer)


掌握HDL语言虽然不是FPGA设计的全部,但是HDL语言对FPGA设计的影响贯穿于整个FPGA设计流程中,与FPGA设计的5项基本功是相辅相成的。


对于FPGA设计者来说,用好“HDL语言的可综合子集”可以完成FPGA设计50%的工作——设计编码。


练好仿真、综合、时序分析这3项基本功,对于学习“HDL语言的可综合子集”有如下帮助:


1. 通过仿真,可以观察HDL语言在FPGA中的逻辑行为。

2. 通过综合,可以观察HDL语言在FPGA中的物理实现形式。

3. 通过时序分析,可以分析HDL语言在FPGA中的物理实现特性。


对于FPGA设计者来说,用好“HDL语言的验证子集”,可以完成FPGA设计另外50%的工作——调试验证。


1. 搭建验证环境,通过仿真的手段可以检验FPGA设计的正确性。 riple


2. 全面的仿真验证可以减少FPGA硬件调试的工作量。


3. 把硬件调试与仿真验证方法结合起来,用调试解决仿真未验证的问题,用仿真保证已经解决的问题不在调试中再现,可以建立一个回归验证流程,有助于FPGA设计项目的维护。


FPGA设计者的这5项基本功不是孤立的,必须结合使用,才能完成一个完整的FPGA设计流程。反过来说,通过完成一个完整的设计流程,才能最有效地练习这5项基本功。


对这5项基本功有了初步认识,就可以逐个深入学习一些,然后把学到的知识再次用于完整的设计流程。如此反复,就可以逐步提高设计水平。采用这样的循序渐进、螺旋式上升的方法,只要通过培训入了门,就可以自学自练,自我提高。


市面上出售的有关FPGA设计的书籍为了保证结构的完整性,对FPGA设计的每一个方面分开介绍,每一方面虽然深入,但是由于缺少其他相关方面的支持,读者很难付诸实践,只有通读完全书才能对FPGA设计获得一个整体的认识。这样的书籍,作为工程培训指导书不行,可以作为某一个方面进阶的参考书。如何使用现有的书籍进行自学,这是后话。


对于新入职的员工来说,他们往往对FPGA的整体设计流程有了初步认识,5项基本功的某几个方面可能很扎实。但是由于某个或某几个方面能力的欠缺,限制了他们独自完成整个设计流程的能力。


入职培训的目的就是帮助他们掌握整体设计流程,培养自我获取信息的能力,通过几个设计流程来回的训练,形成自我促进、自我发展的良性循环。


在这一过程中,随着对工作涉及的知识的广度和深度的认识逐步清晰,新员工的自信心也会逐步增强,对个人的发展方向也会逐步明确,才能积极主动地参与到工程项目中来。



           

初学者常见的一些问题


           


1. 为什么不推荐学习MicroBlaze等软核?

性价比不高,一般的软核性能大概跟Cortex M3或M4差不多,用FPGA那么贵的东西去做一个性能一般的CPU,在工程上是非常不划算的。不如另外加一块M3。

  

加上软核,可能会影响到其它的逻辑的功能。这是在资源并不十分充足的情况下,再加上软核,导致布局布线变得相当困难。软核不开源,出现Bug的时候,不容易调试。工程上很少使用,极有可能派不上用场。

  


2. 为什么不推荐0基础学习ZYNQ或SOC?

入门应该学习尽量简单的东西,要么专心学习ARM,要么专心学习FPGA。这样更容易有成就感,增强信心。

  

ZYNQ和SOC的应用领域并不广,还有很多人没听过这种东西,导致求职的不利。开发工具编译时间长,浪费较多时间。绝大多数工作,都只是负责一方面,也就是说另一方面,很有可能派不上用场。

  


3. 为什么已经存在那么多IP核,仍需写HDL?

问这种问题的,一般是学生,他们没有做过产品,没有遇到过工程上的问题。IP核并非万能,不能满足所有需求。尽量少用闭源IP核,一旦出问题,这种黑匣子很可能让产品难产。


深入理解底一层次,可以更好地使用高一层次。该法则可以适用于所有编程语言。    

声明:


 
声明:文章来源FPGA之家。本号对所有原创、转载文章的陈述与观点均保持中立,推送文章仅供读者学习和交流。文章、图片等版权归原作者享有,如有侵权,联系删除。  


来源:硬件笔记本
电路电子UG芯片通信控制试验人工智能机器视觉
著作权归作者所有,欢迎分享,未经许可,不得转载
首次发布时间:2025-11-26
最近编辑:2小时前
硬件笔记本
本科 一点一滴,厚积薄发。
获赞 157粉丝 47文章 838课程 0
点赞
收藏
作者推荐

公司业务忙,板子画不完,有可靠的外包公司推荐吗?

大家好,我是王工。前段时间,咱们公司比较忙,layout组的人每天加班加点,板子都画不完。后面有人提议,可以考虑外包。可是PCB外包这一块大家好像都没什么经验,后面还是稀里糊涂的给外包出去了,希望大家给推荐一下外包公司以备用。关于PCB外包这一块,我不太了解。比如:1、如何定价?就是怎么收费?2、有哪些注意事项?担心泄露公司机密3、具体的流程是怎样的?还有一点:我觉得也是最重要的一点,那就是一定要可靠。后来我在网上查了一下,网上推荐的外包公司其实比较少,大概有这些公司:1、深圳市一博科技股份有限公司深圳市一博科技股份有限公司成立于2003年3月,专注于高速PCB设计技术服务、研发样机及中小批量的研发及生产服务。致力于打造顶尖的硬件创新平台,加快电子产品的硬件创新进程,提升产品质量。2022年8月3日,证 监会同意深圳市一博科技股份有限公司首次公开发行股票并在创业板上市的注册申请。2、深圳市昂力威科技有限公司深圳市昂力威科技有限公司成立于2015年05月11日,注册地位于深圳市宝安区新安街道兴华一路华创达大厦B703-2,法定代表人为刘优红。经营范围包括一般经营项目是:电子产品、电路板、通讯设备、计算机硬件、电子元器件的设计、研发与销售;多层印刷板、多层柔性印刷板的销售;电子产品的技术开发与技术咨询;货物及技术进出口。3、深圳市励知科技有限公司深圳市励知科技有限公司成立于2017年11月14日,注册地位于深圳市宝安区西乡街道固兴社区骏翔U8智造产业园U2栋217,法定代表人为肖红燕。经营范围包括电子产品的设计及技术开发、销售,电子元器件的购销业务。电子元器件制造;电子元器件与机电组件设备制造;集成电路芯片及产品制造。4、CesgateCesgate是电子工业的pcb制造商和PCB组装服务提供商。希仕捷科技为全球客户提供所有电子制造服务的一站式解决方案。公司在美国,日本,德国,以色列,意大利和台湾等世界上最先进的现代制造和测试设备和软件上投入了大量资金。5、Mankun Technology曼坤科技是一家专业从事双面、多层高精度印制电路板研发、制造和销售的国家高新技术企业。自2003年深圳曼坤成立以来,曼坤科技一直专注于电路板的生产和研发。2018年底,吉安二期工厂投产。目前,曼坤科技拥有年产3500万平方英尺电路板的生产能力,员工1800余人。6、Victory Giant胜宏科技(惠州)股份有限公司于2006年7月落户广东省惠州市惠阳区淡水街道行诚科技园,园区占地面积23.6万平方米,在职员工8000余人。2015年6月在深交所创业板上市,股票代码:300476。7、Founder PCB方正科技是中国领先的PCB制造商,国内排名多年领先,主营业务覆盖产品、销售、服务和高新技术四大环节,拥有六家电路板厂和一家电路板研究院,分别坐落于珠海、重庆两座城市,主要产品为快板、高密度互连板、普通多层板(2-40层)、系统板、大型背板、金手指板等,年产能达一千五百万平方英尺。8、SCC (Shennan Circuit)深南电路股份有限公司(简称“深南电路”),成立于1984年,总部坐落于中国广东省深圳市,主要生产基地位于中国深圳、江苏无锡及南通,业务遍及全球,在北美设有子公司,欧洲设有研发站点。9、DSBJ苏州东山精密制造股份有限公司于2010年4月公司成功登陆深圳证券交易所,股票代码为002384,拥有全资、控股企业达70余家。公司逐步形成了电子电路、光电显示和精密制造三大板块。其中在电子电路领域,公司是全球第二的柔性线路板企业,全球第三的印刷电路板企业。公司主要产品包括印刷电路板、新能源汽车金属结构件、LED背光、LCM模组、触控产品等。2023年,公司跻身中国民营企业500强NO.413,中国制造业民营企业500强NO.267。大家可以看到,以上都是行业大厂,除了一博,其他公司很少听过,不过这些公司感觉也都很强,一般的外包,人家可能都不会搭理你。所以,对于有些简单的外包,公司规格不太大的更合适些。其实除了公司,还有很多优秀的工程师也会经常接一些私活,工程师收费和专业度可能相比一些公司都会更有一些优势。欢迎大家推荐,可以评论区留言或扫下方二维码加微 信私聊。声明: 声明:原创文章,转载请注明出处。本号对所有原创、转载文章的陈述与观点均保持中立,推送文章仅供读者学习和交流。文章、图片等版权归原作者享有,如有侵权,联系删除。 来源:硬件笔记本

未登录
还没有评论
课程
培训
服务
行家
VIP会员 学习计划 福利任务
下载APP
联系我们
帮助与反馈