Hardware/LPC/F718XX.cs
author moel.mich
Sat, 20 Feb 2010 19:51:10 +0000
changeset 56 5cb7eb5bf628
parent 31 c4d1fb76a9e1
child 63 1a7c13ac7348
permissions -rw-r--r--
Improved Winbond temperature reading. Temperatures create by adding PECI Agent values (delta to TCC Activation Temperature) to a (possibly uncalibrated) TBase are not read. Direct reading temperatures from sensor report register if available. Added lower bound for temperatures on Winbond chips. Nvidia GPUs are now displayed even if they do not have any sensors.
moel@16
     1
/*
moel@16
     2
  
moel@16
     3
  Version: MPL 1.1/GPL 2.0/LGPL 2.1
moel@16
     4
moel@16
     5
  The contents of this file are subject to the Mozilla Public License Version
moel@16
     6
  1.1 (the "License"); you may not use this file except in compliance with
moel@16
     7
  the License. You may obtain a copy of the License at
moel@16
     8
 
moel@16
     9
  http://www.mozilla.org/MPL/
moel@16
    10
moel@16
    11
  Software distributed under the License is distributed on an "AS IS" basis,
moel@16
    12
  WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
moel@16
    13
  for the specific language governing rights and limitations under the License.
moel@16
    14
moel@16
    15
  The Original Code is the Open Hardware Monitor code.
moel@16
    16
moel@16
    17
  The Initial Developer of the Original Code is 
moel@16
    18
  Michael Möller <m.moeller@gmx.ch>.
moel@16
    19
  Portions created by the Initial Developer are Copyright (C) 2009-2010
moel@16
    20
  the Initial Developer. All Rights Reserved.
moel@16
    21
moel@16
    22
  Contributor(s):
moel@16
    23
moel@16
    24
  Alternatively, the contents of this file may be used under the terms of
moel@16
    25
  either the GNU General Public License Version 2 or later (the "GPL"), or
moel@16
    26
  the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
moel@16
    27
  in which case the provisions of the GPL or the LGPL are applicable instead
moel@16
    28
  of those above. If you wish to allow use of your version of this file only
moel@16
    29
  under the terms of either the GPL or the LGPL, and not to allow others to
moel@16
    30
  use your version of this file under the terms of the MPL, indicate your
moel@16
    31
  decision by deleting the provisions above and replace them with the notice
moel@16
    32
  and other provisions required by the GPL or the LGPL. If you do not delete
moel@16
    33
  the provisions above, a recipient may use your version of this file under
moel@16
    34
  the terms of any one of the MPL, the GPL or the LGPL.
moel@16
    35
 
moel@16
    36
*/
moel@16
    37
moel@16
    38
using System;
moel@16
    39
using System.Collections.Generic;
moel@16
    40
using System.Drawing;
moel@16
    41
using System.Text;
moel@16
    42
moel@16
    43
