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

    文章

    19155

    浏览量

    229048
  • FPGA
    +关注

    关注

    1625

    文章

    21663

    浏览量

    601670
  • soc
    soc
    +关注

    关注

    38

    文章

    4115

    浏览量

    217897

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

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

收藏 人收藏

    评论

    相关推荐

    MicroBlaze V处理器的功能特性

    本指南提供了有关 AMD Vivado Design Suite 中包含的 32 位和 64 位 MicroBlaze V 处理器的信息。该文档旨在用作为处理器硬件架构的指南,随附
    的头像 发表于 10-16 09:17 380次阅读
    MicroBlaze V<b class='flag-5'>软</b><b class='flag-5'>核</b><b class='flag-5'>处理器</b>的功能特性

    ARM处理器和CISC处理器区别

    ARM处理器和CISC(复杂指令集计算机)处理器在多个方面存在显著的区别。这些区别主要体现在架构原理、性能与功耗、设计目标、应用领域以及市场生态等方面。
    的头像 发表于 09-10 11:10 363次阅读

    浅谈国产异构双RISC-V+FPGA处理器AG32VF407的优势和应用场景

    技术手段提高系统的安全性和可靠性,适用于对安全要求较高的应用场景。 应用场景 边缘计算 : 在物联网、智能城市等边缘计算场景中,异构双RISC-V+FPGA处理器可以
    发表于 08-31 08:32

    中微亿芯发布ARM A9处理器SoC Z7及以7系列FPGA为核心的SIP电路

    近日,中科芯控股公司中微亿芯举办了"融造芯 智创未来"高性能可编程 SoC / SIP 系列新品发布会,隆重发布了ARM A9处理器SoC Z7,及以7系列
    的头像 发表于 05-28 18:22 1116次阅读

    FPGA的IP使用技巧

    够与所使用的FPGA平台和开发工具无缝集成。 阅读和理解IP的文档 : 在使用IP之前,务必仔细阅读和理解其提供的文档,包括用户手
    发表于 05-27 16:13

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

    处理器可以分为硬核处理器硬核处理器
    发表于 05-08 16:23

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

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

    dsp和嵌入式微处理器区别联系

    是一种专门用于数字信号处理(Digital Signal Processing)的处理器。数字信号处理是一种通过对数字信号进行算法运算来处理和分析信号的
    的头像 发表于 04-21 09:35 905次阅读

    Achronix FPGA增加对Bluespec提供的基于Linux的RISC-V处理器的支持,以实现可扩展数据处理

    Bluespec支持加速功能的RISC-V处理器将Achronix的FPGA转化为可编程SoC 近日,高性能FPGA芯片和嵌入式
    的头像 发表于 04-19 18:08 676次阅读

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

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

    fpga和gpu的区别

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

    fpga和risc-v处理器区别

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

    fpga和单片机的区别联系 fpga和cpu区别

    fpga和单片机的区别联系 FPGA(现场可编程逻辑门阵列)和单片机在电子系统设计中都扮演着重要的角色,但它们之间存在明显的区别
    的头像 发表于 03-14 17:33 1045次阅读

    fpga芯片和soc芯片的区别

    FPGA芯片和SoC芯片在多个方面存在显著的区别
    的头像 发表于 03-14 17:28 2793次阅读

    怎么使用DMA在FPGA中的HDL和嵌入式C之间传输数据?

    鉴于机器学习和人工智能等应用的 FPGA 设计中硬件加速的兴起,现在是剥开几层“云雾”并讨论 HDL 之间来回传递数据(主要指FPGA 的可编程逻辑 (PL) 中运行的代码以及 FPGA 中的
    的头像 发表于 11-27 09:12 1416次阅读
    怎么使用DMA在<b class='flag-5'>FPGA</b>中的HDL和嵌入式C之间传输数据?