Reading TjMax for each core on Intel Core i3/i5/i7 CPUs.
authormoel.mich
Tue, 02 Mar 2010 22:26:07 +0000
changeset 695f539c00e925
parent 68 d706e16a79c0
child 70 dc69dc4d7512
Reading TjMax for each core on Intel Core i3/i5/i7 CPUs.
Hardware/CPU/IntelCPU.cs
     1.1 --- a/Hardware/CPU/IntelCPU.cs	Tue Mar 02 20:32:24 2010 +0000
     1.2 +++ b/Hardware/CPU/IntelCPU.cs	Tue Mar 02 22:26:07 2010 +0000
     1.3 @@ -87,6 +87,13 @@
     1.4      private static extern bool GetProcessAffinityMask(IntPtr handle, 
     1.5        out IntPtr processMask, out IntPtr systemMask);
     1.6  
     1.7 +    private float[] Floats(float f) {
     1.8 +      float[] result = new float[coreCount];
     1.9 +      for (int i = 0; i < coreCount; i++)
    1.10 +        result[i] = f;
    1.11 +      return result;
    1.12 +    }
    1.13 +
    1.14      public IntelCPU(string name, uint family, uint model, uint stepping, 
    1.15        uint[,] cpuidData, uint[,] cpuidExtData) {
    1.16        
    1.17 @@ -146,7 +153,7 @@
    1.18  
    1.19        coreCount = logicalProcessors / logicalProcessorsPerCore;
    1.20  
    1.21 -      float tjMax;
    1.22 +      float[] tjMax;
    1.23        switch (family) {
    1.24          case 0x06: {
    1.25              switch (model) {
    1.26 @@ -155,53 +162,59 @@
    1.27                    case 0x06: // B2
    1.28                      switch (coreCount) {
    1.29                        case 2:
    1.30 -                        tjMax = 80 + 10; break;
    1.31 +                        tjMax = Floats(80 + 10); break;
    1.32                        case 4:
    1.33 -                        tjMax = 90 + 10; break;
    1.34 +                        tjMax = Floats(90 + 10); break;
    1.35                        default:
    1.36 -                        tjMax = 85 + 10; break;
    1.37 +                        tjMax = Floats(85 + 10); break;
    1.38                      }
    1.39 -                    tjMax = 80 + 10; break;
    1.40 +                    tjMax = Floats(80 + 10); break;
    1.41                    case 0x0B: // G0
    1.42 -                    tjMax = 90 + 10; break;
    1.43 +                    tjMax = Floats(90 + 10); break;
    1.44                    case 0x0D: // M0
    1.45 -                    tjMax = 85 + 10; break;
    1.46 +                    tjMax = Floats(85 + 10); break;
    1.47                    default:
    1.48 -                    tjMax = 85 + 10; break;
    1.49 +                    tjMax = Floats(85 + 10); break;
    1.50                  } break;
    1.51                case 0x17: // Intel Core (45nm)
    1.52 -                tjMax = 100; break;
    1.53 +                tjMax = Floats(100); break;
    1.54                case 0x1C: // Intel Atom 
    1.55 -                tjMax = 90; break;
    1.56 +                tjMax = Floats(90); break;
    1.57                case 0x1A: // Intel Core i7 LGA1366 (45nm)
    1.58                case 0x1E: // Intel Core i5, i7 LGA1156 (45nm)
    1.59                case 0x25: // Intel Core i3, i5, i7 LGA1156 (32nm)
    1.60                  uint eax, edx;
    1.61 -                if (WinRing0.Rdmsr(IA32_TEMPERATURE_TARGET, out eax, out edx)) {
    1.62 -                  tjMax = (eax >> 16) & 0xFF;
    1.63 -                } else {
    1.64 -                  tjMax = 100;
    1.65 +                tjMax = new float[coreCount];
    1.66 +                for (int i = 0; i < coreCount; i++) {
    1.67 +                  if (WinRing0.RdmsrTx(IA32_TEMPERATURE_TARGET, out eax,
    1.68 +                    out edx, (UIntPtr)(
    1.69 +                    1 << (int)(logicalProcessorsPerCore * i)))) 
    1.70 +                  {
    1.71 +                    tjMax[i] = (eax >> 16) & 0xFF;
    1.72 +                  } else {
    1.73 +                    tjMax[i] = 100;
    1.74 +                  }
    1.75                  }
    1.76                  if (WinRing0.Rdmsr(MSR_PLATFORM_INFO, out eax, out edx)) {
    1.77                    maxNehalemMultiplier = (eax >> 8) & 0xff;
    1.78                  }
    1.79                  break;
    1.80                default:
    1.81 -                tjMax = 100; break;
    1.82 +                tjMax = Floats(100); break;
    1.83              }
    1.84            } break;
    1.85 -        default: tjMax = 100; break;
    1.86 +        default: tjMax = Floats(100); break;
    1.87        }
    1.88  
    1.89        // check if processor supports a digital thermal sensor
    1.90        if (cpuidData.GetLength(0) > 6 && (cpuidData[6, 0] & 1) != 0) {
    1.91          coreTemperatures = new Sensor[coreCount];
    1.92          for (int i = 0; i < coreTemperatures.Length; i++) {
    1.93 -          coreTemperatures[i] = new Sensor(CoreString(i), i, tjMax,
    1.94 +          coreTemperatures[i] = new Sensor(CoreString(i), i, tjMax[i],
    1.95              SensorType.Temperature, this, new ParameterDescription[] { 
    1.96                new ParameterDescription(
    1.97                  "TjMax", "TjMax temperature of the core.\n" + 
    1.98 -                "Temperature = TjMax - TSlope * Value.", tjMax), 
    1.99 +                "Temperature = TjMax - TSlope * Value.", tjMax[i]), 
   1.100                new ParameterDescription(
   1.101                  "TSlope", "Temperature slope of the digital thermal sensor.\n" + 
   1.102                  "Temperature = TjMax - TSlope * Value.", 1)});