Added mainboard specific configurations for the following Gigabyte mainboards: EX58-UD3R, G41M-Combo, G41MT-S2, G41MT-S2P, GA-MA770T-UD3P, GA-MA785GM-US2H, GA-MA78LM-S2H, GA-MA790X-UD3P, H55-USB3, H55N-USB3, H61M-DS2 REV 1.2, H61M-USB3-B3 REV 2.0, H67A-USB3-B3, P55A-UD3, P67A-UD3-B3, P67A-UD3R-B3, Z68A-D3H-B3, Z68AP-D3, Z68X-UD3H-B3.
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;