Windows Server / Datacenter:使用>设置CPU亲缘关系。 64核心

时间:2012-11-14 20:35:00

标签: c# .net windows winapi multiprocessing

SetThreadAffinityMask()允许为64个逻辑核心(处理器)设置关联掩码。但是,Windows Datacenter最多可以有64个CPU,每个CPU都有许多核心(请参阅here)。

如何为>设置线程? 64个核心?

聚苯乙烯。我使用C#进行编码,因此.Net的答案是理想的,但C语言中的API也很好。

3 个答案:

答案 0 :(得分:2)

我使用以下代码设置处理器组和CPU的关联:

[StructLayout(LayoutKind.Sequential, Pack = 4)]
private struct _GROUP_AFFINITY
{
    public UIntPtr Mask;
    [MarshalAs(UnmanagedType.U2)]
    public ushort Group;
    [MarshalAs(UnmanagedType.ByValArray, SizeConst = 3, ArraySubType = UnmanagedType.U2)]
    public ushort[] Reserved;
}

[DllImport("kernel32", SetLastError = true)]
private static extern Boolean SetThreadGroupAffinity(
    IntPtr hThread,
    ref _GROUP_AFFINITY GroupAffinity,
    ref _GROUP_AFFINITY PreviousGroupAffinity);

[DllImport("kernel32", SetLastError = true)]
private static extern IntPtr GetCurrentThread();

/// <summary>
/// Sets the processor group and the processor cpu affinity of the current thread.
/// </summary>
/// <param name="group">A processor group number.</param>
/// <param name="cpus">A list of CPU numbers. The values should be
/// between 0 and <see cref="Environment.ProcessorCount"/>.</param>
public static void SetThreadProcessorAffinity(ushort groupId, params int[] cpus)
{
    if (cpus == null) throw new ArgumentNullException(nameof(cpus));
    if (cpus.Length == 0) throw new ArgumentException("You must specify at least one CPU.", nameof(cpus));

    // Supports up to 64 processors
    long cpuMask = 0;
    foreach (var cpu in cpus)
    {
        if (cpu < 0 || cpu >= Environment.ProcessorCount)
            throw new ArgumentException("Invalid CPU number.");

        cpuMask |= 1L << cpu;
    }

    var hThread = GetCurrentThread();
    var previousAffinity = new _GROUP_AFFINITY {Reserved = new ushort[3]};
    var newAffinity = new _GROUP_AFFINITY
    {
        Group = groupId,
        Mask = new UIntPtr((ulong) cpuMask),
        Reserved = new ushort[3]
    };

    SetThreadGroupAffinity(hThread, ref newAffinity, ref previousAffinity);
}

答案 1 :(得分:1)

根据MSDN,SetThreadAffinityMask()设置当前处理器组的关联,每个处理器组可以有64个逻辑核心。使用SetThreadGroupAffinity()更改您的组。有关详情,请参阅http://msdn.microsoft.com/en-us/library/windows/desktop/dd405503(v=vs.85).aspx

答案 2 :(得分:0)

要使用超过64个CPU,您必须考虑处理器组。有关详细信息,请参阅MSDN:

Processor Groups