为了申请板子,发帖慢慢说自己学fpga的过程
开始学的时候。学和Verilog HDL,因为有c基础。选的FPGA是cycloneII系列的FPGA(EP2C5/EP2C8),利用这块板子我完成了项目中的几个主要功能:RS232通信,指令译码,配置DDS,AD数据高速缓存等,在实践中学习起来真的比平时快很多,这个过程难点就是综合。代码综合以后是逻辑网表,而不是指令,所以需要注意我们写的代码是否正确描述了需要实现的逻辑电路。除了逻辑功能,还要把描述中的时序给看出来,一开始的时候,可以根据代码尝试着把波形画出来,尽管仿真软件也能做到这个,还是建议自己画以加强对语言的理解,可以用仿真软件来验证你画的波形 。注意区分哪些是可综合的,哪些是不可综合的代码,这个对出学Verilog的人会比较困惑,因为C只要语法正确,可以编译就能运行,而Verilog一些代码只能在仿真环境中用,不能综合成实际的电路。 要多关注描述代码综合后的电路,不能象C语言那样写好了就行,Verilog写好代码只能算做了一半工作,还要做仿真,如果时序不满足还可能调整程序代码。 要多些多练习。多看代码,特别是原厂提供的代码,这些代码应该代表了比较高的FPGA设计水平,从中我们可以学习两个方面的知识:一是相对比较大规模的逻辑设计如何组织模块结构,二是局部应用处理,可以照搬,作为我们开发时的模板。就会习惯的学会他们的开发模式,我有这样的体会,看多了,很多东西思想上已经把它当作是自己的理所当然的东西了,实际一做,手生的很,遇到很多问题,解决这些问题,这个过程就通过了,学习就需要这么个过程。
现在,我FPGA和ARM都接触。ARM更多的出现在消费电子中,FPGA更多用在通信基础设施和军工科研中。个人认为,ARM和FPGA是两个相对复杂的工具,要掌握工具性的东西难度都不是太大。即使自学,只要英语还可以,一般性的掌握也不会有多难。当然,要用好,结合实际项目是很重要的。
我用FPGA多一些,主要说说我对FPGA的一些看法。用FPGA无非实现两个东西:一是接口,二是数据处理。状态机的设计流程掌握了,做接口基本上是体力活。数据(信号)处理,除了用到一些信号处理理论外,还要明白一些信号处理的VLSI实现的基本理论。信号处理的VLSI实现的理论现在已经较成熟了。综合来看FPGA不是什么难得不得了的东西,可是要用溜它也不是短期能做到的事儿。
另外,有不少人总强调FPGA实现的是电路,需要多强的电路功底。其实用过的人都知道,没那么玄乎,无非是多路选择器 plus IP plus 控制器。当然,掌握一些电路知识是没有坏处的,现在的FPGA在IO设计上会用到一点电磁兼容的知识。
我用FPGA多一些,主要说说我对FPGA的一些看法。用FPGA无非实现两个东西:一是接口,二是数据处理。状态机的设计流程掌握了,做接口基本上是体力活。数据(信号)处理,除了用到一些信号处理理论外,还要明白一些信号处理的VLSI实现的基本理论。信号处理的VLSI实现的理论现在已经较成熟了。综合来看FPGA不是什么难得不得了的东西,可是要用溜它也不是短期能做到的事儿。
另外,有不少人总强调FPGA实现的是电路,需要多强的电路功底。其实用过的人都知道,没那么玄乎,无非是多路选择器 plus IP plus 控制器。当然,掌握一些电路知识是没有坏处的,现在的FPGA在IO设计上会用到一点电磁兼容的知识。
9楼
已经很不错了,给你加分,支持原创。
楼主的文笔不错,可以考虑参加本期的“Get Over it”活动嘛,有奖品的哦。
楼主的文笔不错,可以考虑参加本期的“Get Over it”活动嘛,有奖品的哦。
回复
有奖活动 | |
---|---|
【有奖活动——B站互动赢积分】活动开启啦! | |
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |