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

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

3天内不再提示

详解硬核与软核处理器的区别及联系

FPGA之家 来源:电子电路开发学习 作者:wcc149 2021-04-15 09:48 次阅读

软核处理器

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 以及混合信号功能。

ZYNQ开发板

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架构进行设计开发是比较好的选择。

ZYNQ内部框图

ZYNQ框图

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

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

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

    关注

    68

    文章

    18298

    浏览量

    222257
  • FPGA
    +关注

    关注

    1603

    文章

    21328

    浏览量

    593275
  • cpu
    cpu
    +关注

    关注

    68

    文章

    10451

    浏览量

    206583

原文标题:FPGA硬核和软核处理器的区别

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

收藏 人收藏

    评论

    相关推荐

    集特国产飞腾D2000/8处理器GM7-2602-21

    处理器
    GITSTAR 集特工控
    发布于 :2024年04月22日 11:24:47

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

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

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

    DSP(Digital Signal Processor,数字信号处理器)和嵌入式微处理器是两种常见的处理器,用于不同的应用领域。 首先,让我们了解一下DSP和嵌入式微处理器的基本概念
    的头像 发表于 04-21 09:35 136次阅读

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

    HLS,设计者很容易将软件瓶颈转换为由硬件处理。 2、全可编程片上系统中的处理器类型 根据不同的需求,全可编程片上系统的处理器可以分为
    发表于 04-10 16:00

    fpga和risc-v处理器区别

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

    飞腾2000 4处理器国产主板介绍# 飞腾主板# 国产主板# 飞腾处理器

    处理器服务
    jf_67464575
    发布于 :2024年02月03日 10:15:41

    英特尔和AMD处理器区别和特点

    英特尔和AMD处理器区别和特点 英特尔(Intel)和AMD是全球最著名的两个处理器制造商。他们都提供高性能、可靠的芯片,为消费者和企业用户提供强大的计算能力。然而,他们之间存在很多区别
    的头像 发表于 01-30 14:28 1208次阅读

    mcu和单片机的区别联系

    地指的是整合了中央处理器(CPU)、内存和I/O接口等功能的芯片,而MCU则更加广义,还包括了嵌入式软件开发环境等支持功能。 下面将详细介绍MCU和单片机的区别联系,以及它们在不同领域的应用。 结构和功能
    的头像 发表于 12-07 15:05 1774次阅读

    一文详解pcb和smt的区别

    一文详解pcb和smt的区别
    的头像 发表于 10-08 09:31 1601次阅读

    傅氏变换和傅里叶变换的区别联系

    傅氏变换和傅里叶变换的区别联系 傅氏变换和傅里叶变换是信号处理中常用的两种变换方法,它们有着不同的作用和特点。傅氏变换主要应用于连续时间信号的频域分析,而傅里叶变换则主要用于离散时间信号的频域分析
    的头像 发表于 09-07 16:35 1015次阅读

    对于不规范的NICE指令格式,主处理器E203是否会将自定义指令派发给NICE

    若不按照官方文档中的NICE指令格式自定义指令,主处理器会如何处理该指令?主处理器正常派发该指令给协处理器,报错或者卡死或者忽略?
    发表于 08-17 06:41

    如何在蜂鸟处理器的基础上扩展第三方指令?

    想咨询一下如何在蜂鸟处理器的基础上扩展第三方指令,使用户自定义指令,并如何构建机器码等内容? 我看了胡老师的RISC-V处理器设计的书里面讲的使用custom1-4来进行扩展,并以EAI为实例进行
    发表于 08-16 07:36

    FPGA和ASIC的区别联系

      FPGA和ASIC作为数字电路的常见实现方式,其联系区别备受关注。本文将从FPGA和ASIC的基本概念入手,深入研究它们的区别联系,以帮助读者更好地理解两者的应用场景和选择方法
    发表于 08-14 16:38 1880次阅读

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

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

    「直播预告」T507-H国产处理器音频接口详解

    5月25日(本周四)晚19:00,飞凌嵌入式资深软件工程师李亚飞将为大家带来本次系列讲座的第3期——【全志T507-H国产处理器音频接口详解】。不仅有硬核干货,还有精美的定制礼品等着你!
    的头像 发表于 05-24 10:42 932次阅读
    「直播预告」T507-H国产<b class='flag-5'>处理器</b>音频接口<b class='flag-5'>详解</b>