Changed the RAM implementation (removed Microsoft.VisualBasic dependency which is not implemented in Mono) and added code to prevent RAM hardware from loading on Linux.
     1.1 --- a/Hardware/RAM/GenericRAM.cs	Tue Jul 24 16:04:30 2012 +0000
     1.2 +++ b/Hardware/RAM/GenericRAM.cs	Tue Jul 24 16:45:48 2012 +0000
     1.3 @@ -8,7 +8,7 @@
     1.4  	
     1.5  */
     1.6  
     1.7 -using Microsoft.VisualBasic.Devices;
     1.8 +using System.Runtime.InteropServices;
     1.9  
    1.10  namespace OpenHardwareMonitor.Hardware.RAM {
    1.11    internal class GenericRAM : Hardware {
    1.12 @@ -16,16 +16,14 @@
    1.13      private Sensor loadSensor;
    1.14      private Sensor availableMemory;
    1.15  
    1.16 -    private ComputerInfo computerInfo;
    1.17 -
    1.18      public GenericRAM(string name, ISettings settings)
    1.19        : base(name, new Identifier("ram"), settings)
    1.20      {   
    1.21 -      computerInfo = new ComputerInfo();
    1.22        loadSensor = new Sensor("Memory", 0, SensorType.Load, this, settings);
    1.23        ActivateSensor(loadSensor);
    1.24  
    1.25 -      availableMemory = new Sensor("Available Memory", 0, SensorType.Data, this, settings);
    1.26 +      availableMemory = new Sensor("Available Memory", 0, SensorType.Data, this, 
    1.27 +        settings);
    1.28        ActivateSensor(availableMemory);
    1.29      }
    1.30  
    1.31 @@ -36,12 +34,39 @@
    1.32      }
    1.33  
    1.34      public override void Update() {
    1.35 -      loadSensor.Value = 100.0f - 
    1.36 -        (100.0f * computerInfo.AvailablePhysicalMemory) / 
    1.37 -        computerInfo.TotalPhysicalMemory;
    1.38 +      NativeMethods.MemoryStatusEx status = new NativeMethods.MemoryStatusEx();
    1.39 +      status.Length = checked((uint)Marshal.SizeOf(
    1.40 +          typeof(NativeMethods.MemoryStatusEx)));
    1.41  
    1.42 -      availableMemory.Value = (float)computerInfo.AvailablePhysicalMemory /
    1.43 +      if (!NativeMethods.GlobalMemoryStatusEx(ref status))
    1.44 +        return;
    1.45 +
    1.46 +      loadSensor.Value = 100.0f -
    1.47 +        (100.0f * status.AvailablePhysicalMemory) /
    1.48 +        status.TotalPhysicalMemory;
    1.49 +
    1.50 +      availableMemory.Value = (float)status.AvailablePhysicalMemory /
    1.51          (1024 * 1024 * 1024);
    1.52      }
    1.53 +
    1.54 +    private class NativeMethods {
    1.55 +      [StructLayout(LayoutKind.Sequential)]
    1.56 +      public struct MemoryStatusEx {
    1.57 +        public uint Length;
    1.58 +        public uint MemoryLoad;
    1.59 +        public ulong TotalPhysicalMemory;
    1.60 +        public ulong AvailablePhysicalMemory;
    1.61 +        public ulong TotalPageFile;
    1.62 +        public ulong AvailPageFile;
    1.63 +        public ulong TotalVirtual;
    1.64 +        public ulong AvailVirtual;
    1.65 +        public ulong AvailExtendedVirtual;
    1.66 +      }
    1.67 +
    1.68 +      [DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
    1.69 +      [return: MarshalAs(UnmanagedType.Bool)]
    1.70 +      internal static extern bool GlobalMemoryStatusEx(
    1.71 +        ref NativeMethods.MemoryStatusEx buffer);
    1.72 +    }
    1.73    }
    1.74  }
     2.1 --- a/Hardware/RAM/RAMGroup.cs	Tue Jul 24 16:04:30 2012 +0000
     2.2 +++ b/Hardware/RAM/RAMGroup.cs	Tue Jul 24 16:45:48 2012 +0000
     2.3 @@ -8,12 +8,22 @@
     2.4  	
     2.5  */
     2.6  
     2.7 +using System;
     2.8 +
     2.9  namespace OpenHardwareMonitor.Hardware.RAM {
    2.10    internal class RAMGroup : IGroup {
    2.11  
    2.12      private IHardware[] hardware;
    2.13  
    2.14      public RAMGroup(SMBIOS smbios, ISettings settings) {
    2.15 +
    2.16 +      // No implementation for RAM on Unix systems
    2.17 +      int p = (int)Environment.OSVersion.Platform;
    2.18 +      if ((p == 4) || (p == 128)) {
    2.19 +        hardware = new IHardware[0];
    2.20 +        return;
    2.21 +      }
    2.22 +
    2.23        string name;
    2.24        if (smbios.MemoryDevices.Length > 0) {
    2.25          name = smbios.MemoryDevices[0].ManufacturerName + " " + 
     3.1 --- a/OpenHardwareMonitorLib.csproj	Tue Jul 24 16:04:30 2012 +0000
     3.2 +++ b/OpenHardwareMonitorLib.csproj	Tue Jul 24 16:45:48 2012 +0000
     3.3 @@ -52,7 +52,6 @@
     3.4      <CodeAnalysisRuleSet>AllRules.ruleset</CodeAnalysisRuleSet>
     3.5    </PropertyGroup>
     3.6    <ItemGroup>
     3.7 -    <Reference Include="Microsoft.VisualBasic" />
     3.8      <Reference Include="System" />
     3.9      <Reference Include="System.Management" />
    3.10    </ItemGroup>