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

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

3天内不再提示

基于FPGA的SOC设计技术的硬核与软核处理器的区别和联系

FPGA研究院 来源:电子电路开发学习 作者:电子电路开发学习 2022-12-06 10:00 次阅读

软核处理器

SOPC技术,即软核处理器,最早是由Altera公司提出来的,它是基于FPGA的SOC片上系统设计技术。是使用FPGA的逻辑和资源搭建的一个软核CPU系统,由于是使用FPGA的通用逻辑搭建的CPU,因此具有一定的灵活性,用户可以根据自己的需求对CPU进行定制裁剪,增加一些专用功能,例如除法或浮点运算单元,用于提升CPU在某些专用运算方面的性能,或者删除一些在系统里面使用不到的功能,以节约逻辑资源。

另外也可以根据用户的实际需求,为CPU添加各种标准或定制的外设,例如UART,SPI,IIC等标准接口外设,同时,用户也可以自己使用FPGA的逻辑资源,编写各种专用的外设,然后连接到CPU总线上,由CPU进行控制,以实现软硬件的协同工作,在保证系统性能的同时,增加了系统的灵活性。

而且,如果单个的软核CPU无法满足用户需求,可以添加多个CPU软核,搭建多核系统,通过多核CPU协同工作,让系统拥有更加灵活便捷的控制能力。

由于是使用FPGA资源实现的,所以具有很大的灵活性,可以实现根据需要实现多种处理器,如8051,RISC-V,Xilinx的 MicroBlaze ,Altera的Nios-II等等。

硬核处理器

由于软核CPU是使用FPGA的通用逻辑资源搭建的,相较使用经过布局布线优化的硬核处理器来说,软核处理器够运行的最高实时钟主频要低一些,而且也会相应的消耗较多的FPGA逻辑资源以及片上存储器资源,因此SOPC方案仅适用于对于数处理器整体性能要求不高的应用,例如整个系统的初始化配置,人机交互,多个功能模块间的协调控制等功能。

所以,各大FPGA厂家推出了SoC FPGA技术,是在芯片设计之初,就在内部的硬件电路上添加了硬核处理器,是纯硬件实现的,不会消耗FPGA的逻辑资源,硬核处理器和FPGA逻辑在一定程度上是相互独立的,简单的说,就是SoC FPGA就是把一块ARM处理器和一块FPGA芯片封装成了一个芯片。

例如比较有名的Xilinx的ZYNQ/PYNQ系列集成ARM Cortex-A9处理器,同时具有ARM软件的可编程性和FPGA 的硬件可编程性,不仅可实现重要分析与硬件加速,同时还在单个器件上高度集成CPU、DSP、ASSP 以及混合信号功能。

Intel的Cyclone V系列,集成双核Cortex-A9,于2013年发布,在单一芯片上集成了双核的ARM Cortex-A9处理器和FPGA逻辑资源的新型SoC芯片,相较于传统的单一ARM处理器或FPGA芯片,它既拥有了ARM处理器灵活高效的数据运算和事务处理能力,又集成了FPGA的高速并行处理优势。

同时,基于两者独特的片上互联结构,使用时可以将FPGA上的通用逻辑资源经过配置,映射为ARM处理器的一个或多个具有特定功能的外设,通过高达128位宽的AXI高速总线进行通信,完成数据和控制命令的交互。由于片上的ARM处理器是经过布局布线的硬线逻辑,因此其能工作的时钟主频较高,因此单位时间内能够执行的指令也更多。

区别与联系

从架构的角度来说,SOPC和SoC FPGA是统一的,都是由FPGA部分和处理器部分组成。在SoC FPGA 中,嵌入的是纯硬件基础的硬核处理器,简称HPS(Hardware Processor System),而SOPC技术中,嵌入的是使用FPGA逻辑资源实现的软核处理器,两者指令集不一样,处理器性能也不一样。

一般来说,硬核处理器的性能要远远高于软核处理器。另外,硬核处理器除了CPU部分,还集成了各种高性能外设,如MMU、DDR3控制器、Nand FLASH控制器等,可以运行成熟的Linux操作系统和应用程序,提供统一的系统API,降低开发者的软件开发难度。而软核CPU虽然可以通过配置,用逻辑资源来搭建相应的控制器以支持相应功能,但是从性能和开发难度上来说,基于SoC FPGA架构进行设计开发是比较好的选择。

67e61fde-74f5-11ed-8abf-dac502259ad0.png

▲ZYNQ内部框图

另外,虽然SoC FPGA芯片上既包含了有ARM,又包含了有FPGA,但是两者一定程度上是相互独立的,SoC芯片上的ARM处理器核并非是包含于FPGA逻辑单元内部的,FPGA和ARM(HPS)处理器只是封装到同一个芯片中,JTAG接口、电源引脚和外设的接口引脚都是独立的。因此,如果使用SoC FPGA芯片进行设计,即使不使用到片上的ARM处理器,ARM处理器部分占用的芯片资源也无法释放出来,不能用作通用的FPGA资源。

