在 GNU/Linux 里启用 Intel Rapid Start

在 GNU/Linux 里启用 Intel Rapid Start

Intel Rapid Start 是 Intel 公司研发的一种帮助笔记本电脑节省电源和快速恢复的技术,与传统的睡眠(Sleep)和休眠(Hibernate)有一定的区别,相较而言,与混合睡眠(Hybrid Sleep)倒是有一些相似的地方。Intel 说,这技术首先要主板支持,其次要有 SSD,最后要有 Windows。但其实 SSD 和 Windows 都不是必须的。昨天,我就在 HDD + Linux 的组合里成功地使用了 Intel Rapid Start。

一、Intel Rapid Start 原理

其实 Intel Rapid Start 的原理很简单,就是让计算机在传统的睡眠(Sleep)的基础上有机会进入更深层的睡眠(Deep Sleep),用户可以通过 BIOS 设置一个超时,比如一分钟、十分钟、半个小时等(也可以设置「立即」),当计算机进入睡眠状态之后,计时开始,如果用户在计时到达之前唤醒了计算机,那就啥也没发生,如果预定时间达到,则计算机会被浅唤醒(wake up briefly),将内存中的数据写入硬盘(官方文档指 SSD)中的一个特定分区,然后彻底断电。在这之后,用户只能通过按电源键的方式开机,主板固件会把特定分区中的内容读回内存,然后计算机就可以继续使用了。

总结一下,Intel Rapid Start 技术(IRST)的前半段与普通的睡眠是一样的,而后半段则与休眠(Hibernate)类似,但是休眠是由操作系统完成的,而 IRST 则是由主板固件(BIOS 或 UEFI)去完成这一操作,也就是说,在加电自检(POST)之后,直接就是从硬盘中读取内容的过程了,根本没有引导器(Boot loader)和操作系统的加载过程,因此比操作系统级别的休眠要快不少,再加上 SSD 的应用,就更加快了,这就是 Intel 所宣称的「六秒恢复」。按照我的理解,就是恢复速度和睡眠一样快,但是耗电和休眠一样低(零耗电)。

Intel 的官方文档提到该技术需要 SSD + Windows,可是我没看出其中的必要性:SSD 是为了加速,如果用 HDD 代替的话除了慢点也没啥问题,而 Windows 呢?令人兴奋的是,2013年6月的时候,Linux 开发者 Matthew Garrett 就提交了一个内核补丁,实现了 Linux 内核对此的支持。该补丁已在 Linux 3.11 中得到了应用,而截至我写这篇文章时,最新的 Linux 内核版本已经是 3.12.6 了,显然可以使用。

二、调整分区

我的计算机是 ThinkPad X240s,该型号内部有一个 SATA 和两个 NGFF 接口,后者是 Intel 推的新接口,可以用来接蓝牙、3G 等模块,也可以用来接 NGFF 接口的 SSD。最理想的配置应该是 SATA 接口用来接 HDD 而 NGFF 用来接 SSD,这样的版本是已经配置好 Intel Rapid Start 的。我的这个版本 SATA 接口上接了一块 500GB 7200 转的机械硬盘,一个 NGFF 接了 WiFi + 蓝牙,另一个 NGFF 是空的。也就是说,没有 SSD,自然默认也没得用 Intel Rapid Start。但除了淘宝一块小而贵的 NGFF SSD 之外没有别的方法了吗?当然不是。仔细阅读 Intel Rapid Start 的用户手册就会发现,它提到主板固件是通过分区标识符来找寻 IRST 分区的,对于 GPT,是 D3BFE2DE-3DAF-11DF-BA-40-E3A556D89593,对于 MBR 则是 0x84。

调整前我的分区结构是这样的:


  1. NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT
  2. sda 8:0 0 465,8G 0 disk
  3. ├─sda1 8:1 0 2M 0 part
  4. ├─sda2 8:2 0 200M 0 part /boot
  5. ├─sda3 8:3 0 50G 0 part
  6. │ └─crypt-sda3 254:0 0 50G 0 crypt /
  7. └──sda4 8:4 0 415,6G 0 part
  8. └─crypt-sda4 254:1 0 415,6G 0 crypt /home

整块硬盘 465 GiB 使用 GPT 分为四个区,开头 2 MiB 用来存放 GRUB,之后 200 MiB 是 /boot,然后是 50 GiB 和 /,最后剩下的 415.6 GiB 用作 /home。其中 sda3 和 sda4 都是 LUKS 容器。我的目的是要把 sda4 调整为 400 GiB,然后把剩下的 15.6 GiB 划为 sda5,作为 IRST 分区。

由于 sda4 是 GPT + LUKS + ext4 三层嵌套结构,所以需要一层一层地缩小它们,然后再一层一层地撑大它们到合适的位置。


  1. # 把 /home 卸载
  2. umount /home
  3. # 调整文件系统前必须要先检查文件系统
  4. e2fsck -f /dev/mapper/crypt-sda4
  5. # 缩小文件系统至 398 GiB
  6. resize2fs -p /dev/mapper/crypt-sda4 398G
  7. # 缩小 LUKS 容器至 399 GiB
  8. # 换算成 512 KiB 的区块是 399 * 1024 * 1024 * 2 = 836763648
  9. cryptsetup resize crypt-sda4 836763648
  10. # 将 sda4 分区调整为 400 GiB
  11. # 并用剩余的空间建立 sda5
  12. # 建立的时候分区标识符输入 8400
  13. gdisk /dev/sda
  14. # 重启计算机使内核使用新的分区表
  15. reboot
  16. # 再次卸载 /home
  17. umount /home
  18. # 放大 LUKS 容器撑满 sda4
  19. cryptsetup resize crypt-sda4
  20. # 检查文件系统
  21. e2fsck -f /dev/mapper/crypt-sda4
  22. # 放大文件系统至撑满 LUKS 容器
  23. resize2fs -p /dev/mapper/crypt-sda4
  24. # 挂载测试
  25. mount /dev/mapper/crypt-sda4 /home

调整完成后,就是这样的效果了:


  1. NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT
  2. sda 8:0 0 465,8G 0 disk
  3. ├─sda1 8:1 0 2M 0 part
  4. ├─sda2 8:2 0 200M 0 part /boot
  5. ├─sda3 8:3 0 50G 0 part
  6. │ └─crypt-sda3 254:0 0 50G 0 crypt /
  7. ├─sda4 8:4 0 400G 0 part
  8. │ └─crypt-sda4 254:1 0 400G 0 crypt /home
  9. └─sda5 8:5 0 15,6G 0 part
  10.  
  11. Number Start (sector) End (sector) Size Code Name
  12. 1 2048 6143 2.0 MiB EF02 BIOS boot partition
  13. 2 6144 415743 200.0 MiB 8300 Linux filesystem
  14. 3 415744 105273343 50.0 GiB 8300 LUKS partition
  15. 4 105273344 944134143 400.0 GiB 8300 LUKS partition
  16. 5 944134144 976773134 15.6 GiB 8400 Intel Rapid Start

三、设置主板固件(BIOS/UEFI)

这一步视不同的制造商自有不同,但主旨就是找到 BIOS/UEFI 中有关 Intel Rapid Start 的设置,将之开启。在完成以上步骤之前,这一选项是不可开启的状态,会提示没有找到合适的存储设备,但是在完成了上述步骤之后,固件就会根据 GUID 找到 IRST 分区,从而允许开启这一功能。至于多久后启用,就是个人爱好了,我选择的是「立即」,也就是相当于用 IRST 代替了睡眠(Sleep)功能。

四、测试

为了测试效果明显,可以先用 dd_rescue 把 sda5 清空一下:dd_rescue /dev/zero /dev/sda5。可以用诸如 head -c 1G /dev/sda5 之类的命令检验一下。

准备完成之后开始测试:echo -n mem > /sys/power/state 将系统挂起至内存(S3,睡眠)→系统顺利睡眠→系统被短暂唤醒并将内存中的内容写入 IRST 分区,此时如果仔细听可以听到机械硬盘写入的声音→写入完成,系统断电停机。

断电停机之后,用户只能通过按电源键把计算机唤醒。按下电源键后可观察到 BIOS/UEFI 上显示类似 Resuming from deep sleep ... 字样,说明这一恢复过程是由固件完成的,与操作系统无关。恢复完成后,直接回复到进入睡眠之前的样子。此时使用 head /dev/sda5 可观察到大量输出,说明 sda5 的确被写入了。

至此 IRST 部署成功。

原文发布时间:2014-01-02

本文来自云栖合作伙伴“linux中国”

时间: 2024-10-24 20:51:38

在 GNU/Linux 里启用 Intel Rapid Start的相关文章

“您的系统似乎尚未启用Intel Rapid Start Technology”解决方法

Intel Rapid start报错"您的系统似乎尚未启用Intel Rapid Start Technology"如下图: 原因分析: 1. BIOS下没有开启Intel Rapid start技术. 2. 在系统下已安装Intel Rapid start程序情况下休眠分区被破坏或不存在. 解决方法: 1. 进入磁盘管理查看休眠分区是否存在,如果不存在请按搜索常见问题,文章编号:092784,按照文章引导创建; 2. 如果休眠分区正常需要进入:BIOS---config---pow

