Hardware/Computer.cs
author moel.mich
Sun, 31 Oct 2010 22:08:47 +0000
changeset 236 763675f19ff4
parent 195 0ee888c485d5
child 254 d8079800a888
permissions -rw-r--r--
Replaced the non-kernel code of WinRing0 with a managed implementation. The new implementation should fix Issue 32 and simplify further work on Issue 46.
moel@28
     1
/*
moel@28
     2
  
moel@28
     3
  Version: MPL 1.1/GPL 2.0/LGPL 2.1
moel@28
     4
moel@28
     5
  The contents of this file are subject to the Mozilla Public License Version
moel@28
     6
  1.1 (the "License"); you may not use this file except in compliance with
moel@28
     7
  the License. You may obtain a copy of the License at
moel@28
     8
 
moel@28
     9
  http://www.mozilla.org/MPL/
moel@28
    10
moel@28
    11
  Software distributed under the License is distributed on an "AS IS" basis,
moel@28
    12
  WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
moel@28
    13
  for the specific language governing rights and limitations under the License.
moel@28
    14
moel@28
    15
  The Original Code is the Open Hardware Monitor code.
moel@28
    16
moel@28
    17
  The Initial Developer of the Original Code is 
moel@28
    18
  Michael Möller <m.moeller@gmx.ch>.
moel@28
    19
  Portions created by the Initial Developer are Copyright (C) 2009-2010
moel@28
    20
  the Initial Developer. All Rights Reserved.
moel@28
    21
moel@28
    22
  Contributor(s):
moel@28
    23
moel@28
    24
  Alternatively, the contents of this file may be used under the terms of
moel@28
    25
  either the GNU General Public License Version 2 or later (the "GPL"), or
moel@28
    26
  the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
moel@28
    27
  in which case the provisions of the GPL or the LGPL are applicable instead
moel@28
    28
  of those above. If you wish to allow use of your version of this file only
moel@28
    29
  under the terms of either the GPL or the LGPL, and not to allow others to
moel@28
    30
  use your version of this file under the terms of the MPL, indicate your
moel@28
    31
  decision by deleting the provisions above and replace them with the notice
moel@28
    32
  and other provisions required by the GPL or the LGPL. If you do not delete
moel@28
    33
  the provisions above, a recipient may use your version of this file under
moel@28
    34
  the terms of any one of the MPL, the GPL or the LGPL.
moel@28
    35
 
moel@28
    36
*/
moel@28
    37
moel@28
    38
using System;
moel@28
    39
using System.Collections.Generic;
moel@182
    40
using System.Globalization;
moel@28
    41
using System.IO;
moel@167
    42
using System.Security.Permissions;
moel@236
    43
using System.Reflection;
moel@167
    44
moel@28
    45
