2015-08-12 14:42:13 -07:00
|
|
|
// Copyright 2013 Dolphin Emulator Project / 2015 Citra Emulator Project
|
2014-12-16 21:38:14 -08:00
|
|
|
// Licensed under GPLv2 or any later version
|
2013-09-04 17:17:46 -07:00
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
2014-08-17 10:45:50 -07:00
|
|
|
#pragma once
|
2013-09-04 17:17:46 -07:00
|
|
|
|
2015-07-21 16:49:33 -07:00
|
|
|
namespace Common {
|
|
|
|
|
2020-02-09 12:53:22 -08:00
|
|
|
enum class Manufacturer : u32 {
|
|
|
|
Intel = 0,
|
|
|
|
AMD = 1,
|
|
|
|
Hygon = 2,
|
|
|
|
Unknown = 3,
|
|
|
|
};
|
|
|
|
|
2015-08-12 14:42:13 -07:00
|
|
|
/// x86/x64 CPU capabilities that may be detected by this module
|
|
|
|
struct CPUCaps {
|
2020-02-09 12:53:22 -08:00
|
|
|
Manufacturer manufacturer;
|
2014-04-01 15:20:08 -07:00
|
|
|
char cpu_string[0x21];
|
|
|
|
char brand_string[0x41];
|
2015-08-12 14:42:13 -07:00
|
|
|
bool sse;
|
|
|
|
bool sse2;
|
|
|
|
bool sse3;
|
|
|
|
bool ssse3;
|
|
|
|
bool sse4_1;
|
|
|
|
bool sse4_2;
|
|
|
|
bool lzcnt;
|
|
|
|
bool avx;
|
|
|
|
bool avx2;
|
2020-05-16 04:24:57 -07:00
|
|
|
bool avx512;
|
2015-08-12 14:42:13 -07:00
|
|
|
bool bmi1;
|
|
|
|
bool bmi2;
|
|
|
|
bool fma;
|
|
|
|
bool fma4;
|
|
|
|
bool aes;
|
2020-02-09 12:53:22 -08:00
|
|
|
bool invariant_tsc;
|
|
|
|
u32 base_frequency;
|
|
|
|
u32 max_frequency;
|
|
|
|
u32 bus_frequency;
|
2013-09-04 17:17:46 -07:00
|
|
|
};
|
|
|
|
|
2015-08-12 14:42:13 -07:00
|
|
|
/**
|
|
|
|
* Gets the supported capabilities of the host CPU
|
|
|
|
* @return Reference to a CPUCaps struct with the detected host CPU capabilities
|
|
|
|
*/
|
|
|
|
const CPUCaps& GetCPUCaps();
|
|
|
|
|
2015-07-21 16:49:33 -07:00
|
|
|
} // namespace Common
|