3 Version: MPL 1.1/GPL 2.0/LGPL 2.1
5 The contents of this file are subject to the Mozilla Public License Version
6 1.1 (the "License"); you may not use this file except in compliance with
7 the License. You may obtain a copy of the License at
9 http://www.mozilla.org/MPL/
11 Software distributed under the License is distributed on an "AS IS" basis,
12 WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
13 for the specific language governing rights and limitations under the License.
15 The Original Code is the Open Hardware Monitor code.
17 The Initial Developer of the Original Code is
18 Michael Möller <m.moeller@gmx.ch>.
19 Portions created by the Initial Developer are Copyright (C) 2009-2010
20 the Initial Developer. All Rights Reserved.
22 Contributor(s): Paul Werelds
24 Alternatively, the contents of this file may be used under the terms of
25 either the GNU General Public License Version 2 or later (the "GPL"), or
26 the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
27 in which case the provisions of the GPL or the LGPL are applicable instead
28 of those above. If you wish to allow use of your version of this file only
29 under the terms of either the GPL or the LGPL, and not to allow others to
30 use your version of this file under the terms of the MPL, indicate your
31 decision by deleting the provisions above and replace them with the notice
32 and other provisions required by the GPL or the LGPL. If you do not delete
33 the provisions above, a recipient may use your version of this file under
34 the terms of any one of the MPL, the GPL or the LGPL.
39 using System.Collections.Generic;
40 using System.Globalization;
42 namespace OpenHardwareMonitor.Hardware.HDD {
43 internal class HDD : IHardware {
45 private const int UPDATE_DIVIDER = 30; // update only every 30s
47 private readonly string name;
48 private readonly IntPtr handle;
49 private readonly int drive;
52 private readonly SMART.AttributeID temperatureID = 0x00;
53 private readonly SMART.SSDLifeID lifeID = 0x00;
55 private readonly Sensor temperatureSensor;
56 private readonly Sensor lifeSensor;
58 public HDD(string name, IntPtr handle, int drive,
59 SMART.AttributeID temperatureID, ISettings settings)
65 this.temperatureID = temperatureID;
66 this.temperatureSensor = new Sensor("HDD", 0, SensorType.Temperature,
72 public HDD(string name, IntPtr handle, int drive, SMART.SSDLifeID lifeID,
80 this.lifeSensor = new Sensor("HDD", 0, SensorType.Level, this, settings);
89 public Identifier Identifier {
91 return new Identifier("hdd",
92 drive.ToString(CultureInfo.InvariantCulture));
96 public HardwareType HardwareType {
97 get { return HardwareType.HDD; }
100 public IHardware[] SubHardware {
101 get { return new IHardware[0]; }
104 public virtual IHardware Parent {
108 public ISensor[] Sensors {
110 if (lifeID != SMART.SSDLifeID.None)
111 return new ISensor[] { lifeSensor };
113 if (temperatureID != 0x00)
114 return new ISensor[] { temperatureSensor };
116 return new ISensor[] {};
120 public string GetReport() {
124 public void Update() {
126 List<SMART.DriveAttribute> attributes = SMART.ReadSmart(handle, drive);
127 if (temperatureID != 0x00 &&
128 attributes.Exists(attr => (int)attr.ID == (int)temperatureID))
130 temperatureSensor.Value = attributes
131 .Find(attr => (int)attr.ID == (int)temperatureID)
135 if (lifeID != 0x00 &&
136 attributes.Exists(attr => (int)attr.ID == (int)lifeID))
138 lifeSensor.Value = attributes
139 .Find(attr => (int)attr.ID == (int)temperatureID)
143 if (temperatureID != 0x00) {
144 temperatureSensor.Value = temperatureSensor.Value;
147 if (lifeID != 0x00) {
148 lifeSensor.Value = lifeSensor.Value;
152 count++; count %= UPDATE_DIVIDER;
155 public void Close() {
156 SMART.CloseHandle(handle);
159 #pragma warning disable 67
160 public event SensorEventHandler SensorAdded;
161 public event SensorEventHandler SensorRemoved;
162 #pragma warning restore 67
164 public void Accept(IVisitor visitor) {
166 throw new ArgumentNullException("visitor");
167 visitor.VisitHardware(this);
170 public void Traverse(IVisitor visitor) { }