集成电路技术分享

 找回密码
 我要注册

QQ登录

只需一步,快速开始

搜索
查看: 98344|回复: 210

FPGA学习步骤,我的体会

[复制链接]
20080067 发表于 2010-4-27 13:47:39 | 显示全部楼层 |阅读模式
本帖最后由 fpgaw 于 2011-11-6 05:45 编辑

FPGA学习步骤,我的体会
FPGA在目前应用领域非常,在目前的单板设计里面,几乎都可以看到它的身影。从简单的逻辑组合,到高端的图像、通信协议处理,从单片逻辑到复杂的ASIC原型验证,从小家电到航天器,都可以看到FPGA应用,它的优点在这里无庸赘述。从个人实用角度看,对于学生,掌握FPGA可以找到一份很好的工作,对于有经验的工作人员,使用fgpa可以让设计变得非常有灵活性。掌握了fpga的设计,单板硬件设计就非常容易(不是系统设计),特别是上大学时如同天书的逻辑时序图,看起来就非常亲切。但fpga的入门却有一定难度,因为它不像软件设计,只要有一台计算机,几乎就可以完成所有的设计。fpga的设计与硬件直接相关,需要实实在在的调试仪器,譬如示波器等。这些硬件设备一般比较昂贵,这就造成一定的入门门槛,新人在入门时遇到一点问题或者困难,由于没有调试设备,无法定位问题,最后可能就会放弃。其实这时如果有人稍微指点一下,这个门槛很容易就过去。
          我用FPGA做设计很多年了,远达不到精通的境界,只是熟悉使用,在这里把我对fpga的学习步骤理解写出来,仅是作为一个参考,不对的地方,欢迎大家讨论和指正。
     1、工欲善其事,必先利其器。
     计算机必不可少。目前FPGA应用较多的是Altera和xilinx这两个公司,可以选择安装quartusII或者ISE软件。这是必备的软件环境。
     硬件环境还需要下载器、目标板。虽然有人说没有下载器和目标板也可学习fpga,但那总是纸上谈兵。这就像谈女朋友, 总是嘴上说说,通个电话,连个手都没牵,能说人家是你朋友?虽说搭建硬件环境需要花费,但想想,硬件环境至多几百元钱, 你要真的掌握FPGA的设计,起薪比别人都不止高出这么多。这点花费算什么?
     
     2、熟悉verilog语言或者vhdl语言 ,熟练使用quartusII或者ISE软件。
     VHDL和verilog各有优点,选择一个,建议选择verilog。熟练使用设计软件,知道怎样编译、仿真、下载等过程。
         
     3、设计一个小代码,下载到目标板看看结果
     此时可以设计一个最简答的程序,譬如点灯。如果灯在闪烁了,表示基本入门了。如果此时能够下载到fpga外挂的flash,fpga程序能够从flash启动,表明fpga的最简单设计你已经成功,可以到下一步。
     
     4、设计稍微复杂的代码,下载到目标板看看结果。
     
     可以设计一个UART程序,网上有参考,你要懂RS232协议和fpga内置的逻辑分析仪。网上下载一个串口调试助手,调试一番,如果通信成功了,  恭喜,水平有提高。进入下一步。
     
     5、设计复杂的代码,下载到目标板看看结果。
     譬如sdram的程序,网上也有参考,这个设计难度有点大。可用串口来调试sdram,把串口的数据存储到sdram,然后读回,如果成功,那你就比较熟悉fpga的设计饿了
     
     6、设计高速接口,譬如ddr2或者高速串行接口
      这要对fpga的物理特性非常了解,而且要懂得是时序约束等设计方法,要看大量的原厂文档,这部分成功了,那就对fpga的物理接口掌握很深,你就是设计高手了
      
     7、设计一个复杂的协议
        譬如USB、PCIexpress、图像编解码等,锻炼对系统的整体把握和逻辑划分。完成这些,你就是一个一流的高手、
        
     8、学习再学习
        学习什么,我也不知道,我只知道“学无止境,山外有山”。
        
上述只是一些简单的学习步骤,希望能对大家有所帮助!
524783807 发表于 2010-5-14 13:19:23 | 显示全部楼层
感受颇深!谢谢楼主!
清霜一梦 发表于 2010-5-15 00:03:43 | 显示全部楼层
哇  我这几天总是在找这些东西   能不能来点新的  总是这几段话  
   对不住了   实话啊
tangding 发表于 2010-5-26 16:06:00 | 显示全部楼层
现在的开发板  核心芯片有 EP2C8  和EP2C5  那种 更适合初学者
 楼主| 20080067 发表于 2010-5-28 13:55:32 | 显示全部楼层
回复 4# tangding


    EP2C8,比EP2C5要多一些。
wangluqing 发表于 2010-6-1 17:55:40 | 显示全部楼层
受益了,谢谢了!
wangw899 发表于 2010-6-17 09:34:59 | 显示全部楼层
受益匪浅啊,望LZ多发一些关于这方面的东西啊
houhj88 发表于 2010-6-22 14:59:05 | 显示全部楼层
还可以O(∩_∩)O~
hlknj134 发表于 2010-6-27 11:46:21 | 显示全部楼层
如果是从0开始学,应该如何学起呢
guluyili 发表于 2010-6-27 19:52:06 | 显示全部楼层
楼主推荐几个开发板啊
刚接触也不知道该买哪样的
您需要登录后才可以回帖 登录 | 我要注册

本版积分规则

关闭

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

QQ|小黑屋|手机版|Archiver|fpga论坛|fpga设计论坛 ( 京ICP备20003123号-1 )

GMT+8, 2024-12-24 09:53 , Processed in 0.062194 second(s), 20 queries .

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表