0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

MachXO迷你开发板加快了FPGA设计的开发速度

电子设计 来源:网络整理 作者:佚名 2019-11-25 07:54 次阅读

许多中等规模的可编程逻辑器件(PLD)设计,特别是控制方面的应用,通过片上总线互联一些接口微处理器,这些微处理器可以是片上芯片或外部的。虽然每个接口往往是相对简单的,构建所有片上的互连和对它们进行调试的任务可能会非常耗时和令人沮丧。越来越多的设计人员使用预设计的基于处理器系统的开发板来加快开发过程。

这种方法有几个好处。首先,没有必要装配许多IP或构建选择的IP至片上总线的缓冲。此外,片上总线结构不需要选择和构建。第二是没有必要手工连接各种IP至片上总线。即使是本文中讨论的相对较小的设计,使用约1000个查找表(LUT),对于顶层的连接大约需要300行的 Verilog代码。第三,使用这种方法构建硬件的时间大大减少。设计人员可能需要花数天时间来组成基本的硬件部分,并进行所有重要的接口调试。一旦调试接口工作使设计已经处于稳定状态,添加或删除接口就变得非常简单。此外,如果修改设计导致调试接口失败,很容易返回到最近所知的成功设计版本。

典型的开发板

这里以开发环境为实例,允许设计人员用预先设计的系统作为起点,然后修改它来构建自己的样机,在将它移植到最终的系统之前使用莱迪思的MachXO迷你开发板。虽然适用于许多应用场合,这个电路板最适用于控制设计,这种设计往往用小型的非易失可编程逻辑器件来实现。图1说明了典型的用可编程逻辑器件实现控制应用的功能。

MachXO迷你开发板加快了FPGA设计的开发速度

图1用可编程逻辑器件实现的典型控制功能

迷你开发板的中心是MachXO2280非易失、基于闪存的拥有2280个LUT逻辑实现的可编程逻辑器件。图2展示了MachXO迷你开发板,并对主要接口加了注释。这个电路板提供五种主要的功能:

1、通过发光二极管组、扩展端、DIP开关和按钮开关提供GPIO和状态指示器。

2、 SPI闪存和I2C温度传感器用作这些常用串行接口的例子。

3、SRAM内存提供了额外的便笺式存储器。

4、通过USBRS232提供了一个调试接口。

5、通过USB的JTAG用作对器件编程的接口。

对于开发过程而言,通过USB接口至RS232的方式和通过USB至 JTAG的方式是至关重要的。利用这两个小的“B”型的USB连接器,可以通过电缆连接到任何个人电脑的USB接口。一旦加载适当的驱动程序(适用于Windows XP及更高版本),通过USB接口至JTAG的方式允许莱迪思的ispVM软件对所需修改设计的MachXO进行编程。采用相应的驱动程序,通过USB接口至RS232的方式对通过USB至RS232的方式进行仿真。驱动程序包括Linux最新版本,也可用于Windows XP及更高版本。串行端口只作为主机的“COM”端口。此接口为片上设计提供了一个简便的方法,用于发送状态及适当修改、调试信息至主处理器。

MachXO迷你开发板加快了FPGA设计的开发速度

图2 MachXO迷你开发板

预测试的片上系统设计

迷你开发板加速开发的关键是采用预开发的,预加载的片上系统(SOC)设计,可以作为用PLD实现控制功能的起点。下面是一个典型的开发流程和相关的时间,假设相应的软件工具和驱动程序已被加载至PC主机:

1、验证硬件和接口的正常运行如所期望的那样。(通常为5分钟。)此刻设计人员已经了解了硬件情况。

2、确认可以使用ispVM编程软件将FPGA配置文件再次载入MachXO。 (通常为5分钟。)

3、使用ispLEVER设计软件重新编译设计,并确认所产生的配置如预期的情况工作。 (通常为10分钟。)此时,设计者有一个已知的良好起点。

4、首先修改设计,重新编译并加载新的配置。(通常是60分钟,但实际的时间取决于所修改的量。)

按照这个开发流程,初始开发需要几个星期的时间可以减少到数小时。SoC设计的概况如图3所示。可以看到设计由六个接口和一个微处理器组成,并通过一个片上总路线联在一起。

MachXO迷你开发板加快了FPGA设计的开发速度

图3 MachXO迷你板预装载了SOC设计

