1

我想在没有连接交流适配器的情况下以翻盖模式使用 Macbook air。但是,当我合上盖子时,Mac OS 会强制系统进入睡眠状态。

我发现来自苹果开源的 XNU 内核的这一部分可能与这种行为有关:

iokit/内核/IOPMrootDomain.cpp

...

6362     /*
6363      * Evaluate clamshell and SLEEP if appropiate
6364      */
6365     if (eval_clamshell && clamshellClosed)
6366     {
6367         if (shouldSleepOnClamshellClosed())
6368             privateSleepSystem (kIOPMSleepReasonClamshell);
6369         else
6370             evaluatePolicy( kStimulusDarkWakeEvaluate );
6371     }

...

3061 //******************************************************************************
3062 // sleepOnClamshellClosed
3063 //
3064 // contains the logic to determine if the system should sleep when the clamshell
3065 // is closed.
3066 //******************************************************************************
3067 
3068 bool IOPMrootDomain::shouldSleepOnClamshellClosed( void )
3069 {
3070     if (!clamshellExists)
3071         return false;
3072 
3073     DLOG("clamshell closed %d, disabled %d, desktopMode %d, ac %d sleepDisabled %d\n",
3074         clamshellClosed, clamshellDisabled, desktopMode, acAdaptorConnected, clamshellSleepDisabled);
3075 
3076     return ( !clamshellDisabled && !(desktopMode && acAdaptorConnected) && !clamshellSleepDisabled );
3077 }

当然,我可以编译内核,但我怀疑它是否是最新的 Mavericks 内核。所以我想知道我是否可以通过插入动态库来覆盖内核空间函数,就像我们为用户空间函数所做的那样。

4

1 回答 1

0

重新编译 xnu 内核比你想象的要容易:

http://shantonu.blogspot.ca/2013/10/building-xnu-for-os-x-109-mavericks.html

然而,Apple 为 OSX 的维护版本发布源代码的速度相当缓慢,因此您必须延迟更新 10.9.x,直到源代码可用。

除此之外,您还有两个明显的选择:

  • 直接在磁盘上修补 mach_kernel 可执行文件。
  • 使用专门构建的 kext 在运行时修补 IOPMrootDomain::shouldSleepOnClamshellClosed 函数。

在这两种情况下,在反汇编中定位IOPMrootDomain::shouldSleepOnClamshellClosed函数。mach_kernel找出它读取的位置acAdaptorConnected并将这些指令替换为使代码表现得好像acAdaptorConnected总是正确的指令。

在运行时修补时需要小心。该方法是私有的,因此您无法使用 kext 链接器直接获取其地址,因此您需要从其他地方获取地址。

FWIW,我不是 100% 相信这段代码应该归咎于你所看到的行为。如果连接了外部显示器,clamshellDisabled通常应该是。true如果您专门尝试使用连接屏幕的 Macbook,则可以尝试生成一个虚假的kIOPMDisableClamshell电源事件,这应该会翻转该标志。

顺便说一句,Apple 在内核中硬编码这种行为有点令人失望——这似乎是一个简单的用户空间脚本应该决定的事情。:-(

于 2013-12-13T01:36:39.653 回答