news 2026/4/23 11:25:19

ACPI!ACPIBuildProcessDevicePhasePsc函数分析对节点iSA的处理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ACPI!ACPIBuildProcessDevicePhasePsc函数分析对节点iSA的处理

ACPI!ACPIBuildProcessDevicePhasePsc函数分析对节点iSA的处理

1: kd> g
Breakpoint 5 hit
eax=00000016 ebx=00000016 ecx=89984198 edx=00000001 esi=89984188 edi=80b019f4
eip=f73fb911 esp=f78aef68 ebp=f78aef84 iopl=0 nv up ei pl zr na pe nc
cs=0008 ss=0010 ds=0023 es=0023 fs=0030 gs=0000 efl=00000246
ACPI!ACPIBuildProcessGenericList+0x4d:
f73fb911 ff55f4 call dword ptr [ebp-0Ch] ss:0010:f78aef78={ACPI!ACPIBuildProcessDevicePhasePsc (f73fb57c)}
1: kd> kc
#
00 ACPI!ACPIBuildProcessDevicePhasePsc
01 ACPI!ACPIBuildProcessGenericList
02 ACPI!ACPIBuildDeviceDpc
03 nt!KiRetireDpcList
04 nt!KiDispatchInterrupt
WARNING: Frame IP not in any known module. Following frames may be wrong.
05 0x0
1: kd> dv
BuildRequest = 0x89984188
matrixIndex = 0n8 (No matching enumerant)
i = 0n-1986510456 (No matching enumerant)

typedef enum _SYSTEM_POWER_STATE {
PowerSystemUnspecified = 0,
PowerSystemWorking = 1,
PowerSystemSleeping1 = 2,
PowerSystemSleeping2 = 3,
PowerSystemSleeping3 = 4,
PowerSystemHibernate = 5,
PowerSystemShutdown = 6,
PowerSystemMaximum = 7
} SYSTEM_POWER_STATE, *PSYSTEM_POWER_STATE;


1: kd> dv matrixIndex
matrixIndex = PowerSystemSleeping1 (0n2)
2 3 4 5

