网站:http://www.cnblogs.com/emouse/archive/2013/07/26/3217244.html

一、获取芯片资料:

要做芯片的选型,首先就是要对有可能要面对的芯片有整体的了解,也就是说要尽可能多的先获取芯片的资料。现在FPGA主要有4个生产厂家,ALTERA,XILINX,LATTICE和ACTEL。获取资料最便捷的途径就是这些生产厂家的官方网站(http://www.altera.com.cn/,http://china.xilinx.com/,http://www.lattice.com/,http://www.actel.com/intl/china/)。一般情况下,官方网站都会按照产品系列或应用场合列出所有的产品,直观的告诉你某个系列产品的应用场合。比如在ALTERA的网站,就会明确标明它的三大类的FPGA产品,高端的Stratix系列,中端的Arria系列和低成本的Cyclone系列。

每个厂家每年都会推出一个产品选型手册,很多公司网站上还提供评估工具,下图是Altera2012版的选型手册:

经常逛一逛这些厂家的官方网站,看一些概述类的文档,当对各FPGA厂家的产品系列有比较广泛的了解以后,选型就不会成为太大的问题了。确定要做的方向之前,如果能够找到类似的产品,可以研究下这些产品所采用的方案,如果找不到,可以通过检索知网等数据库,也可以看看其他人做类似的方向所采用的方案,这也是非常好的一个参考,需要注意的是很多学术研究型的方案并不是经过产品验证的,有些方案还是比较滞后的,总之需要做一个综合的评估。

二、FPGA厂家的选择

如上所述,生产FPGA厂家主要有ALTERA,XILINX,LATTICE和ACTEL。每个厂家的产品都有各自的特色和适用领域。选择厂家是一个相对比较复杂,要综合考虑下面几个因素:

  1. 要满足项目特殊的需求。比如说你要选择4mmx4mm封装的小体积同时又不需要配置芯片的FPGA,那么可能ACTEl就是你唯一的选择。如果你需要一个带ADC的FPGA芯片,那么可能你只能选择XILINX和ACTEL的某些带ADC的FPGA。
  2. 看供货,好的供货渠道对于产品的量产会有比较好的保证,如果没有特殊渠道还是选择那些比较好买并且广泛使用的型号
  3. 看价格,较低的价格会有效的提高产品的竞争力
  4. 就是技术人员对所有符合要求的厂家的产品的熟悉程度。使用最熟悉的产品,可以有效的缩短开发的难度,减少开发时间,提高产品上市时间。
  5. 看该芯片的成熟度,是不是有较好的开发软件平台,是不是有较好的技术支持,是不是有大批量的应用,是否可以比较容易的获取到资源等等。

三、芯片系列的选择

每个FPGA的生产厂家都有多个系列的产品,来满足不同应用场合对性能和价格的不同需求。例如对于Altera公司的FPGA产品,主要分为三个系列,分别是高端的Stratix,中端的Arria和低端的Cyclone。

每一个系列FPGA具体的性能特点也都可以在ALTERA的官方网站上找到相应的文档。在选择的时候,要根据实际的项目需求,来选择合适的系列。比如说,如果需要实现一个比较简单的控制功能,对资源的要求比较低,且成本控制要求比较高,那么就需要从Cyclone系列的FPGA入手,评估这一系列的FPGA是否可以满足要求。但如果要做比较大型的ASIC芯片的validation,对FPGA的逻辑资源,带宽以及运行频率的要求都比较高,那么就要去评估Stratix系列的FPGA。有一个基本的原则是需要注意的,可以用低端的芯片完成的工作,就不要采用高端的芯片,目标是达到性能和成本的最佳平衡点。

每一个系列的FPGA芯片,可能又分为好几代的产品,比如ALTERA的Cyclone系列,到现在已经发展了Cyclone,CycloneII,CycloneIII和CycloneIV四代产品。这种产品的升级换代很大程度上都是由于半导体工艺的升级换代引起的。随着半导体工艺的升级换代,FPGA芯片也在升级换代的过程中,提供了更强大的功能,更低的功耗和更好的性价比。那么在确定一个系列的FPGA后,选择哪一代的产品则又成为一个问题。我个人建议是在价格和供货都没有问题的情况下,选择越新的产品越好。一定不能选择厂家已经或者即将停产的芯片。任何产品都是有生命周期的,目标就是尽量保证在产品的生命周期里,所用到的芯片的生命周期还没有结束。在产品初期规划时做芯片选型,要尽可能选用厂家刚量产或者量产不久的产品,甚至在有确切的供货渠道的情况下,可以选择厂家即将量产的芯片。

四、芯片的选择

在CycloneIII这个系列的FPGA中,又分为两个不同的子系列,普通的CycloneIII和CycloneIII LS。在每个子系列里,根据片内资源的不同又分为更多的型号,比如普通的CycloneIII子系列,就包含了EP3C5,EP3C10,EP3C16,EP3C25,EP3C40,EP3C55,EP3C80和EP3C120等8种型号的芯片。每个型号的芯片又根据通用I/O口数量和封装区分出不同的芯片。比如,EP3C5的芯片又有EP3C5E144,EP3C5M164,EP3C5F256和EP3C5U256这四种不同的芯片。而每一种芯片,又有不同的速度等级,比如说EP3C5E144就有C7,C8,I7和A7四个速度等级。

下面的表格从不同的角度列出了普通CycloneIII系列的FPGA的参数,这些表格都源自于CycloneIII芯片的官方文档:

1,各型号芯片的片内资源表。这个表格中给出了每个型号芯片的片内资源,其中Maximum User I/Os给出了该型号最多拥有的User I/O的数量,但需要注意的是,不同的封装拥有的User I/O的数量并不相同。

2,下面的表格给出了各型号芯片的封装信息,以及该封装下,芯片所具有的可用I/O的数量和差分信号通道的数量。

在选择具体的芯片型号以及封装的时候,要根据下面的几个方面做综合的考量:

1,片上资源,主要依据表1给出的信息。要根据设计的大小选择合适的片上资源。这个是比较难确定的一个参数,自己做的设计到底有多大,需要多少片上资源,很难一下子确定下来。比较推荐的一个方式是先拿之前的设计去综合后映射到某一个芯片上,看看需要占用多少的片内资源,然后评估要做的新的设计跟之前的大小,做换算后得到需要片上资源的数量。另外的一种方式就是先完成新的设计,直接综合出来映射到不同型号的芯片上,然后评估哪一种芯片合适。还有一个需要注意的地方就是,不能选择片上资源刚刚够用的芯片,要留有一定的余量,以便于后期设计错误的修正和升级。

2,封装,主要依据表2和表3给出的信息。选择封装,主要需要在两个方面考量,第一个就是可用的I/O口的数量。第二个就是封装的尺寸。I/O数量是一个必要的条件,先要根据这个条件筛选出可以用的芯片。然后在筛选出来的芯片中,再根据封装类型,尺寸和pitch尺寸选择合适的芯片。在封装尺寸符合要求的情况下,尽量选择有利于PCB设计和生产的封装。比如如果有TQFP封装的芯片,尺寸又符合项目的需求,那么就不要选择BGA封装的。对于BGA封装的芯片,如果有pitch为1.0mm的可以满足要求,就不要选择pitch为0.5mm的。这直接影响到PCB设计难度,制造成本和良率。

3,速度等级,主要依据表4给出的信息。速度等级是一个相对比较独立的参数。要根据实际设计所能综合出来的最高运行频率和需求的运行频率做比较,尽量选用速度等级比较慢的芯片。当所有的速度等级都不能满足需要的时候,更多的要从优化设计的角度来提高设计本身所能达到的最高运行频率。

五、FPGA初学者的选择

对于一个FPGA的初学者,如何选择一个公司的某一个系列的产品作为学习的基础呢?这是一个问题,但并不是最重要的问题。

初学者在学习FPGA的时候,要解决的首要的问题就是对数字电路技术基础知识的掌握,然后就是对硬件描述语言的掌握(veirlog或者VHDL)。至于FPGA芯片本身,只是一个载体。当真正掌握了FPGA设计的本质后,需要使用某一个厂家的某一种FPGA的时候,只需要针对这个厂家的该型号的FPGA做一些了解就可以了,设计的基础还是一样的,以往积累的大部分经验都可以应用得上。

不过在选择的时候,还是要选择主流厂家的流行的型号,这样更容易获取学习资源。

★emouse 思·睿博客文章★ 原创文章转载请注明:http://emouse.cnblogs.com

Lattice系列FPGA入门之FPGA选型相关推荐

  1. FPGA入门(FPGA结构、Verilog编程基础)

    1.首先了解FPGA是什么,Field(现场) Programmable(可编程) Gate(逻辑门) Array(阵列),其中,逻辑门单元是构成一切数字逻辑器件的基本单元,大量的逻辑门单元可以在任何 ...

  2. Lattice系列FPGA入门相关0(Lattice与Altera、Xilinx对比及入门)

    需求说明:Lattice系统FPGA入门 内容       :Lattice与Altera.Xilinx对比 来自       :时间的诗 1.Lattice与Altera.Xilinx对比 latt ...

  3. Lattice系列FPGA入门相关1(Lattice系列FPGA简介)

    需求说明:Lattice系统FPGA入门 内容       :Lattice系列FPGA简介 来自       :时间的诗 1.为什么Lattice在进入FPGA市场的第一年就能取得这么好的成绩? 我 ...

  4. FPGA入门系列17--task

    文章简介 本系列文章主要针对FPGA初学者编写,包括FPGA的模块书写.基础语法.状态机.RAM.UART.SPI.VGA.以及功能验证等.将每一个知识点作为一个章节进行讲解,旨在更快速的提升初学者在 ...

  5. FPGA入门系列12--RAM的使用

    文章简介 本系列文章主要针对FPGA初学者编写,包括FPGA的模块书写.基础语法.状态机.RAM.UART.SPI.VGA.以及功能验证等.将每一个知识点作为一个章节进行讲解,旨在更快速的提升初学者在 ...

  6. FPGA和CPLD芯片选型介绍(三)

    CPLD器件(以Xilinx和Altera为例) 对CPLD器件的介绍和选型仍然以主流厂商Xilinx和Altera的器件为例进行简单介绍.FPGA与CPLD的辨别和分类主要是根据其结构特点和工作原理 ...

  7. FPGA和CPLD芯片选型介绍(二)

    FPGA器件选型(以Xilinx和Altera为例) 器件选型是件很严肃的事情,既要考虑性能又要兼顾成本,还要考虑长期供货的稳定性,因此很考验工程师的知识广度储备.一般而言,FPGA(CPLD)需要分 ...

  8. 我的FPGA入门学习计划

    本文是自己初步学习fpga的一个计划,由于这个月才开始接触的fpga所以可能有认识不足的地方 还请各位大侠指点 (ps本文涉及到的书籍大部分都能在网络上找到pdf档 利用好搜索引擎 和网盘搜索引擎即可 ...

  9. 【FPGA】初探FPGA —— 入门过程的分享

    #悬崖上的花,越芬芳越无常~ 终于又抽出时间搞这个FPGA入门系列了.这个也是我之前在B站做的视频,关于FPGA入门的过程经验的一个总结,去帮助大家帮助了解FPGA的入门. 南信大电子工程师协会慕课计 ...

最新文章

  1. 安利 10 个 Intellij IDEA 实用插件
  2. spark on yarn 完全分布式_Apache Spark探秘:三种分布式部署方式比较
  3. jQuery全选反选实例
  4. 计算机永远无法处理日语所具有的暧昧性,计算机永远无法处理日语所具有的暧昧性。( )...
  5. SQL 与 Hibernate 性能相差悬殊
  6. 十步让你成为一名优秀的 Web 开发人员
  7. [ACNOI2021]OEIS yyds
  8. 破而后立,破除陈旧,认识自我,而后顶天立地!
  9. 利用GitHub搭建个人网站
  10. Batman+joker乱谈
  11. win7桌面计算机图标去掉,win7桌面图标小箭头怎么去掉?
  12. 生物信息学计算机等级,生物信息学考试题.doc
  13. select函数详细用法解析
  14. 一手掌控美食新鲜“灵魂”且融汇到生活的方方面面
  15. JSTL标签库动态生成表格
  16. 结构光三维重建基本原理
  17. 取石子游戏(威佐夫博弈)
  18. 方便的U盘量产工具不刻盘装系统
  19. VMware Workspace ONE UEM安装部署
  20. 微型计算机在工程实践中作用,【电子技术论文】思维教学中数字电子技术的应用(共2702字)...

热门文章

  1. 登峰造极的python requests完成接口文件上传的案例
  2. 钩子函数-建立键盘鼠标动作记录与回放
  3. linux开发stm32和keil的区别,STM32cubeIDE 和 KEIL 的区别
  4. 在python中使用linux命令写一个监控脚本
  5. picoCTF - la cifra de
  6. 团队管理中的第六人模式
  7. Windows网络编程 undefined reference to `__imp_WSAStartup‘ 解决办法
  8. 遥感识别1——遥感影像语义分割参考文献
  9. 使用Response对象实现数据传输
  10. bongo cat mver 全键盘版震撼来袭