而SOPC则是使用FPGA通用逻辑和存储器资源搭建的CPU,当不使用CPU时,CPU部分占用的资源可以被释放,重新用作通用FPGA资源。

审核编辑:郭婷

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

    关注

    68

    文章

    18298

    浏览量

    222254
  • FPGA
    +关注

    关注

    1603

    文章

    21328

    浏览量

    593275
  • soc
    soc
    +关注

    关注

    38

    文章

    3750

    浏览量

    215724

原文标题:FPGA硬核与软核处理器有什么区别和联系?

文章出处:【微信号:FPGA研究院,微信公众号:FPGA研究院】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    dsp和嵌入式微处理器区别联系 嵌入式微处理器应用领域分析

    、性能特点和软硬件支持等方面存在一些区别联系。 一、嵌入式微处理器和DSP的区别联系 1.定义和设计思路的
    的头像 发表于 04-21 09:50 204次阅读

    简谈Xilinx Zynq-7000嵌入式系统设计与实现

    的PowerPC硬核集成在V5系列的FPGA中,后来将ARM公司的双Cortex-A9硬核集成在ZYNQ 7000系列的SoC芯片中
    发表于 04-10 16:00

    fpga和gpu的区别

    FPGA(现场可编程门阵列)和GPU(图形处理器)在多个方面存在显著的区别
    的头像 发表于 03-27 14:23 285次阅读

    fpga和risc-v处理器区别

    FPGA(现场可编程门阵列)和RISC-V处理器在多个方面存在显著的区别
    的头像 发表于 03-27 14:21 208次阅读

    【基于Lattice MXO2的小脚丫FPGA核心板】工程创建和固件烧录

    的Diamond 支持MICO32/8处理器以及RISC-V 板上集成FPGA编程
    发表于 01-31 21:01

    如何将Arm Cortex-M处理器与Xilinx的FPGASoC结合使用

    电子发烧友网站提供《如何将Arm Cortex-M处理器与Xilinx的FPGASoC结合使用.pdf》资料免费下载
    发表于 09-15 15:04 1次下载
    如何将Arm Cortex-M<b class='flag-5'>处理器</b>与Xilinx的<b class='flag-5'>FPGA</b>和<b class='flag-5'>SoC</b>结合使用

    ARM Cortex-R52+处理器技术参考手册

    兼容的处理元素(PE)。 在Cortex-R52+的背景下,PE和核心在概念上是相同的。 多个受保护的内存系统架构(PMSA)上下文可以在同一上执行,使用虚拟化技术来包含它们。 该处理器
    发表于 08-29 07:33

    Juno R2 ARM开发平台SoC技术概述

    Linux用户空间示例。 ·DS-5工具支持。 处理器集群包含以下完全一致的处理器集群: ·双Cortex®-A72处理器集群。 ·四
    发表于 08-24 07:05

    ARM Cortex-R52处理器技术参考手册

    ARMv8-R标准的处理元件(PE)。 在Cortex-R52的背景下,PE和核心在概念上是相同的。 多个受保护的内存系统架构(PMSA)上下文可以在同一上执行,使用虚拟化技术来包含它们。 该
    发表于 08-18 07:07

    Arm Cortex-R52处理器技术参考手册

    。 该处理器能够包含不同上下文的实时性能,从而防止一个上下文影响更关键的上下文的响应时间和确定性。 处理器可以具有用于双锁定步骤(DCLS)操作的逻辑和比较实例的冗余副本。
    发表于 08-17 06:24

    FPGA和ASIC的区别联系

      FPGA和ASIC作为数字电路的常见实现方式,其联系区别备受关注。本文将从FPGA和ASIC的基本概念入手,深入研究它们的区别
    发表于 08-14 16:38 1880次阅读

    fpga如何共用一块flash?

    fpga如何共用一块flash? 目前fpga开发板上只有一个flash,用nuclei 向
    发表于 08-12 06:05

    FPGA工作原理与简介

    、Miroblaze、Picoblaze等平台,能够开发标准的DSP处理器及其相关应用,达到SOC的开发目的。1.2.3 硬核以及固
    发表于 05-30 20:53

    FPGA硬核处理器有什么区别联系

    FPGA硬核处理器有什么区别联系
    发表于 05-30 20:36

    手机处理器soc还是cpu soc包含哪些模块 中端芯soc和中端soc区别

    CPU核和内存子系统:SoC芯片需要内置处理器和内存子系统。处理器主要负责计算和控制各种运算和任务,内存则用于存储数据和程序代码。
    发表于 05-03 08:23 3831次阅读