//
// For each S state, walk PR0 to PR2 until you find a resource that
// cannot be ON in S state. The next lighter D state is then the lightest
// D state for the given S state.
//
for ( ; matrixIndex <= PowerSystemHibernate ; matrixIndex++ ) {

//
// Loop on all members of the PowerNode
//
for (i = PowerDeviceD0; i <= PowerDeviceD2; i++ ) {


1: kd> dx -id 0,0,899a2278 -r1 (*((ACPI!_ACPI_POWER_INFO *)0x899c0b18))
(*((ACPI!_ACPI_POWER_INFO *)0x899c0b18)) [Type: _ACPI_POWER_INFO]
[+0x000] Context : 0x0 [Type: void *]
[+0x004] PowerState : PowerDeviceUnspecified (0) [Type: _DEVICE_POWER_STATE]
[+0x008] DeviceNotifyHandler : 0x0 [Type: void (*)(void *,unsigned long)]
[+0x00c] HandlerContext : 0x0 [Type: void *]
[+0x010] PowerNode [Type: _ACPI_DEVICE_POWER_NODE * [4]]//这个
[+0x020] PowerObject [Type: _NSObj * [5]]
[+0x034] WakeBit : 0x0 [Type: unsigned long]
[+0x038] DevicePowerMatrix [Type: _DEVICE_POWER_STATE [7]]//这个
1: kd> dx -id 0,0,899a2278 -r1 (*((ACPI!_ACPI_DEVICE_POWER_NODE * (*)[4])0x899c0b28))
(*((ACPI!_ACPI_DEVICE_POWER_NODE * (*)[4])0x899c0b28)) [Type: _ACPI_DEVICE_POWER_NODE * [4]]
[0] : 0x0 [Type: _ACPI_DEVICE_POWER_NODE *]
[1] : 0x0 [Type: _ACPI_DEVICE_POWER_NODE *]
[2] : 0x0 [Type: _ACPI_DEVICE_POWER_NODE *]
[3] : 0x0 [Type: _ACPI_DEVICE_POWER_NODE *]

1: kd> dx -id 0,0,899a2278 -r1 (*((ACPI!_DEVICE_POWER_STATE (*)[7])0x899c0b50))
(*((ACPI!_DEVICE_POWER_STATE (*)[7])0x899c0b50)) [Type: _DEVICE_POWER_STATE [7]]
[0] : PowerDeviceUnspecified (0) [Type: _DEVICE_POWER_STATE]
[1] : PowerDeviceD0 (1) [Type: _DEVICE_POWER_STATE]
[2] : PowerDeviceD0 (1) [Type: _DEVICE_POWER_STATE]
[3] : PowerDeviceD0 (1) [Type: _DEVICE_POWER_STATE]
[4] : PowerDeviceD0 (1) [Type: _DEVICE_POWER_STATE]
[5] : PowerDeviceD3 (4) [Type: _DEVICE_POWER_STATE]
[6] : PowerDeviceD3 (4) [Type: _DEVICE_POWER_STATE]

1: kd> dd 0x899c0b50
899c0b50 00000000 00000001 00000001 00000001
899c0b60 00000001 00000004 00000004 00000000

typedef enum _DEVICE_POWER_STATE {
PowerDeviceUnspecified = 0,
PowerDeviceD0,
PowerDeviceD1,
PowerDeviceD2,
PowerDeviceD3,
PowerDeviceMaximum
} DEVICE_POWER_STATE, *PDEVICE_POWER_STATE;


1: kd> dv
BuildRequest = 0x00000004
matrixIndex = PowerSystemSleeping2 (0n3)
i = PowerDeviceD3 (0n4)

//
// If we have had a device node, but don't have now, that means
// that we found a D level that is compliant for this S-state
//
if (deviceNode == NULL) {

ACPIDevPrint( (
ACPI_PRINT_LOADING,
deviceExtension,
"ACPIBuildDeviceProcessPhasePsc: D%x <-> S%x\n",
(i - PowerDeviceD0),
matrixIndex - PowerSystemWorking
) );

//
// This device can be in Di state while in SmatrixIndex state
//
powerInfo->DevicePowerMatrix[matrixIndex] = i;
break;

1: kd> dx -id 0,0,899a2278 -r1 (*((ACPI!_ACPI_POWER_INFO *)0x899c0b18))
(*((ACPI!_ACPI_POWER_INFO *)0x899c0b18)) [Type: _ACPI_POWER_INFO]
[+0x000] Context : 0x0 [Type: void *]
[+0x004] PowerState : PowerDeviceUnspecified (0) [Type: _DEVICE_POWER_STATE]
[+0x008] DeviceNotifyHandler : 0x0 [Type: void (*)(void *,unsigned long)]
[+0x00c] HandlerContext : 0x0 [Type: void *]
[+0x010] PowerNode [Type: _ACPI_DEVICE_POWER_NODE * [4]]
[+0x020] PowerObject [Type: _NSObj * [5]]
[+0x034] WakeBit : 0x0 [Type: unsigned long]
[+0x038] DevicePowerMatrix [Type: _DEVICE_POWER_STATE [7]]
[+0x054] SystemWakeLevel : PowerSystemUnspecified (0) [Type: _SYSTEM_POWER_STATE]


//
// Now that we have built the matrix, we can figure out what D-level the
// device can support wake with.
//
powerInfo->DeviceWakeLevel =
powerInfo->DevicePowerMatrix[powerInfo->SystemWakeLevel];

1: kd> dx -id 0,0,899a2278 -r1 (*((ACPI!_DEVICE_POWER_STATE (*)[7])0x899c0b50))
(*((ACPI!_DEVICE_POWER_STATE (*)[7])0x899c0b50)) [Type: _DEVICE_POWER_STATE [7]]
[0] : PowerDeviceUnspecified (0) [Type: _DEVICE_POWER_STATE]
[1] : PowerDeviceD0 (1) [Type: _DEVICE_POWER_STATE]
[2] : PowerDeviceD0 (1) [Type: _DEVICE_POWER_STATE]
[3] : PowerDeviceD0 (1) [Type: _DEVICE_POWER_STATE]
[4] : PowerDeviceD0 (1) [Type: _DEVICE_POWER_STATE]
[5] : PowerDeviceD3 (4) [Type: _DEVICE_POWER_STATE]
[6] : PowerDeviceD3 (4) [Type: _DEVICE_POWER_STATE]


typedef enum _SYSTEM_POWER_STATE {
PowerSystemUnspecified = 0,
PowerSystemWorking = 1,
PowerSystemSleeping1 = 2, 2
PowerSystemSleeping2 = 3, 3
PowerSystemSleeping3 = 4, 4
PowerSystemHibernate = 5, 5
PowerSystemShutdown = 6,
PowerSystemMaximum = 7
} SYSTEM_POWER_STATE, *PSYSTEM_POWER_STATE;

外循环循环4次,内循环循环3次,共循环12次。

typedef enum _DEVICE_POWER_STATE {
PowerDeviceUnspecified = 0,
PowerDeviceD0, 1
PowerDeviceD1, 2
PowerDeviceD2, 3
PowerDeviceD3,
PowerDeviceMaximum
} DEVICE_POWER_STATE, *PDEVICE_POWER_STATE;

for ( ; matrixIndex <= PowerSystemHibernate ; matrixIndex++ ) {

//
// Loop on all members of the PowerNode
//
for (i = PowerDeviceD0; i <= PowerDeviceD2; i++ ) {

//
// Are there any resources to look at?
//
deviceNode = powerInfo->PowerNode[i];
if (deviceNode == NULL) {

continue;

}

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 16:20:20

技术炒股心得

技术炒股心得&#xff1a;工具为骨&#xff0c;心法为魂&#xff08;附避坑指南&#xff09;重要前提&#xff1a;技术分析是概率工具&#xff0c;非“圣杯”。所有策略需配合严格风控&#xff0c;投资有风险&#xff0c;本文仅为经验总结&#xff0c;不构成任何投资建议。&…

作者头像 李华
网站建设 2026/4/19 3:41:45

24GB显卡轻松上手InternLM-20B大模型,手把手教程来啦

无论在本地电脑还是在云端都可以轻松使用该镜像&#xff0c;现在就让我们跟着教程一起体验InternLM-20B的魅力吧~ 本地电脑运行 如果您本地有GPU&#xff08;显存24GB及以上&#xff09;&#xff0c;可以在本地CG客户端直接使用&#xff0c;即可获得和AutoDL云端一致的使用体…

作者头像 李华
网站建设 2026/4/19 2:11:29

最强开源模型新王通义千问2.5 72B被我用4GB老显卡本地跑通了

炸裂&#xff01;最强开源模型一夜之间易主。阿里发布千问2.5模型&#xff0c;72B版本在MMLU、MATH、MBPP等大部分评测指标上都超过了Llama3 405B&#xff0c;甚至一些指标也超过了GPT4o。正式加冕最强开源模型新王&#xff01; 今天要挑战用我的4GB老显卡不做量化、不做压缩&…

作者头像 李华
网站建设 2026/4/3 4:28:07

python校园互助系统 微信小程序的设计与开发

目录 校园互助系统微信小程序的设计与开发摘要背景与目标技术架构核心功能创新点测试与部署总结 开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 校园互助系统微信小程序的设计与开发摘要 …

作者头像 李华
网站建设 2026/4/18 1:39:54

Gitee领衔2026年项目管理工具变革:技术驱动与本土化优势的双重突破

Gitee领衔2026年项目管理工具变革&#xff1a;技术驱动与本土化优势的双重突破 在数字化浪潮席卷全球的2026年&#xff0c;项目管理工具市场正经历着一场深刻的变革。作为中国最大的代码托管平台&#xff0c;Gitee&#xff08;码云&#xff09;凭借其技术驱动的创新理念和全面的…

作者头像 李华