智能手机发展太快了,尤其是移动处理器上,今年年底联发科的10核处理器就要跟大家见面。
或许你也想问,为何手机处理器上的核心比数目提升的比计算机快?难道就是为了单纯的制造噱头吗?现在有网友在知乎上,给出了自己的详细看法。
最根本的是,PC和手机两个领域对处理器有非常不同的需求,前者可以以一味地追求高主频,高单核性能,因为它可以安装风扇或者安装很大块的散热装置,可以直接接入家用能源。
手机则是核不可以“一味地”追求高频,它小巧,它随身携带,它要考虑发热,要考虑电池的容量。
所以,智能终端的SOC在设计的时候必须在兼顾温控与能耗的情况下。这注定智能终端的SOC要走PC的多核化老路,并且做更多样化的尝试。
多核只是其中一种尝试。因为单核在主频上去以后,要求的电压更高,发热严重,而随着发热量的增加,漏电率又会增加,会进一步增加能耗与发热。而这两项恰会影响手持设备的两个重要体验,即续航与温控。
在单核方面,相应的技术改进有HPM,漏电率比LP下降不少,所以同样的主频可以跑在更低的电压上。除此之外,还有一些筛选和区分不同品质晶圆的技术,例如三星的ASV,晶圆质量高的同频下可以跑更低的电压。
与此同时,还有各种类型资源的DVFS支持,idle支持,clock gating,regulator gating,power domain……好了,那单核的性能努力如何呢?从当前市场上在售的来看:
“Cortex-A57是ARM最先进、性能最高的应用处理器,号称可在同样的功耗水平下达到当今顶级智能手机性能的三倍;而Cortex-A53是世界上能效最高、面积最小的64位处理器,同等性能下能效是当今高端智能手机的三倍。这两款处理器还可整合为ARM big.LITTLE(大小核心伴侣)处理器架构,根据运算需求在两者间进行切换,以结合高性能与高功耗效率的特点,两个处理器是独立运作的。”
而未来联发科上市的全新Helio X20(即MT6797)的大核A72可以到2.5G。那问题来了,虽然性能很强劲,但是发热的剧增会导致处理器持续高频不了多久。因为外部人体的温度是恒定的,37度,再温一点,42~43度,再热一点45~47度,再就烫起来了。所以这个加上主板的散热结构已经阻止了固定工艺和技术下的性能成长空间。也限制了高频核心的高性能的应用。
而加强手持设备的结构空间限制,又限制了散热技术的应用,这个是PC和服务器根本就不存在的问题。
既然往上涨不了了(实际上还有技术和成本制约),那是不是可以横着涨呢,好了,尝试多核,而多核又有同构多核,异构多核,有真多核还有伪多核。
到这个份上,咱们就可以得到一个初步的结论,多核完全是为了迎合消费者,不是为了迎合和迎合,而是为了给用户更好的体验。
为什么会提供更好的体验?
随着主频的提升,单核的工作能耗会随着指数级上升,相应的热量聚集也会更高。换算到同等计算能力(单位时间内可执行的指令数)的多核,能耗上升呈线性关系,热量聚集会明显降低。具体量化起来,得画个图表,把频率,核数和能耗关系绘制出来,这里先省掉。
1、对于远古时代的单一任务系统,多核是没有意义的。任务的工作量没有办法分派给其他核心执行。并行不起来。
2、现今的系统,包括Android等手持设备的系统默认任务数量已经非常多,具体数量会有差异。稍微看了下MX3,有100+,实际线程数只会更多。
3、多核相比单核,无用的任务context switch会减少,能耗利用率会提高,任务的响应能力(最高频率满足条件下)也响应会增加。甚至对于一些关键的任务,可以通过独占某一个核心获得最好的响应能力。
那核数是不是越多越好呢?是不是100个任务就开100个核呢?肯定不是,首先有硬件成本的限制,其二,核数多了以后,负载均衡,任务迁移,甚至任务同步也是很大一笔开销。