苹果M1用着舒服的原因找到了 Intel:下次我也用
苹果m1又快又省电,除了跑分很高之外,实际体验上也有一种流畅感。
苹果到底怎么做到的?
原来除了硬件性能强大以外,软件层面也有优化技巧。
一位名叫hoakley的程序员偶然发现了其中的秘密。
这老哥总之是有钱,m1和英特尔版的imac都买了。业余时间他喜欢自己开发点实用小工具,比如压缩软件。
老哥在后台测试自己的压缩程序时发现,m1上只有4个核心在跑,还有4个闲着。
换到英特尔上试试,因为还没用到虚拟核心,是由8个真实核心共同承担了工作。
回到m1里仔细一看,使用率高的还不是性能高的那4个,而是“效率核心”。
在m1芯片的8个cpu核心里,有4个被称作“firestorm”的性能核心,另外4个是“icestorm”效率核心,性能弱一些,不过功耗更低。
研究了一下,老哥发现是自己把任务优先级设低了,提高以后,就能让4个性能核心参与进来。
老哥恍然大悟,原来这就是苹果的策略。
让优先度低的任务只占用效率核心,慢点就慢点吧,谁让你优先度低呢。
性能核心保持空闲状态,随时应对突发的高优先度任务。
app启动速度快,切换流畅的原因找到了:4个高性能的核心一直候着呢。
非对称核心
macos给开发者提供了4种优先级,分别是后台 (background)、实用 (utility)、用户发起的 (userinitiated)、用户交互的 (userinteractive)。
如果不指定的话就归为默认,由操作系统自己安排。
hoakley老哥把自己的压缩软件改造成可以随时调整优先级的,然后准备了一个10gb的文件开始测试。
在英特尔cpu上,最高优先级完成压缩需要23.3秒,调成最低优先级需要26秒。
在m1上,最高优先级运行只要14.1秒,调成后台优先级直接涨到101秒。
老哥认为,牺牲一些不重要任务的运行速度,换来的使用体验上的流畅,太值了。
比如备份文件就不用着急,即使慢到用15分钟备份不到1g也无所谓。
历史上也有这样一个反面教材。
2006年的时候linux内核引入了一种叫完全公平队列 (completely fair queuing)的i/o调度机制。
虽然在理论上能提升总体的运行效率,但用户正需要完成的任务总是有一些延迟才能执行。
因为用户体验太差,最终完全公平队列被大多数linux发行版放弃了。
不过也有人不喜欢m1的这种机制,他认为在笔记本上这样做可以延长续航。但台式的imac上真的要牺牲运行速度吗?反正都是插电源的。
英特尔:在学了在学了
其实cpu内核分性能核心和效率核心这件事,手机上的arm芯片早就在做了。
甚至高通还在研发中的骁龙875,被曝光在这种架构基础上还增加了一个“超大核心”cortex x1。总共1+3+4构成8个核心。
苹果m1将arm平台带到了pc市场,让英特尔开了眼。
在ces2021上曝光的12代酷睿alder lake,英特尔也宣布要区分两种核心了。
amd知道了这个消息后,直接把挤牙膏的zen3+项目给取消了,转而全力研发下一代zen4架构处理器,代号raphael,预计2022年发布。
不知道amd会不会选择跟上这个潮流。
- the end -
下一篇: 隋唐头号猛将是谁?李元霸还是尉迟恭