这个设计的中心是片上总线。使用WISHBONE标准:WISHBONE是一个开放源代码的总线标准,为SOC设计提供了一个理想的基本结构。WISHBONE标准的优点有以下几个方面:

· WISHBONE是开放源代码,所以可以用于各种FPGA或ASIC

· 有大量的适用于WISHBONE接口开放源码IP。

· 简单但灵活的定义使设计人员能够对性能的复杂性进行平衡。

由于许多用于控制的可编程逻辑器件的性能要求相对较低,Wishbone总线是与主微处理器作为主器件(master)的共享总线。地址总线有24位,保留的前3位用于产生从器件的选择信号

LatticeM

ico8(参考设计RD1026)和相关的WISHBONE适配器(RD1043)用于构成设计核的处理器。Mico8具有开放源代码的优点。这是非常重要的,因为设计人员通常要为嵌入式处理器开发大量的代码。LatticeMico8开放源代码的性质意味着它可以在各种FPGA或ASIC中实现,保护了嵌入式代码的投资。

Mico8有8位的数据通道,18位宽的指令和16或32个通用寄存器。外部存储器是分页的,前面的8位地址包含在相关操作码中。用R15和R16寄存器控制地址总线的其他16位。程序存储器可以设置成512和4096之间的深度。在这种情况下,使用18位宽可达1024深度。程序存储器存储在两个嵌入式RAM块(EBR.)中,这些可以被初始化为器件启动时所需的内容。请注意,每个MachXO EBR支持9位字节,深度达1024。Mico8大约使用300个LUT。

通过修改汇编清单可以很容易地生成针对Mico8的新代码,汇编清单是作为项目文件的一部分。于是通过修改后的代码可以LatticeMico8工具链和生成的相应HEX文件。ispLEVER工具可以使用这些HEX文件,合适地初始化EBR用于编程的存储。Mico8工具链也是开放源代码,可从莱迪思网站下载源代码以及可执行文件。

其他的EBR存储器连接到Wishbone总线。这个EBR配置成1024深度 8位字节。针对通过RS232接口的Mico8显示的各种菜单,存储空间是用来共享数据。

SPI接口利用了莱迪思的SPI WISHBONE控制器参考设计(RD1044)的修改版本。 SPI接口连接外部2兆位的SPI闪存至Wishbone总线。如果需要的话,SPI WISHBONE控制器可以用来控制多达8个从器件(slave)。尽管在这种情况下使用了8位寄存器,接收和发送寄存器可配置为1到32位长度,。寄存器是双缓冲的,当微处理器服务响应中断请求以清除其他缓冲区时,允许接收或发送数据。这个参考设计大约使用了113个LUT。这个I2C接口使用了Wishbone总线接口的莱迪思的I2C主器件(master)参考设计(RD1046)。这个设计支持7位或10位寻址模式和一个8位接收/发送缓冲器。I2C参考设计大约使用了234个LUT。

UART的设计采用了Lattice WISHBONE UART参考设计(RD1042.)。这个设计用类似常用的独立NS16450 UART功能实现了一个灵活的UART。设计占用大约291个LUT的资源。 SRAM接口相对比较简单,是针对这个项目的代码。这是一个简单的WISHBONE外设的很好的例子。

整合所有的一切

MachXO迷你开发板的目标是为了加快小的、非易失FPGA设计的开发速度。为了实现这一点,所有在本文中讨论的关于系统芯片设计的信息可作为一个软件包从莱迪思网站上下载。而且,除了文件和源文件,针对所讨论的SoC设计,还提供了一个完整的ispLEVER项目,以及TransFR和使用睡眠模式以减少功耗的演示。提供的信息包括项目文件和所有必要的优先选择和约束,以便在第一时间编译设计。

因此,如果要对你系统中的PLD控制设计进行全面的修改,请仔细看看这个开发系统和预测试的设计。它可以为你的下一个设计节省几周的时间。

责任编辑:gt


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 处理器
    +关注

    关注

    68

    文章

    19317

    浏览量

    230110
  • FPGA
    +关注

    关注

    1629

    文章

    21748

    浏览量

    604030
  • PLD
    PLD
    +关注

    关注

    6

    文章

    224

    浏览量

    59424
