28

抢答

【参与话题讨论,立得100IC币】MPU与MCU之间是否有明确的界限真的重要吗?你怎么看?曾有一段时间,微处理器(MPU)与微控制器(MCU)是截然不同的两种设备,微控制器完成“控制”相关的任务,根据外界信号刺激产生反应,微处理器主要执行处理功能,对数据处理和计算能力的要求较高。但如今由于内存架构的变化,两者之间的界限正在变得模糊。 图片源自 Shutterstock 事实上,可以通过多种方式区分微处理器和微控制器,只是业界尚未对他们的区分标准达成共识。不过已经有一些人得出结论,目前两者之间的准确区分都已经不再重要了。  “近年来,MCU和MPU之间的区别变得越来越模糊。”西门子业务部门的嵌入式软件技术专家Colin Walls说,“最初,MCU在一个芯片上集成了CPU、内存和外围设备,如今大多数MCU依然如此,但因为MCU具有足够强大的功能来支持更复杂的应用程序,附加外部存储器的MCU也变得常见。” 计算芯片的两个市场 曾经有一段时间,计算芯片分为两个截然不同的市场,大部分芯片设备主要针对主流计算,性能是最主要的考虑因素,这些单片微型计算机被称之为“微处理器”,为个人计算机和更大的系统提供动力。 如今我们可以在各种类型的笔记本电脑、台式机和服务器中看到它们,值得注意的是,它们是通用引擎,旨在运行事先未知的任何数量的程序,主内存是DRAM,非易失性存储是硬盘驱动器或固态硬盘。 在不那么主流的嵌入式计算世界里,需要适度计算能力和专门用途,设计好的程序可能在固件中运行,以便让整个系统(包括程序和所有系统)在出货之前得以验证,内存需求将受到更多限制,可以将用于存储代码的SRAM和非易失性内存与CPU集成到同一块芯片上,关键一点,实时响应通常很重要。 嵌入式计算机也倾向于在有特殊I/O需求的环境中使用,一些可能是在驱动电动机,另一些可能是在处理声音或读取传感器。将专用外围设备接口硬件集成到同CPU和内存相同的芯片上十分有效,这会产生具有不同特性的各种芯片。 总的来说,CPU与SRAM、非易失性存储器和专用外设集成在一起的被称之为“微控制器”。 微处理器发展至今已经多达64位,而微控制器依然是8位居多,但在这中间发生了一些变化,使得两者之间的区别更加模糊。 集成式闪存是MCU的重要特征,不过这类闪存尚未在拥有最先进节点的微控制器上使用,因此许多以微控制器形式销售的设备都使用外部闪存而不是嵌入式闪存,此外还使用外部DRAM。 实际上,一个称之为“shadowing”的过程可以从外部闪存中获取代码,并将其复制到DRAM中,然后从中执行代码,而且为了提高性能,缓存也可以包括在内。这使得CPU/内存子系统与MPU几乎没有区别。 那么现在的MCU就是MPU吗?不再有区别了吗? 当下可区分MCU与MPU的因素 如今的MCU和MPU十分相似,但依然在很多方面有一些细微的区别,这包括CPU功能、位数、操作系统、时序要求、核心数量等方面。 在CPU功能方面,如果CPU具有复杂的流水线,具有预测执行和其他超标量功能,则可以将其视为MPU,但是转变的确切位置并没有明确界定。 在位数上,8位设备更有可能被视为MCU,64位设备很可能被视为MPU。不过最早的却是MPU是4位,这更像是历史问题,而不是决定性的特征。 也可以根据计算机可运行的操作系统进行分类,如果它运行Linux,则可以将其称为MPU。如果它仅允许较小的实时操作系统,甚至只运行裸机,则可以将其称为MCU,这为能够运行的Linux的设备留出了许多中间地带。在时序方面,MCU通常用于需要硬或软实时响应的应用程序,MPU通常不能用于这一目的。 一般也将多核处理器视为MPU,尤其是在内核相同且管理对称的情况下。不过专用设备可能具有多个处理器,有些专用于诸如数字信号之类特定任务的处理器也会被认为是MCU,因此通过核心数目判断是MPU还是MCU并不是一个准确的依据。 从使用目的来看,可以认为通用设备是MPU,单用途设备是MCU,但这实际上只关乎设备的使用方式,如果在不明确使用目的的情况下使用任何设备,那时候如何称呼这一设备呢? 通常全功能MPU不会具有专用外围设备,这在很大程度上是因为它们是通用的,而不是面向特定应用,因此你可能会认为只要有这样的外围设备,就是MCU,但是事实并非如此,缺少外围设备也并不意味着就是MPU。 从上面的分析来看,每个特征因素都会存在缺陷,结果无法令人满意,那么行业专家又是怎么认为的呢? MCU和MPU已成过时的术语 Cadence IP集团产品行销总监Marc Greenberg对此表示:“我不知道MCU与MPU之间的区别是否存在某些官方的定义,经过简单的检索似乎表明,裸片上存在NVM的为MCU,但各种MPU上都有NVM的某些位,MPU也可能在同一片裸片上具有MCU,那又是什么呢?最小的无缓存处理器可能仍具有一些寄存器和SRAM,用RTL编码的定序器与从ROM执行的通用处理器真的有区别吗?显然MCU和MPU之间的区别有些随意,这意味着这一界限并不明确甚至可以随心所欲。当我想到MPU时,我想到的是用于控制通用计算机的设备,例如台式机、服务器、平板电脑等。” Cadence高级工程师Grant Martin认为:“根据维基百科的解释,MCU是在单个金属氧化物半导体集成电路芯片上的小型计算机,MPU是一种计算机处理器,在MOSFET结构的单个或多个集成电路上结合了中央处理单元的功能。”  “如果深入研究,MPU具有CPU的功能,因此它是计算机处理器,而MCU则是更完整的计算机,这意味着MCU内包含MPU,这与常识相反。具有多个处理器核心的16路服务器处理器是否不再是MPU?而是一种多核异构SoC?” “例如,一部手机可能包括多个应用程序处理内核,用于音频、视频、图像处理的多个DSP,一个或两个用于在屏幕上呈现图像的GPU以及一个仅用于娱乐目的的神经网络处理单元——MCU。从我的角度来看,行业应该放弃这些过时的术语,使用更精确更具描述性的术语。”Grant Martin继续说。 西门子业务部门Mentor的高级产品经理Jeff Hancock则认为:“从系统软件的角度来看,MCU有望适用于直接解释和控制硬件传感器和执行器的应用。这种访问通常涉及一致且可靠的指令时序,这与通用MPU的需求相矛盾。通用MPU旨在优化吞吐量,而MCU通常会优化延迟。因此,如果是需要处理大型数据库,MPU更合适,如果是要精细的机电控制,那么MCU更合适。 Jeff Hancock还说:“外部存储器和缓存肯定让MCU的标准有所变化,但这距离将MCU等同于MPU还有很长的路要走。特别是并不是所有MCU中的所有处理单元都专门使用外部存储器,也可以使用隔离的子系统构建系统,这些子系统允许关键的工作负载和不太关键的应用程序级系统并行继续。”  “从软件工程师的角度看,这是一个有趣的挑战,在不连续的地方可能有两个内存区域,集成式内存虽小,但速度更快,因此最好留给对速度有高要求的代码,例如实时操作系统。这意味着开发工具必须足够灵活以将代码正确地映射到存储器上,而RTOS必须足够小适合片上存储器。”西门子业务部门的嵌入式软件技术专家Walls补充到。 Tortuga Logic的高级硬件安全工程师Nicole Fern表示:“过去,MCU与嵌入式系统相关联。在嵌入式系统中,低成本和低功耗的要求比性能更为重要。但是随着移动计算和IoT边缘计算的出现,许多嵌入式系统现在需要复杂的处理,这样就产生了面向嵌入式领域看起来更像MPU的MCU产品,为带有外部存储器和高速缓存的器件提供了更高的性能和可配置性。这种情况下,术语MCU和MPU之间的差异仅取决于是否集成CPU系统。” Arm的低功耗IoT业务高级总监Thomas Ensergueix也认为:“近年来,MCU和MPU之间的界限已经模糊。MCU和MPU之间的主要区别之一是软件和开发。MPU将支持丰富的OS,如Linux和相关的软件堆栈,而MCU通常将专注于裸机和RTOS。在决定哪种硬件平台、MCU或MPU最有效之前,由软件开发人员决定哪个软件环境和生态系统最适合他们的应用。 “随着现在MCU已经过渡到32位,我们还看到了性能的急剧提高,这有助于缩小MCU和MPU之间的差距。例如:许多基于Arm Cortex-M7的MCU可提供100多个Dhrystone MIPS,或在CoreMark中提供2000多个点。这些设备中的许多设备还具有非常大的内置存储器,或者提供快速接口来连接外部存储器。这确保了性能和内存不再是MCU的瓶颈,并使它们更接近低端MPU。” 小结 如今MPU与MCU之间是否有明确的界限真的重要吗?可能不重要了。因为无论我们将其称之为什么,应用程序都有附带要求,这些要求将决定使用哪个设备。 本文编译自https://semiengineering.com/mpu-vs-mcu/原文作者Bryon Moyer声明:部分内容与图片来源于互联网,如侵犯到您的权益,请及时通知我们,我们将在第一时间内删除。【参与话题讨论,立得100IC币】MPU与MCU之间是否有明确的界限真的重要吗?你怎么看?

