longnv521 发表于 2010-12-10 13:21:33

也来谈谈FPGA的学习!

FPGA在目前应用领域非常,在目前的单板设计里面,几乎都可以看到它的身影。从简单的逻辑组合,到高端的图像、通信协议处理,从单片逻辑到复杂的ASIC原型验证,从小家电到航天器,都可以看到FPGA应用,它的优点在这里无庸赘述。从个人实用角度看,对于学生,掌握FPGA可以找到一份很好的工作,对于有经验的工作人员,使用fgpa可以让设计变得非常有灵活性。掌握了fpga的设计,单板硬件设计就非常容易(不是系统设计),特别是上大学时如同天书的逻辑时序图,看起来就非常亲切。但fpga的入门却有一定难度,因为它不像软件设计,只要有一台计算机,几乎就可以完成所有的设计。fpga的设计与硬件直接相关,需要实实在在的调试仪器,譬如示波器等。            
1、工欲善其事,必先利其器。
   计算机必不可少。目前FPGA应用较多的是Altera和xilinx这两个公司,可以选择安装quartusII或者ISE软件。这是必备的软件开发环境。
   硬件环境还需要下载器、目标板。虽然有人说没有下载器和目标板也可学习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、学习再学习
      学习什么,我也不知道,我只知道“学无止境,山外有山”。
      
上述只是我最近的学习想法,希望能对大家有所帮助!
页: [1]
查看完整版本: 也来谈谈FPGA的学习!