收藏 人收藏

    评论

    相关推荐

    Altium推出智能FPGA开发板NanoBoard 300

    Altium推出智能FPGA开发板NanoBoard 3000产品系列 Altium 宣布推出 NanoBoard FPGA 开发板产品系列的最新产品。 NanoBoard
    发表于 11-04 17:01 1195次阅读

    fpga开发板电路图

    最全面的fpga开发板电路图,一共有10多份fpga开发板电路图。
    发表于 04-19 12:50 133次下载
    <b class='flag-5'>fpga</b><b class='flag-5'>开发板</b>电路图

    Lattice_MachXO系列FPGA开发板电路原理图

    电子发烧友网站提供《Lattice_MachXO系列FPGA开发板电路原理图.zip》资料免费下载
    发表于 09-15 16:04 0次下载

    fpga开发板用途,fpga开发板价格

    (host),一个是目标平台(target)即开发板。在此描述的开发平台指的是使用计算机,通过传输的界面,例如串口(RS-232)、USB、并口、或者网络(Ethernet)与目标平台连接,fpga
    发表于 10-23 17:18 4344次阅读

    介绍MachXO迷你开发套件的特点与应用

    看看利用MachXO迷你开发工具套件来设计MachXO可编程逻辑器件是多么容易。 MachXO器件是针对低密度应用最通用的、非易失的可编程逻
    的头像 发表于 06-15 13:14 4483次阅读

    采用FPGA的原型开发板进行ASIC验证与开发设计

    在不太遥远的过去,对ASIC设计团队而言,在这类情况下主要的解决方案就是在内部建立他们自己的定制多个FPGA的原型开发板。然而,今天,使用现成的多个FPGA原型开发板——例如,由Syn
    的头像 发表于 05-16 08:07 3099次阅读
    采用<b class='flag-5'>FPGA</b>的原型<b class='flag-5'>开发板</b>进行ASIC验证与<b class='flag-5'>开发</b>设计

    迷你STM32开发板电路原理图免费下载

    本文档的主要内容详细介绍的是迷你STM32开发板电路原理图免费下载。
    发表于 08-19 08:00 28次下载
    <b class='flag-5'>迷你</b>STM32<b class='flag-5'>开发板</b>电路原理图免费下载

    ESP32迷你开发板设计开源分享

    电子发烧友网站提供《ESP32迷你开发板设计开源分享.zip》资料免费下载
    发表于 07-11 11:42 8次下载
    ESP32<b class='flag-5'>迷你</b><b class='flag-5'>开发板</b>设计开源分享

    制作一个基于ATtiny13的迷你开发板

    电子发烧友网站提供《制作一个基于ATtiny13的迷你开发板.zip》资料免费下载
    发表于 08-10 11:57 2次下载
    制作一个基于ATtiny13的<b class='flag-5'>迷你</b><b class='flag-5'>开发板</b>

    上位机和FPGA开发板--串口通信实验

    首先,上位机发送数据给FPGA开发板;然后,FPGA开发板收到数据,再回发给上位机。
    发表于 05-11 18:26 12次下载
    上位机和<b class='flag-5'>FPGA</b><b class='flag-5'>开发板</b>--串口通信实验

    利用FPGA开发板进行ASIC原型开发的技巧

    )要求一个基于多个FPGA的原型开发板。 在不太遥远的过去,对ASIC设计团队而言,在这类情况下主要的解决方案就是在内部建立他们自己的定制多个FPGA的原型开发板。然而,今天,使用现成
    的头像 发表于 06-04 16:50 1219次阅读

    Unionpi Tiger开发板案例

    提供四个UnionpiTiger开发板案例来帮助大家更快了解、掌握我们的开发板
    发表于 06-15 15:46 25次下载

    fpga开发板与linux开发板区别

    FPGA开发板与Linux开发板是两种不同的硬件开发平台,各自具有不同的特点和应用场景。在以下的文章中,我将详细介绍FPGA
    的头像 发表于 02-01 17:09 2295次阅读

    fpga开发板使用教程

    FPGA开发板的使用教程主要包括以下几个关键步骤。
    的头像 发表于 03-14 15:50 1159次阅读

    fpga开发板是什么?fpga开发板有哪些?

    FPGA开发板是一种基于FPGA(现场可编程门阵列)技术的开发平台,它允许工程师通过编程来定义和配置FPGA芯片上的逻辑电路,以实现各种数字
    的头像 发表于 03-14 18:20 2054次阅读