namespace OpenHardwareMonitor.Hardware {
moel@28
    46
moel@83
    47
  public class Computer : IComputer {
moel@28
    48
moel@195
    49
    private readonly List<IGroup> groups = new List<IGroup>();
moel@195
    50
    private readonly ISettings settings;
moel@28
    51
moel@195
    52
    private bool open;
moel@195
    53
    private bool hddEnabled;    
moel@28
    54
moel@165
    55
    public Computer() {
moel@165
    56
      this.settings = new Settings();
moel@165
    57
    }
moel@165
    58
moel@165
    59
    public Computer(ISettings settings) {
moel@195
    60
      this.settings = settings ?? new Settings();
moel@165
    61
    }
moel@28
    62
moel@28
    63
    private void Add(IGroup group) {
moel@28
    64
      if (groups.Contains(group))
moel@28
    65
        return;
moel@28
    66
moel@28
    67
      groups.Add(group);
moel@28
    68
moel@28
    69
      if (HardwareAdded != null)
moel@83
    70
        foreach (IHardware hardware in group.Hardware)
moel@28
    71
          HardwareAdded(hardware);
moel@28
    72
    }
moel@28
    73
moel@28
    74
    private void Remove(IGroup group) {
moel@28
    75
      if (!groups.Contains(group))
moel@28
    76
        return;
moel@28
    77
moel@28
    78
      groups.Remove(group);
moel@28
    79
moel@28
    80
      if (HardwareRemoved != null)
moel@83
    81
        foreach (IHardware hardware in group.Hardware)
moel@28
    82
          HardwareRemoved(hardware);
moel@28
    83
    }
moel@28
    84
moel@167
    85
    [SecurityPermission(SecurityAction.LinkDemand, UnmanagedCode = true)]
moel@28
    86
    public void Open() {
moel@28
    87
      if (open)
moel@28
    88
        return;
moel@28
    89
moel@236
    90
      Ring0.Open();
moel@236
    91
      Opcode.Open();
moel@167
    92
moel@165
    93
      Add(new Mainboard.MainboardGroup(settings));
moel@165
    94
      Add(new CPU.CPUGroup(settings));
moel@165
    95
      Add(new ATI.ATIGroup(settings));
moel@171
    96
      Add(new Nvidia.NvidiaGroup(settings));      
moel@165
    97
      Add(new TBalancer.TBalancerGroup(settings));
moel@171
    98
      Add(new Heatmaster.HeatmasterGroup(settings));
moel@28
    99
moel@83
   100
      if (hddEnabled)
moel@165
   101
        Add(new HDD.HDDGroup(settings));
moel@28
   102
moel@28
   103
      open = true;
moel@28
   104
    }
moel@167
   105
    
moel@28
   106
    public bool HDDEnabled {
moel@28
   107
      get { return hddEnabled; }
moel@167
   108
moel@167
   109
      [SecurityPermission(SecurityAction.LinkDemand, UnmanagedCode = true)]
moel@28
   110
      set {
moel@28
   111
        if (open && value && !hddEnabled) {
moel@165
   112
          Add(new HDD.HDDGroup(settings));
moel@28
   113
        } else if (open && !value && hddEnabled) {
moel@28
   114
          List<IGroup> list = new List<IGroup>();
moel@28
   115
          foreach (IGroup group in groups)
moel@28
   116
            if (group is HDD.HDDGroup)
moel@28
   117
              list.Add(group);
moel@28
   118
          foreach (IGroup group in list)
moel@83
   119
            Remove(group);
moel@28
   120
        }
moel@28
   121
        hddEnabled = value;
moel@28
   122
      }
moel@28
   123
    }
moel@28
   124
moel@83
   125
    public IHardware[] Hardware {
moel@83
   126
      get {
moel@83
   127
        List<IHardware> list = new List<IHardware>();
moel@28
   128
        foreach (IGroup group in groups)
moel@28
   129
          foreach (IHardware hardware in group.Hardware)
moel@83
   130
            list.Add(hardware);
moel@83
   131
        return list.ToArray();
moel@28
   132
      }
moel@28
   133
    }
moel@28
   134
moel@167
   135
    private static void NewSection(TextWriter writer) {
moel@28
   136
      for (int i = 0; i < 8; i++)
moel@28
   137
        writer.Write("----------");
moel@28
   138
      writer.WriteLine();
moel@28
   139
      writer.WriteLine();
moel@28
   140
    }
moel@28
   141
moel@195
   142
    private static int CompareSensor(ISensor a, ISensor b) {
moel@149
   143
      int c = a.SensorType.CompareTo(b.SensorType);
moel@149
   144
      if (c == 0)
moel@149
   145
        return a.Index.CompareTo(b.Index);
moel@149
   146
      else
moel@149
   147
        return c;
moel@149
   148
    }
moel@149
   149
moel@195
   150
    private static void ReportHardwareSensorTree(
moel@195
   151
      IHardware hardware, TextWriter w, string space) 
moel@195
   152
    {
moel@64
   153
      w.WriteLine("{0}|", space);
moel@83
   154
      w.WriteLine("{0}+-+ {1} ({2})",
moel@64
   155
        space, hardware.Name, hardware.Identifier);
moel@149
   156
      ISensor[] sensors = hardware.Sensors;
moel@195
   157
      Array.Sort(sensors, CompareSensor);
moel@149
   158
      foreach (ISensor sensor in sensors) {
moel@149
   159
        w.WriteLine("{0}|   +- {1}[{2}] : {3} : {4}",
moel@149
   160
          space, sensor.SensorType, sensor.Index, 
moel@64
   161
            string.Format(CultureInfo.InvariantCulture, "{0} : {1} : {2}",
moel@149
   162
            sensor.Value, sensor.Min, sensor.Max), sensor.Name);
moel@149
   163
      }
moel@149
   164
      foreach (IHardware subHardware in hardware.SubHardware)
moel@149
   165
        ReportHardwareSensorTree(subHardware, w, "|   ");
moel@149
   166
    }
moel@149
   167
moel@195
   168
    private static void ReportHardwareParameterTree(
moel@195
   169
      IHardware hardware, TextWriter w, string space) 
moel@195
   170
    {
moel@149
   171
      w.WriteLine("{0}|", space);
moel@149
   172
      w.WriteLine("{0}+-+ {1} ({2})",
moel@149
   173
        space, hardware.Name, hardware.Identifier);
moel@149
   174
      ISensor[] sensors = hardware.Sensors;
moel@195
   175
      Array.Sort(sensors, CompareSensor);
moel@149
   176
      foreach (ISensor sensor in sensors) {
moel@149
   177
        if (sensor.Parameters.Length > 0) {
moel@149
   178
          w.WriteLine("{0}|   +- {1}[{2}] : {3}",
moel@149
   179
            space, sensor.SensorType, sensor.Index, sensor.Name);
moel@149
   180
          foreach (IParameter parameter in sensor.Parameters) {
moel@149
   181
            w.WriteLine("{0}|      +- {1} : {2}",
moel@149
   182
              space, parameter.Name,
moel@149
   183
              string.Format(CultureInfo.InvariantCulture, "{0} : {1}",
moel@149
   184
                parameter.DefaultValue, parameter.Value));
moel@149
   185
          }
moel@64
   186
        }
moel@64
   187
      }
moel@64
   188
      foreach (IHardware subHardware in hardware.SubHardware)
moel@149
   189
        ReportHardwareParameterTree(subHardware, w, "|   ");
moel@64
   190
    }
moel@64
   191
moel@195
   192
    private static void ReportHardware(IHardware hardware, TextWriter w) {
moel@64
   193
      string hardwareReport = hardware.GetReport();
moel@167
   194
      if (!string.IsNullOrEmpty(hardwareReport)) {
moel@64
   195
        NewSection(w);
moel@64
   196
        w.Write(hardwareReport);
moel@64
   197
      }
moel@64
   198
      foreach (IHardware subHardware in hardware.SubHardware)
moel@64
   199
        ReportHardware(subHardware, w);
moel@64
   200
    }
moel@64
   201
moel@83
   202
    public string GetReport() {
moel@28
   203
moel@166
   204
      using (StringWriter w = new StringWriter(CultureInfo.InvariantCulture)) {
moel@28
   205
moel@28
   206
        w.WriteLine();
moel@28
   207
        w.WriteLine("Open Hardware Monitor Report");
moel@28
   208
        w.WriteLine();
moel@28
   209
moel@83
   210
        Version version = typeof(Computer).Assembly.GetName().Version;
moel@83
   211
moel@28
   212
        NewSection(w);
moel@28
   213
        w.Write("Version: "); w.WriteLine(version.ToString());
moel@28
   214
        w.WriteLine();
moel@28
   215
moel@28
   216
        NewSection(w);
moel@119
   217
        w.Write("Common Language Runtime: ");
moel@119
   218
        w.WriteLine(Environment.Version.ToString());
moel@119
   219
        w.Write("Operating System: ");
moel@119
   220
        w.WriteLine(Environment.OSVersion.ToString());
moel@119
   221
        w.Write("Process Type: ");
moel@119
   222
        w.WriteLine(IntPtr.Size == 4 ? "32-Bit" : "64-Bit");
moel@119
   223
        w.WriteLine();
moel@119
   224
moel@119
   225
        NewSection(w);
moel@149
   226
        w.WriteLine("Sensors");
moel@149
   227
        w.WriteLine();
moel@28
   228
        foreach (IGroup group in groups) {
moel@64
   229
          foreach (IHardware hardware in group.Hardware)
moel@149
   230
            ReportHardwareSensorTree(hardware, w, "");
moel@149
   231
        }
moel@149
   232
        w.WriteLine();
moel@149
   233
moel@149
   234
        NewSection(w);
moel@149
   235
        w.WriteLine("Parameters");
moel@149
   236
        w.WriteLine();
moel@149
   237
        foreach (IGroup group in groups) {
moel@149
   238
          foreach (IHardware hardware in group.Hardware)
moel@149
   239
            ReportHardwareParameterTree(hardware, w, "");
moel@28
   240
        }
moel@28
   241
        w.WriteLine();
moel@28
   242
moel@28
   243
        foreach (IGroup group in groups) {
moel@28
   244
          string report = group.GetReport();
moel@167
   245
          if (!string.IsNullOrEmpty(report)) {
moel@28
   246
            NewSection(w);
moel@28
   247
            w.Write(report);
moel@28
   248
          }
moel@28
   249
moel@28
   250
          IHardware[] hardwareArray = group.Hardware;
moel@64
   251
          foreach (IHardware hardware in hardwareArray)
moel@64
   252
            ReportHardware(hardware, w);
moel@83
   253
moel@28
   254
        }
moel@83
   255
        return w.ToString();
moel@28
   256
      }
moel@28
   257
    }
moel@28
   258
moel@83
   259
    public void Close() {      
moel@28
   260
      if (!open)
moel@28
   261
        return;
moel@28
   262
moel@28
   263
      foreach (IGroup group in groups)
moel@28
   264
        group.Close();
moel@28
   265
      groups.Clear();
moel@28
   266
moel@236
   267
      Opcode.Close();
moel@236
   268
      Ring0.Close();
moel@167
   269
moel@28
   270
      open = false;
moel@28
   271
    }
moel@28
   272
moel@28
   273
    public event HardwareEventHandler HardwareAdded;
moel@28
   274
    public event HardwareEventHandler HardwareRemoved;
moel@110
   275
moel@110
   276
    public void Accept(IVisitor visitor) {
moel@167
   277
      if (visitor == null)
moel@167
   278
        throw new ArgumentNullException("visitor");
moel@167
   279
      visitor.VisitComputer(this);
moel@110
   280
    }
moel@110
   281
moel@110
   282
    public void Traverse(IVisitor visitor) {
moel@110
   283
      foreach (IGroup group in groups)
moel@110
   284
        foreach (IHardware hardware in group.Hardware) 
moel@110
   285
          hardware.Accept(visitor);
moel@110
   286
    }
moel@165
   287
moel@165
   288
    private class Settings : ISettings {
moel@165
   289
moel@165
   290
      public bool Contains(string name) {
moel@165
   291
        return false;
moel@165
   292
      }
moel@165
   293
moel@166
   294
      public void SetValue(string name, string value) { }
moel@165
   295
moel@166
   296
      public string GetValue(string name, string value) {
moel@165
   297
        return value;
moel@165
   298
      }
moel@165
   299
moel@165
   300
      public void Remove(string name) { }
moel@165
   301
    }
moel@28
   302
  }
moel@28
   303
}