mirror of https://github.com/PCSX2/pcsx2.git
parent
de24ce0a8f
commit
37de84d55f
|
@ -53,60 +53,62 @@ public:
|
||||||
// x86 CPU Capabilities Section (all boolean flags!)
|
// x86 CPU Capabilities Section (all boolean flags!)
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
u32 hasFloatingPointUnit :1;
|
union {
|
||||||
u32 hasVirtual8086ModeEnhancements :1;
|
struct {
|
||||||
u32 hasDebuggingExtensions :1;
|
u32 hasFloatingPointUnit :1;
|
||||||
u32 hasPageSizeExtensions :1;
|
u32 hasVirtual8086ModeEnhancements :1;
|
||||||
u32 hasTimeStampCounter :1;
|
u32 hasDebuggingExtensions :1;
|
||||||
u32 hasModelSpecificRegisters :1;
|
u32 hasPageSizeExtensions :1;
|
||||||
u32 hasPhysicalAddressExtension :1;
|
u32 hasTimeStampCounter :1;
|
||||||
u32 hasCOMPXCHG8BInstruction :1;
|
u32 hasModelSpecificRegisters :1;
|
||||||
u32 hasAdvancedProgrammableInterruptController :1;
|
u32 hasPhysicalAddressExtension :1;
|
||||||
u32 hasSEPFastSystemCall :1;
|
u32 hasCOMPXCHG8BInstruction :1;
|
||||||
u32 hasMemoryTypeRangeRegisters :1;
|
u32 hasAdvancedProgrammableInterruptController :1;
|
||||||
u32 hasPTEGlobalFlag :1;
|
u32 hasSEPFastSystemCall :1;
|
||||||
u32 hasMachineCheckArchitecture :1;
|
u32 hasMemoryTypeRangeRegisters :1;
|
||||||
u32 hasConditionalMoveAndCompareInstructions :1;
|
u32 hasPTEGlobalFlag :1;
|
||||||
u32 hasFGPageAttributeTable :1;
|
u32 hasMachineCheckArchitecture :1;
|
||||||
u32 has36bitPageSizeExtension :1;
|
u32 hasConditionalMoveAndCompareInstructions :1;
|
||||||
u32 hasProcessorSerialNumber :1;
|
u32 hasFGPageAttributeTable :1;
|
||||||
u32 hasCFLUSHInstruction :1;
|
u32 has36bitPageSizeExtension :1;
|
||||||
u32 hasDebugStore :1;
|
u32 hasProcessorSerialNumber :1;
|
||||||
u32 hasACPIThermalMonitorAndClockControl :1;
|
u32 hasCFLUSHInstruction :1;
|
||||||
u32 hasFastStreamingSIMDExtensionsSaveRestore :1;
|
u32 hasDebugStore :1;
|
||||||
u32 hasStreamingSIMDExtensions :1;
|
u32 hasACPIThermalMonitorAndClockControl :1;
|
||||||
u32 hasStreamingSIMD2Extensions :1;
|
u32 hasFastStreamingSIMDExtensionsSaveRestore :1;
|
||||||
u32 hasSelfSnoop :1;
|
u32 hasStreamingSIMDExtensions :1;
|
||||||
|
u32 hasStreamingSIMD2Extensions :1;
|
||||||
|
u32 hasSelfSnoop :1;
|
||||||
|
|
||||||
// is TRUE for both multi-core and Hyperthreaded CPUs.
|
// is TRUE for both multi-core and Hyperthreaded CPUs.
|
||||||
u32 hasMultiThreading :1;
|
u32 hasMultiThreading :1;
|
||||||
|
|
||||||
u32 hasThermalMonitor :1;
|
u32 hasThermalMonitor :1;
|
||||||
u32 hasIntel64BitArchitecture :1;
|
u32 hasIntel64BitArchitecture :1;
|
||||||
u32 hasStreamingSIMD3Extensions :1;
|
u32 hasStreamingSIMD3Extensions :1;
|
||||||
u32 hasSupplementalStreamingSIMD3Extensions :1;
|
u32 hasSupplementalStreamingSIMD3Extensions :1;
|
||||||
u32 hasStreamingSIMD4Extensions :1;
|
u32 hasStreamingSIMD4Extensions :1;
|
||||||
u32 hasStreamingSIMD4Extensions2 :1;
|
u32 hasStreamingSIMD4Extensions2 :1;
|
||||||
u32 hasAVX :1;
|
u32 hasAVX :1;
|
||||||
u32 hasAVX2 :1;
|
u32 hasAVX2 :1;
|
||||||
u32 hasBMI1 :1;
|
u32 hasBMI1 :1;
|
||||||
u32 hasBMI2 :1;
|
u32 hasBMI2 :1;
|
||||||
u32 hasFMA :1;
|
u32 hasFMA :1;
|
||||||
|
|
||||||
// AMD-specific CPU Features
|
// AMD-specific CPU Features
|
||||||
u32 hasAMD64BitArchitecture :1;
|
u32 hasAMD64BitArchitecture :1;
|
||||||
u32 hasStreamingSIMD4ExtensionsA :1;
|
u32 hasStreamingSIMD4ExtensionsA :1;
|
||||||
|
};
|
||||||
|
|
||||||
|
u32 AllCapabilities;
|
||||||
|
};
|
||||||
|
|
||||||
// Core Counts!
|
// Core Counts!
|
||||||
u32 PhysicalCores;
|
u32 PhysicalCores;
|
||||||
u32 LogicalCores;
|
u32 LogicalCores;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
x86capabilities()
|
x86capabilities();
|
||||||
{
|
|
||||||
isIdentified = false;
|
|
||||||
VendorID = x86Vendor_Unknown;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Identify();
|
void Identify();
|
||||||
void CountCores();
|
void CountCores();
|
||||||
|
|
|
@ -24,6 +24,26 @@ __aligned16 x86capabilities x86caps;
|
||||||
// Recompiled code buffer for SSE and MXCSR feature testing.
|
// Recompiled code buffer for SSE and MXCSR feature testing.
|
||||||
static __pagealigned u8 targetFXSAVE[512];
|
static __pagealigned u8 targetFXSAVE[512];
|
||||||
|
|
||||||
|
x86capabilities::x86capabilities() :
|
||||||
|
isIdentified(false),
|
||||||
|
VendorID(x86Vendor_Unknown),
|
||||||
|
FamilyID(0),
|
||||||
|
Model(0),
|
||||||
|
TypeID(0),
|
||||||
|
StepID(0),
|
||||||
|
Flags(0),
|
||||||
|
Flags2(0),
|
||||||
|
EFlags(0),
|
||||||
|
EFlags2(0),
|
||||||
|
SEFlag(0),
|
||||||
|
AllCapabilities(0),
|
||||||
|
PhysicalCores(0),
|
||||||
|
LogicalCores(0)
|
||||||
|
{
|
||||||
|
memzero(VendorName);
|
||||||
|
memzero(FamilyName);
|
||||||
|
}
|
||||||
|
|
||||||
// Warning! We've had problems with the MXCSR detection code causing stack corruption in
|
// Warning! We've had problems with the MXCSR detection code causing stack corruption in
|
||||||
// MSVC PGO builds. The problem was fixed when I moved the MXCSR code to this function, and
|
// MSVC PGO builds. The problem was fixed when I moved the MXCSR code to this function, and
|
||||||
// moved the recSSE[] array to a global static (it was local to cpudetectInit). Commented
|
// moved the recSSE[] array to a global static (it was local to cpudetectInit). Commented
|
||||||
|
|
Loading…
Reference in New Issue