namespace OpenHardwareMonitor.Hardware.LPC {
moel@31
    44
  public class F718XX : LPCHardware, IHardware {
moel@16
    45
moel@16
    46
    private ushort address;
moel@16
    47
moel@16
    48
    private Sensor[] temperatures;
moel@16
    49
    private Sensor[] fans;
moel@16
    50
    private Sensor[] voltages;
moel@16
    51
    private float[] voltageGains;
moel@16
    52
moel@16
    53
    // Hardware Monitor
moel@16
    54
    private const byte ADDRESS_REGISTER_OFFSET = 0x05;
moel@16
    55
    private const byte DATA_REGISTER_OFFSET = 0x06;
moel@16
    56
moel@16
    57
    // Hardware Monitor Registers
moel@16
    58
    private const byte VOLTAGE_BASE_REG = 0x20;
moel@16
    59
    private const byte TEMPERATURE_BASE_REG = 0x72;
moel@16
    60
    private byte[] FAN_TACHOMETER_REG = new byte[] { 0xA0, 0xB0, 0xC0, 0xD0 };
moel@16
    61
    
moel@16
    62
    private byte ReadByte(byte register) {
moel@16
    63
      WinRing0.WriteIoPortByte(
moel@16
    64
        (ushort)(address + ADDRESS_REGISTER_OFFSET), register);
moel@16
    65
      return WinRing0.ReadIoPortByte((ushort)(address + DATA_REGISTER_OFFSET));
moel@16
    66
    }
moel@16
    67
moel@31
    68
    public F718XX(Chip chip, ushort address) : base(chip) {
moel@16
    69
      this.address = address;
moel@16
    70
moel@16
    71
      temperatures = new Sensor[3];
moel@16
    72
      for (int i = 0; i < temperatures.Length; i++)
moel@16
    73
        temperatures[i] = new Sensor("Temperature #" + (i + 1), i,
moel@16
    74
          SensorType.Temperature, this);
moel@16
    75
moel@16
    76
      fans = new Sensor[4];
moel@16
    77
      for (int i = 0; i < fans.Length; i++)
moel@16
    78
        fans[i] = new Sensor("Fan #" + (i + 1), i, SensorType.Fan, this);
moel@16
    79
moel@16
    80
      voltageGains = new float[] { 1, 0.5f, 1, 1, 1, 1, 1, 1, 1 };
moel@16
    81
      voltages = new Sensor[4];
moel@16
    82
      voltages[0] = new Sensor("VCC3V", 0, SensorType.Voltage, this);
moel@16
    83
      voltages[1] = new Sensor("CPU VCore", 1, SensorType.Voltage, this);      
moel@16
    84
      voltages[2] = new Sensor("VSB3V", 7, SensorType.Voltage, this);
moel@16
    85
      voltages[3] = new Sensor("Battery", 8, SensorType.Voltage, this);
moel@16
    86
    }
moel@16
    87
moel@16
    88
    public string GetReport() {
moel@16
    89
      StringBuilder r = new StringBuilder();
moel@16
    90
moel@31
    91
      r.AppendLine("LPC " + this.GetType().Name);
moel@16
    92
      r.AppendLine();
moel@16
    93
      r.Append("Base Adress: 0x"); r.AppendLine(address.ToString("X4"));
moel@16
    94
      r.AppendLine();
moel@16
    95
      r.AppendLine("Hardware Monitor Registers");
moel@16
    96
      r.AppendLine();
moel@16
    97
moel@16
    98
      r.AppendLine("      00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F");
moel@16
    99
      r.AppendLine();
moel@16
   100
      for (int i = 0; i <= 0xF; i++) {
moel@16
   101
        r.Append(" "); r.Append((i << 4).ToString("X2")); r.Append("  ");
moel@16
   102
        for (int j = 0; j <= 0xF; j++) {
moel@16
   103
          r.Append(" ");
moel@16
   104
          r.Append(ReadByte((byte)((i << 4) | j)).ToString("X2"));
moel@16
   105
        }
moel@16
   106
        r.AppendLine();
moel@16
   107
      }
moel@16
   108
      r.AppendLine();
moel@16
   109
      return r.ToString();
moel@16
   110
    }
moel@16
   111
moel@16
   112
    public void Update() {
moel@16
   113
moel@16
   114
      foreach (Sensor sensor in voltages) {
moel@16
   115
        int value = ReadByte((byte)(VOLTAGE_BASE_REG + sensor.Index));
moel@16
   116
        sensor.Value = voltageGains[sensor.Index] * 0.001f * (value << 4);
moel@16
   117
        if (sensor.Value > 0)
moel@16
   118
          ActivateSensor(sensor);
moel@16
   119
        else
moel@16
   120
          DeactivateSensor(sensor);
moel@16
   121
      }
moel@16
   122
moel@16
   123
      foreach (Sensor sensor in temperatures) {
moel@16
   124
        sbyte value = (sbyte)ReadByte((byte)(
moel@16
   125
          TEMPERATURE_BASE_REG + 2 * sensor.Index));
moel@16
   126
        sensor.Value = value;
moel@16
   127
        if (value < sbyte.MaxValue && value > 0)
moel@16
   128
          ActivateSensor(sensor);
moel@16
   129
        else
moel@16
   130
          DeactivateSensor(sensor);
moel@16
   131
      }
moel@16
   132
moel@16
   133
      foreach (Sensor sensor in fans) {
moel@16
   134
        int value = ReadByte(FAN_TACHOMETER_REG[sensor.Index]) << 8;
moel@16
   135
        value |= ReadByte((byte)(FAN_TACHOMETER_REG[sensor.Index] + 1));
moel@16
   136
moel@16
   137
        if (value > 0) {
moel@16
   138
          sensor.Value = (value < 0x0fff) ? 1.5e6f / value : 0;
moel@34
   139
          if (sensor.Value > 0)
moel@34
   140
            ActivateSensor(sensor);
moel@16
   141
        } else {
moel@16
   142
          DeactivateSensor(sensor);
moel@16
   143
        }
moel@16
   144
      }      
moel@16
   145
    }
moel@16
   146
  }
moel@16
   147
}