Replaced the direct reference to the Mono.Posix assembly with reflection.
authormoel.mich
Thu, 04 Nov 2010 21:46:14 +0000
changeset 23991800d0f54de
parent 238 bddc6e01840a
child 240 631ab73d1ae1
Replaced the direct reference to the Mono.Posix assembly with reflection.
Hardware/Opcode.cs
OpenHardwareMonitorLib.csproj
     1.1 --- a/Hardware/Opcode.cs	Wed Nov 03 22:07:46 2010 +0000
     1.2 +++ b/Hardware/Opcode.cs	Thu Nov 04 21:46:14 2010 +0000
     1.3 @@ -37,7 +37,7 @@
     1.4  
     1.5  using System;
     1.6  using System.Runtime.InteropServices;
     1.7 -using Mono.Unix.Native;
     1.8 +using System.Reflection;
     1.9  
    1.10  namespace OpenHardwareMonitor.Hardware {
    1.11    internal static class Opcode {
    1.12 @@ -64,11 +64,28 @@
    1.13        }
    1.14        
    1.15        size = (ulong)(rdtscCode.Length + cpuidCode.Length);
    1.16 -      
    1.17 -      if ((p == 4) || (p == 128)) { // Unix
    1.18 -        codeBuffer = Syscall.mmap(IntPtr.Zero, size, 
    1.19 -          MmapProts.PROT_READ | MmapProts.PROT_WRITE | MmapProts.PROT_EXEC, 
    1.20 -          MmapFlags.MAP_ANONYMOUS | MmapFlags.MAP_PRIVATE, -1, 0);
    1.21 +
    1.22 +      if ((p == 4) || (p == 128)) { // Unix   
    1.23 +        Assembly assembly = 
    1.24 +          Assembly.Load("Mono.Posix, Version=2.0.0.0, Culture=neutral, " +
    1.25 +          "PublicKeyToken=0738eb9f132ed756");
    1.26 +
    1.27 +        Type syscall = assembly.GetType("Mono.Unix.Native.Syscall");
    1.28 +        MethodInfo mmap = syscall.GetMethod("mmap");
    1.29 +
    1.30 +        Type mmapProts = assembly.GetType("Mono.Unix.Native.MmapProts");
    1.31 +        object mmapProtsParam = Enum.ToObject(mmapProts,
    1.32 +          (int)mmapProts.GetField("PROT_READ").GetValue(null) |
    1.33 +          (int)mmapProts.GetField("PROT_WRITE").GetValue(null) |
    1.34 +          (int)mmapProts.GetField("PROT_EXEC").GetValue(null));
    1.35 +
    1.36 +        Type mmapFlags = assembly.GetType("Mono.Unix.Native.MmapFlags");
    1.37 +        object mmapFlagsParam = Enum.ToObject(mmapFlags,
    1.38 +          (int)mmapFlags.GetField("MAP_ANONYMOUS").GetValue(null) |
    1.39 +          (int)mmapFlags.GetField("MAP_PRIVATE").GetValue(null));
    1.40 +        
    1.41 +        codeBuffer = (IntPtr)mmap.Invoke(null, new object[] { IntPtr.Zero, 
    1.42 +          size, mmapProtsParam, mmapFlagsParam, -1, 0 });        
    1.43        } else { // Windows
    1.44          codeBuffer = NativeMethods.VirtualAlloc(IntPtr.Zero,
    1.45            (UIntPtr)size, AllocationType.COMMIT | AllocationType.RESERVE, 
    1.46 @@ -93,7 +110,14 @@
    1.47        
    1.48        int p = (int)Environment.OSVersion.Platform;
    1.49        if ((p == 4) || (p == 128)) { // Unix
    1.50 -        Syscall.munmap(codeBuffer, size);
    1.51 +        Assembly assembly =
    1.52 +          Assembly.Load("Mono.Posix, Version=2.0.0.0, Culture=neutral, " +
    1.53 +          "PublicKeyToken=0738eb9f132ed756");
    1.54 +
    1.55 +        Type syscall = assembly.GetType("Mono.Unix.Native.Syscall");
    1.56 +        MethodInfo munmap = syscall.GetMethod("munmap");
    1.57 +        munmap.Invoke(null, new object[] { codeBuffer, size });
    1.58 +
    1.59        } else { // Windows
    1.60          NativeMethods.VirtualFree(codeBuffer, UIntPtr.Zero, 
    1.61            FreeType.RELEASE);        
    1.62 @@ -246,7 +270,7 @@
    1.63      }
    1.64  
    1.65      [Flags]
    1.66 -    enum FreeType {
    1.67 +    public enum FreeType {
    1.68        DECOMMIT = 0x4000,
    1.69        RELEASE = 0x8000
    1.70      }
     2.1 --- a/OpenHardwareMonitorLib.csproj	Wed Nov 03 22:07:46 2010 +0000
     2.2 +++ b/OpenHardwareMonitorLib.csproj	Thu Nov 04 21:46:14 2010 +0000
     2.3 @@ -1,4 +1,4 @@
     2.4 -<?xml version="1.0" encoding="utf-8"?>
     2.5 +<?xml version="1.0" encoding="utf-8"?>
     2.6  <Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
     2.7    <PropertyGroup>
     2.8      <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
     2.9 @@ -54,7 +54,6 @@
    2.10    <ItemGroup>
    2.11      <Reference Include="System" />
    2.12      <Reference Include="System.Management" />
    2.13 -    <Reference Include="Mono.Posix" />
    2.14    </ItemGroup>
    2.15    <ItemGroup>
    2.16      <Compile Include="Hardware\ATI\ADL.cs" />