Updated the version.
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/.
7 Copyright (C) 2009-2010 Michael Möller <mmoeller@openhardwaremonitor.org>
11 namespace OpenHardwareMonitor.Hardware.CPU {
13 internal abstract class AMDCPU : GenericCPU {
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;
20 public AMDCPU(int processorIndex, CPUID[][] cpuid, ISettings settings)
21 : base(processorIndex, cpuid, settings) { }
23 protected uint GetPciAddress(byte function, ushort deviceId) {
25 // assemble the pci address
26 uint address = Ring0.GetPciAddress(PCI_BUS,
27 (byte)(PCI_BASE_DEVICE + processorIndex), function);
29 // verify that we have the correct bus, device and function
31 if (!Ring0.ReadPciConfig(
32 address, DEVICE_VENDOR_ID_REGISTER, out deviceVendor))
33 return Ring0.InvalidPciAddress;
35 if (deviceVendor != (deviceId << 16 | AMD_VENDOR_ID))
36 return Ring0.InvalidPciAddress;