2022-04-23 03:59:50 -05:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
|
|
|
|
// SPDX-FileCopyrightText: Copyright 2013 Dolphin Emulator Project / 2015 Citra Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2013-09-04 19:17:46 -05:00
|
|
|
|
2014-08-17 12:45:50 -05:00
|
|
|
#pragma once
|
2013-09-04 19:17:46 -05:00
|
|
|
|
2022-02-23 21:41:27 -06:00
|
|
|
#include <string_view>
|
2022-02-23 12:17:47 -06:00
|
|
|
#include "common/common_types.h"
|
|
|
|
|
2015-07-21 18:49:33 -05:00
|
|
|
namespace Common {
|
|
|
|
|
2015-08-12 16:42:13 -05:00
|
|
|
/// x86/x64 CPU capabilities that may be detected by this module
|
|
|
|
struct CPUCaps {
|
2022-02-23 21:41:27 -06:00
|
|
|
|
|
|
|
enum class Manufacturer : u8 {
|
|
|
|
Unknown = 0,
|
|
|
|
Intel = 1,
|
|
|
|
AMD = 2,
|
|
|
|
Hygon = 3,
|
|
|
|
};
|
|
|
|
|
|
|
|
static Manufacturer ParseManufacturer(std::string_view brand_string);
|
|
|
|
|
2020-02-09 14:53:22 -06:00
|
|
|
Manufacturer manufacturer;
|
2022-02-23 21:41:27 -06:00
|
|
|
char brand_string[13];
|
|
|
|
|
|
|
|
char cpu_string[48];
|
|
|
|
|
2020-02-09 14:53:22 -06:00
|
|
|
u32 base_frequency;
|
|
|
|
u32 max_frequency;
|
|
|
|
u32 bus_frequency;
|
2022-02-23 21:41:27 -06:00
|
|
|
|
2022-07-06 12:42:01 -05:00
|
|
|
u32 tsc_crystal_ratio_denominator;
|
|
|
|
u32 tsc_crystal_ratio_numerator;
|
|
|
|
u32 crystal_frequency;
|
|
|
|
u64 tsc_frequency; // Derived from the above three values
|
|
|
|
|
2022-02-23 12:17:47 -06:00
|
|
|
bool sse : 1;
|
|
|
|
bool sse2 : 1;
|
|
|
|
bool sse3 : 1;
|
|
|
|
bool ssse3 : 1;
|
|
|
|
bool sse4_1 : 1;
|
|
|
|
bool sse4_2 : 1;
|
2022-03-09 20:11:46 -06:00
|
|
|
|
2022-02-23 12:17:47 -06:00
|
|
|
bool avx : 1;
|
2022-03-09 20:11:46 -06:00
|
|
|
bool avx_vnni : 1;
|
2022-02-23 12:17:47 -06:00
|
|
|
bool avx2 : 1;
|
2022-03-09 20:11:46 -06:00
|
|
|
bool avx512f : 1;
|
|
|
|
bool avx512dq : 1;
|
|
|
|
bool avx512cd : 1;
|
|
|
|
bool avx512bw : 1;
|
|
|
|
bool avx512vl : 1;
|
|
|
|
bool avx512vbmi : 1;
|
|
|
|
bool avx512bitalg : 1;
|
|
|
|
|
|
|
|
bool aes : 1;
|
2022-02-23 12:17:47 -06:00
|
|
|
bool bmi1 : 1;
|
|
|
|
bool bmi2 : 1;
|
2022-03-09 20:11:46 -06:00
|
|
|
bool f16c : 1;
|
2022-02-23 12:17:47 -06:00
|
|
|
bool fma : 1;
|
|
|
|
bool fma4 : 1;
|
2022-03-09 20:11:46 -06:00
|
|
|
bool gfni : 1;
|
2022-02-23 12:17:47 -06:00
|
|
|
bool invariant_tsc : 1;
|
2022-03-09 20:11:46 -06:00
|
|
|
bool lzcnt : 1;
|
|
|
|
bool movbe : 1;
|
|
|
|
bool pclmulqdq : 1;
|
|
|
|
bool popcnt : 1;
|
|
|
|
bool sha : 1;
|
2013-09-04 19:17:46 -05:00
|
|
|
};
|
|
|
|
|
2015-08-12 16:42:13 -05: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 18:49:33 -05:00
|
|
|
} // namespace Common
|