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、学习再学习
学习什么,我也不知道,我只知道“学无止境,山外有山”。

最后,如果有什么意见或者建议欢迎您留言给我,让我们共同学习一起进步,
如果需要 程序完整源代码和 视频教程,请在下方留言或者私信我,看到后会第一时间回复。

谢谢!

FPGA/CPLD学习心得体会-送给入门学习的你(后附郭天祥FPGA视频教程)相关推荐

  1. 河南城建计算机网络试卷,河南城建计算机网络技术学习心得体会.docx

    河南城建计算机网络技术学习心得体会 河南城建计算机网络技术学习心得体会 计算机网络技术学习心得体会 众所周知,21世纪是一个信息经济时代.为适应时代的发展,作为一名即将走出校园参加工作的当代大学生,所 ...

  2. 学习matlab体会,matlab学习心得体会

    MATLAB是一个实用性很强,操作相对容易,比较完善的工具软件,你知道matlab学习心得体会是什么吗?接下来就是学习啦小编为大家整理的关于matlab学习心得体会,供大家阅读! matlab学习心得 ...

  3. linux课程总结范文,大学课程学习心得体会5篇.doc

    时间: TIME \@ "yyyy'年'M'月'd'日'" 2021年4月21日 学海无涯 页码:第 PAGE 1页共 NUMPAGES 1页 大学课程学习心得体会5篇 学习作为一 ...

  4. 学习计算机软件技术感想,信息技术学习心得体会

    篇一:信息技术培训心得体会 信息技术培训心得体会 信息技术培训心得体会 王维君愉快而又充实的培训时光弹指间就过去了,作为一位农村学校的校长,教育战线的一员,能够参加此次信息技术培训,我感到十分幸运.经 ...

  5. 计算机暑期学校心得,暑期学校学习心得体会

    为了更好地全面贯彻党的教育方针,丰富自己的学识,了解国内外最新教育教学动态,不断提高自己的教育教学能力,出色地完成上级教育主管部门和学校下达的各项教育教学任务,许多人参加暑期学校学习.下面出国留学网小 ...

  6. 学计算机的学后感,计算机学习心得体会

    第1篇:计算机学习心得体会 在未学习计算机之前,我从不知道它到底是干什么用的,为什么很多很多的人都要迫不及待的地要去学它,同时也有人陷入计算机的泥潭,不能自拔.自从我触摸到它的时候,即老师教给我们怎样 ...

  7. java听课心得体会,Java初步学习的一点心得体会

    从2015年9月份开始接触到java语言,一开始学习并不上心,而且一直在找自学资源,在没有大牛带的情况下,一直拖到2016年3月份,正式开启了我的java自学之路,现在的我还处在刚入门阶段,谈谈自己学 ...

  8. 学计算机的初衷,计算机学习心得体会5篇

    计算机学习心得体会5篇 从某件事情上得到收获以后,往往会写一篇心得体会,这样我们可以养成良好的总结方法.那么好的心得体会都具备一些什么特点呢?下面是小编精心整理的计算机学习心得体会5篇,仅供参考,希望 ...

  9. MYSQL选修课的心得体会_选修课学习心得体会范文7篇_大学选修课心得体会

    大学公共选修课程是提供给学生自由选修的非专业性课程,目的在于开拓学生视野.完善和优化学生的知识结构,以及促进学生个性发展,选修课学习是丰富大学生的课余生活和扩大大学生的知识面.下面是学习啦带来的选修课 ...

最新文章

  1. R语言ggplot2可视化删除所有分面图(facet_wrap可视化的facet结果)的标签实战(Remove facet_wrap labels)
  2. python_restframework(频率组件)
  3. tensorflow saver_TensorFlow: Model Persistence
  4. 大数据下的质量体系建设
  5. Html如何触发闹铃,事件闹钟设置.html
  6. Spring boot实体类中常用基本注解
  7. python 通过索引迭代列表_Python的索引迭代
  8. [Win32]创建模态窗口
  9. 2019 SWERC
  10. 用javascript实现点击按钮删除一个文本框
  11. 【架构风格 架构模式 设计模式 概念】
  12. 金刚石结构的各向异性
  13. demo:用matlab app designer做一个简易app
  14. 9:参数校验-Java Spring
  15. python字典筛选
  16. # 个人日记-书籍《银河帝国2之基地与帝国》观后感-20210808
  17. 当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心, 因为并不是一个随便的信用卡号码都是合法的,它必须通过Luhn算法来验证通过。
  18. CarSim仿真快速入门(十六)—CarSim传感器仿真之ADAS Sensor Objects (2)
  19. 三维体素图绘制实验与教程
  20. ubuntu命令行启动浏览器_linux命令行下使用linux打开浏览器命令

热门文章

  1. 2021年化工自动化控制仪表试题及解析及化工自动化控制仪表实操考试视频
  2. GET与POST比较(数据大小、数据类型、传送形式)
  3. 消耗卡路里的android程序,Movesum - 用食物来表示,走路消耗的卡路里 - Android 应用 - iPad - 【最美应用】...
  4. 安卓开发环信即时通信,聊天软件-可实现单聊群聊
  5. 书籍-传承至今的智慧载体
  6. 多线程-银行出纳员仿真
  7. 集成Cortana到你的应用中
  8. 台式计算机磁盘视图怎么改,[极速u盘装系统]win7系统分配盘符“因为磁盘管理控制台视图不是...
  9. SCADE Display(OpenGL)软件设计文档生成工具的设计考虑
  10. 按键精灵刷阿里妈妈广告联盟源码 V1.1版