电子芯吧客 2020-12-08 阅读:2128

2

回答

BAIDU_CLB_fillSlot%28%22202720%22%29%3B 想做三个方波信号源,要求这三个信号源的输入相位之间间隔120°,怎么做到

loulou 2020-12-08 阅读:35

7

回答
单片机串行口通信电路分析 单片机综合应用

chunyang 2020-12-08 阅读:35

8

回答

如题

MIMonoD 2020-12-08 阅读:105

6

回答
人体感应器的原理是什么? 单片机综合应用

人体感应器的原理

MIMonoD 2020-12-07 阅读:47

1

回答

屏幕截图 2020-12-06 11111.png (360.31 KB 下载次数: 0) 下载附件  保存到相册 2020-12-6 00:08 上传 屏幕截图2222.png (144.52 KB 下载次数: 0) 下载附件  保存到相册 2020-12-6 00:09 上传 看的懂得伙伴,看一下红线是怎么理解得 原码和反码是指啥, 为啥用uchar了k,用k=00010203来判断是怎么个原理

韩梅梅 2020-12-07 阅读:32

8

回答

有的设备不支持5v信号,是否可以用分压电阻让信号等于3.3v,如果可以的话分压电阻多大合适

yhj416606438 2020-12-07 阅读:109

0

回答
终端回显错误 单片机综合应用

