Hardware/CPU/AMDCPU.cs
author moel.mich
Sun, 27 May 2012 14:23:31 +0000
changeset 344 3145aadca3d2
parent 271 8635fa73eacc
permissions -rw-r--r--
Changed the license to the Mozilla Public License 2.0 and update the licensing information.
     1 /*
     2  
     3   This Source Code Form is subject to the terms of the Mozilla Public
     4   License, v. 2.0. If a copy of the MPL was not distributed with this
     5   file, You can obtain one at http://mozilla.org/MPL/2.0/.
     6  
     7   Copyright (C) 2009-2010 Michael Möller <mmoeller@openhardwaremonitor.org>
     8 	
     9 */
    10 
    11 namespace OpenHardwareMonitor.Hardware.CPU {
    12 
    13   internal abstract class AMDCPU : GenericCPU {
    14 
    15     private const byte PCI_BUS = 0;
    16     private const byte PCI_BASE_DEVICE = 0x18;
    17     private const byte DEVICE_VENDOR_ID_REGISTER = 0;
    18     private const ushort AMD_VENDOR_ID = 0x1022;
    19 
    20     public AMDCPU(int processorIndex, CPUID[][] cpuid, ISettings settings)
    21       : base(processorIndex, cpuid, settings) { }
    22 
    23     protected uint GetPciAddress(byte function, ushort deviceId) {
    24       
    25       // assemble the pci address
    26       uint address = Ring0.GetPciAddress(PCI_BUS,
    27         (byte)(PCI_BASE_DEVICE + processorIndex), function);
    28 
    29       // verify that we have the correct bus, device and function
    30       uint deviceVendor;
    31       if (!Ring0.ReadPciConfig(
    32         address, DEVICE_VENDOR_ID_REGISTER, out deviceVendor))
    33         return Ring0.InvalidPciAddress;
    34       
    35       if (deviceVendor != (deviceId << 16 | AMD_VENDOR_ID))
    36         return Ring0.InvalidPciAddress;
    37 
    38       return address;
    39     }
    40 
    41   }
    42 }