联想E430出现“您的系统似乎尚未启用Intel Rapid Start Technology"

  故障现象: Intel Rapid start报错您的系统似乎尚未启用Intel Rapid Start Technology如下图: 原因分析: 1.BIOS下没有开启Intel Rapid start技术. 2. 在系统下已安装Intel Rapid start程序情况下休眠分区被破坏或不存在. 解决方案: 1. 进入磁盘管理查看休眠分区是否存在,如果不存在请创建. 2. 如果休眠分区正常需要进入:BIOS--config--power--Intel rapid start techno

Intel Rapid start报错”您的系统似乎尚未启用Intel Rapid Start Technology“

故障现象: Intel Rapid start报错您的系统似乎尚未启用Intel Rapid Start Technology,如下图: 原因分析: 1. BIOS下没有开启Intel Rapid start技术. 2. 在系统下已安装Intel Rapid start程序情况下休眠分区被破坏或不存在. 解决方案: 1. 进入磁盘管理查看休眠分区是否存在,如果不存在请按搜索常见问题,文章编号:092784,按照文章引导创建: 2. 如果休眠分区正常需要进入:BIOS---config---pow

Intel Rapid start报错”您的系统似...Start Technology“

  故障现象: Intel Rapid start报错您的系统似乎尚未启用Intel Rapid Start Technology,如下图: 原因分析: 1. BIOS下没有开启Intel Rapid start技术. 2. 在系统下已安装Intel Rapid start程序情况下休眠分区被破坏或不存在. 解决方案: 1. 进入磁盘管理查看休眠分区是否存在,如果不存在请按搜索常见问题,文章编号:092784,按照文章引导创建; 2. 如果休眠分区正常需要进入:BIOS---config---p

Firefox 44.0将在Linux上启用H.264支持:GTK3仍缺席

随着 Firefox 43.0 的平稳落地,下面我们不妨预知下 Firefox 44.0 中将要迎来的大变化.12 月 18 号,Mozilla 发布了首个测试版本(Firefox 44.0 Beta 1),最显著的一点就是将启用 GNU/Linux 操作系统上的H.264 (如果跨平台的 FFmpeg 后端已安装的话).而在不支持 MP4/H.264 的机器上,也将支持 WebM/VP9 的视频回放. 遗憾的是,目前文档中并未提及任何有关 GTK3(for Linux)的消息.此前,Mozil

Fluxbox v1.3.1发布 GNU/Linux的轻量级图形操作界面

Fluxbox是一个基于GNU/Linux的轻量级图形操作界面,它基于Blackbox 0.61.1代码开发,它虽然没有GNOME和KDE那样精美,但由于它的运行对系统资源和配置要求极低,所以它被安装到很多较旧的或是对性能要求较高的机器上,其菜单和相关配置被保存于用户根目录下的.fluxbox目录里,这样使得它的配置极为便利. Fluxbox是类Unix系统里一个极为轻量极的图形界面,它的运行速度相当快.它基于Blackbox并与之相兼容,这两者的窗体控件,色调等都极为相似.Fluxbox对KD

Fluxbox v1.3发布 基于GNU/Linux轻量级图形操作界面

Fluxbox是一个基于GNU/Linux的轻量级图形操作界面,它基于Blackbox 0.61.1代码开发,它虽然没有GNOME和KDE那样精美,但由于它的运行对系统资源和配置要求极低,所以它被安装到很多较旧的或是对性能要求较高的机器上,其菜单和相关配置被保存于用户根目录下的.fluxbox目录里,这样使得它的配置极为便利. Fluxbox是类Unix系统里一个极为轻量极的图形界面,它的运行速度相当快.它基于Blackbox并与之相兼容,这两者的窗体控件,色调等都极为相似.Fluxbox对KD

不要在linux上启用net.ipv4.tcp_tw_recycle参数

不要在linux上启用net.ipv4.tcp_tw_recycle参数 发布于 2015/07/27 莿鸟栖草堂 本文为翻译英文BLOG<Coping with the TCP TIME-WAIT state on busy Linux servers>,但并非完整的翻译,译者CFC4N对原文理解后,进行了调整,增加了相关论点论据,跟原文稍有不同.翻译的目的,是为了加深自己知识点的记忆,以及分享给其他朋友,或许对他们也有帮助.文章比较长,没耐心请点关闭. 不要启用 net.ipv4.tcp_

Parsix GNU/Linux 项目宣布即将终止

基于 Debian 的 Parsix 发行版已经宣布将会在 Debian Stretch 发布六个月后终止.官方表示 Parsix GNU/Linux 8.15 (Nev) 在这段时间里会得到完全的支持,用户应该可以把他们的安装升级到 Debian Stretch 而不会有重大的问题.官方也会进行有必要的更改和更新,以确保能平滑过渡到 Debian Stretch. 下面是官方的公告全文: Parsix GNU/Linux 项目终止公告 - 2017.5.19 Parsix GNU/Linux