我调试串口的时候,发现出现回显错误可以肯定,全部输出都是英文,不存在中文输出的情况。而且输入的字母也是显示乱码,但似乎可以被板子正确识别,不知这种情况应该如何处理?

9604a3b72d92b876 2020-12-05 阅读:16

7

回答

​会不会因为不兼容而损坏。比如电压电流不一样什么的

MIMonoD 2020-12-04 阅读:110

2

回答

原子的P100下载器经常偶发性出现下载失败在同一个板子上死活刷不进去能刷进去就刷进去了 而且这个问题很有意思 看提示 目标芯片连接成功 解除读保护成功 然后就开始失败 9b6a406c03e6b467d0b5a7836260443.jpg (174.8 KB 下载次数: 0) 下载附件 昨天 08:38 上传 通过KEIL5看进去也能看到它按说连接应该完全没问题了吧? 1606956101(1).png (10.26 KB 下载次数: 0) 下载附件 昨天 08:41 上传 不知道到底怎么回事有同样问题的兄弟吗?怎么解决的啊?

chunyang 2020-12-04 阅读:44

4

回答

手上有一颗新唐的ms51fb9ae,网上的下载器很贵想要自己做一个,有能有便宜的编程器可以用或者diy一个

yhj416606438 2020-12-04 阅读:51

0

回答
ads1259怎么校准偏移寄存器 单片机综合应用

每次校准好都没用,是不是校准需要再一定范围内,还是说在adc总量程里面就可以了

yhj416606438 2020-12-04 阅读:34

7

回答

是树莓派么?

MIMonoD 2020-12-03 阅读:57

6

回答

我想在OLED上显示一下温度,但这个变量就是没办法显示,求大佬看看

奋发图强 2020-12-03 阅读:41

6

回答

提问:现有的WIFI模块可以用在51单片机上吗?例如ESP8266模块?

cb48a67effadef96 2020-12-02 阅读:49

2

回答

有没有mcu通过控制wifi芯片远程读写服务器上mysql数据库?相应的mcu和wifi模块的数据手册及控制方法?

SunnyPlus 2020-12-02 阅读:64

2

回答

问题1:外接上拉电阻的作用是什么,P0是为了输出时防止漏极开路,正常工作。。对P1、P2、P3而言可不可以加?是不是为了增加负载能力?      问题2:准双向口是读入前要写1,关闭场效应管。它是P1、P2、P3口的特点。           P0口作为一般I/O口时,上拉场效应一直截止,所以如果不置1,下拉场效应管会导通,永远只能读到0。     为什么P0不叫准双向口?     图片2.png (15.9 KB 下载次数: 0) 下载附件  保存到相册 P02020-11-30 22:57 上传 图片1.png (44.49 KB 下载次数: 0) 下载附件  保存到相册 P12020-11-30 22:57 上传

韩梅梅 2020-12-02 阅读:56

4

回答

怎么随机存取存储器ram中的存储单元

loulou 2020-12-02 阅读:32

0

回答
HLS中的问题RTL无法导出IP核 单片机综合应用

请教一下,我在HLS里面要将以下程序生成IP核,C Synthesis已经做好了,但是在export RTL的时候一直在运行 int sum_single(int A int B) { #pragma HLS INTERFACE s_axilite port=return #pragma HLS INTERFACE s_axilite port=B #pragma HLS INTERFACE s_axilite port=A         int C = 0;         C = A+B;         return C; }

韩梅梅 2020-11-30 阅读:73

4

回答

普中板,led灯4种不同的闪烁模式,按键按一次,数码管显示一,以此类推,但是led灯是P2脚,数码管也是P2的234脚控制,有什么办法能分开控制???

力洪 2020-11-30 阅读:55
  • 帮助人数
  • 0
  • 获得赞数
  • 0
  • 一周积分
  • 0

问题达人换一批

本月问答

排名
用户名
问答积分
13
100
15
70
16
70
18
50
19
40
20
40
21
40
22
26
23
26
25
20
26
20
27
16
28
12
29
10
30
8
< 123 >