KeGetProcessorNumberFromIndex 函数 (ntifs.h)

KeGetProcessorNumberFromIndex 例程将系统范围的处理器索引转换为组号和组相对处理器编号。

语法

NTSTATUS KeGetProcessorNumberFromIndex(
  [in]  ULONG             ProcIndex,
  [out] PPROCESSOR_NUMBER ProcNumber
);

参数

[in] ProcIndex

系统范围的处理器索引。 如果多处理器系统总共包含 n 个逻辑处理器,则有效的处理器索引范围为 0 到 n-1

[out] ProcNumber

指向调用方分配 的PROCESSOR_NUMBER 结构的指针,例程在该结构中写入 由 ProcIndex 标识的处理器的组号和相对于组的处理器编号。

返回值

如果调用成功,KeGetProcessorNumberFromIndex 将返回STATUS_SUCCESS。 可能的错误返回值包括:

返回代码 说明
STATUS_INVALID_PARAMETER
ProcIndex 参数值不是有效的处理器索引。

注解

此例程接受一个处理器索引作为输入,用于标识整个多处理器系统中的处理器。 输出值是一个 PROCESSOR_NUMBER 结构,它按组号和组中的处理器编号来标识处理器。

例如,如果多处理器系统包含两个组,并且每个组包含 64 个逻辑处理器,则每个组中的处理器编号范围为 0 到 63,但系统范围的处理器索引范围为 0 到 127。

若要获取系统中活动逻辑处理器的总数,请调用 KeQueryActiveProcessorCountEx 例程。

KeGetProcessorIndexFromNumber 例程将组号和组相对处理器编号转换为系统范围的处理器索引。

示例

下面的代码示例使用 KeQueryActiveProcessorCountExKeGetProcessorNumberFromIndex 例程枚举系统中的所有活动逻辑处理器:

ULONG Count;
ULONG ProcIndex;
PROCESSOR_NUMBER ProcNumber;

Count = KeQueryActiveProcessorCountEx(ALL_PROCESSOR_GROUPS);
for (ProcIndex = 0; ProcIndex < Count; ProcIndex += 1)
{
    KeGetProcessorNumberFromIndex(ProcIndex, &ProcNumber);

    // Do something with the contents of ProcNumber.
    ...
}

ALL_PROCESSOR_GROUPS常量值在 Winnt.h 和 Ntdef.h 中定义。

要求

要求
最低受支持的客户端 Windows 7
目标平台 通用
标头 ntifs.h (包括 Ntddk.h、Wdm.h、Ntddk.h、Ntifs.h)
Library NtosKrnl.lib
DLL NtosKrnl.exe
IRQL 任何级别

另请参阅

KeGetProcessorIndexFromNumber

KeQueryActiveProcessorCountEx

PROCESSOR_NUMBER