刚毕业不久,师兄说FPGA工程师比较抢手,建议我向这方面发展。但是,我只是学习过51单片机的简单设计,如何能尽快学会FPGA的开发呢?
一个初学者,我该从哪里开始系统学习FPGA设计呢?

我在另外一个论坛看到过相关的问题,其中有一位网友的回答比较全面,特别摘录在下面供参考,希望你尽快从菜鸟级发展成为高手:
一、首先要有好的数字电路基础,这样你写出来的代码才可能综合出最好的效果,(也就是说你你知道你的每一个语句描述出来的是什么电路,自已心里要清楚);
二、其次你要对FPGA内部结构要了解,知道内部都有些什么资源,怎么利用;
三、现就是一些开发环境和综合环境,特别是仿真工具的学习和掌握。
最后自已写几个代码,仿仿、调调看。(硬件描述语言要有基础,包括可综合的和写激励代码的都要很熟,建议学verilog)
一、首先要有好的数字电路基础,这样你写出来的代码才可能综合出最好的效果,(也就是说你你知道你的每一个语句描述出来的是什么电路,自已心里要清楚);
二、其次你要对FPGA内部结构要了解,知道内部都有些什么资源,怎么利用;
三、现就是一些开发环境和综合环境,特别是仿真工具的学习和掌握。
最后自已写几个代码,仿仿、调调看。(硬件描述语言要有基础,包括可综合的和写激励代码的都要很熟,建议学verilog)


1、看FPGA的datasheet,了解FPGA的原理,结构,资源。既然你要用这个器件,就必须把它理解透彻,如果器件的原理都没有理解透,你怎么可能做出好的稳定的设计?
2、了解综合软件,一定要好好看看帮助文档,看看文档里推荐的代码风格。综合软件是对你写的代码进行综合,所以你的代码风格很重要,只有遵循代码风格写出的代码才能综合出好的效果。就象C语言有C语言的规范一样。XILINX的帮助文档写的特别好,专门有一篇讲代码风格的,里面介绍了如果你想综合成寄存器,代码应该怎么写;如果你想综合成锁存器,代码应该怎么写。还有一篇讲如何针对不同的FPGA系列进行设计优化的。ALTERA的文档也有。

买一块开发板,三四百的就行,一边调试一边学习开发工具,altera和xilinx的开发工具可以参考www.fpga.com.cn的视频,同时学习数字集成电路知识和fpga原理。
在学习过程中不断提高HDL的优化能力。
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
Buck电路工作在CCM模式下电感电流的计算公式是什么?被打赏5分 | |
buck电路工作原理被打赏5分 | |
基于MSPM0L1306的MODBUS-RTU协议通讯实验被打赏100分 | |
我想要一部加热台+多合一调试工具被打赏18分 | |
每周了解几个硬件知识+485硬件知识分享被打赏10分 | |
【换取手持数字示波器】树莓派PICO调试器官方固件本地化部署实践被打赏24分 | |
【换取手持数字示波器】分享一个KEIL无法识别CMSIS-DAP调试器的解决办法被打赏20分 | |
【换取手持数字示波器】分享一个自制的ArduinoNano扩展板底板被打赏23分 | |
【换取手持示波器】树莓派PICOW网页烟花被打赏18分 | |
【换取手持示波器】树莓派PICO逻辑分析仪被打赏16分 |