VideoCommon/DriverDetails: Make look-up table immutable

Previously, this array potentially wouldn't be placed within the
read-only segment, since it wasn't marked const. We can make the lookup
table const, along with any other nearby variables.
This commit is contained in:
Lioncash 2019-06-08 18:06:34 -04:00
parent d927cd2b03
commit 92b445618a

View File

@ -24,17 +24,17 @@ struct BugInfo
// Local members // Local members
#ifdef _WIN32 #ifdef _WIN32
const u32 m_os = OS_ALL | OS_WINDOWS; constexpr u32 m_os = OS_ALL | OS_WINDOWS;
#elif ANDROID #elif ANDROID
const u32 m_os = OS_ALL | OS_ANDROID; constexpr u32 m_os = OS_ALL | OS_ANDROID;
#elif __APPLE__ #elif __APPLE__
const u32 m_os = OS_ALL | OS_OSX; constexpr u32 m_os = OS_ALL | OS_OSX;
#elif __linux__ #elif __linux__
const u32 m_os = OS_ALL | OS_LINUX; constexpr u32 m_os = OS_ALL | OS_LINUX;
#elif __FreeBSD__ #elif __FreeBSD__
const u32 m_os = OS_ALL | OS_FREEBSD; constexpr u32 m_os = OS_ALL | OS_FREEBSD;
#elif __OpenBSD__ #elif __OpenBSD__
const u32 m_os = OS_ALL | OS_OPENBSD; constexpr u32 m_os = OS_ALL | OS_OPENBSD;
#endif #endif
static API m_api = API_OPENGL; static API m_api = API_OPENGL;
@ -45,7 +45,7 @@ static double m_version = 0.0;
// This is a list of all known bugs for each vendor // This is a list of all known bugs for each vendor
// We use this to check if the device and driver has a issue // We use this to check if the device and driver has a issue
static BugInfo m_known_bugs[] = { constexpr BugInfo m_known_bugs[] = {
{API_OPENGL, OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM, Family::UNKNOWN, {API_OPENGL, OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM, Family::UNKNOWN,
BUG_BROKEN_BUFFER_STREAM, -1.0, -1.0, true}, BUG_BROKEN_BUFFER_STREAM, -1.0, -1.0, true},
{API_OPENGL, OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM, Family::UNKNOWN, {API_OPENGL, OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM, Family::UNKNOWN,
@ -107,7 +107,8 @@ static BugInfo m_known_bugs[] = {
{API_VULKAN, OS_ALL, VENDOR_IMGTEC, DRIVER_IMGTEC, Family::UNKNOWN, {API_VULKAN, OS_ALL, VENDOR_IMGTEC, DRIVER_IMGTEC, Family::UNKNOWN,
BUG_BROKEN_CLEAR_LOADOP_RENDERPASS, -1.0, -1.0, true}, BUG_BROKEN_CLEAR_LOADOP_RENDERPASS, -1.0, -1.0, true},
{API_VULKAN, OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM, Family::UNKNOWN, BUG_BROKEN_D32F_CLEAR, {API_VULKAN, OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM, Family::UNKNOWN, BUG_BROKEN_D32F_CLEAR,
-1.0, -1.0, true}}; -1.0, -1.0, true},
};
static std::map<Bug, BugInfo> m_bugs; static std::map<Bug, BugInfo> m_bugs;
@ -147,7 +148,7 @@ void Init(API api, Vendor vendor, Driver driver, const double version, const Fam
// Clear bug list, as the API may have changed // Clear bug list, as the API may have changed
m_bugs.clear(); m_bugs.clear();
for (auto& bug : m_known_bugs) for (const auto& bug : m_known_bugs)
{ {
if ((bug.m_api & api) && (bug.m_os & m_os) && if ((bug.m_api & api) && (bug.m_os & m_os) &&
(bug.m_vendor == m_vendor || bug.m_vendor == VENDOR_ALL) && (bug.m_vendor == m_vendor || bug.m_vendor == VENDOR_ALL) &&
@ -155,13 +156,15 @@ void Init(API api, Vendor vendor, Driver driver, const double version, const Fam
(bug.m_family == m_family || bug.m_family == Family::UNKNOWN) && (bug.m_family == m_family || bug.m_family == Family::UNKNOWN) &&
(bug.m_versionstart <= m_version || bug.m_versionstart == -1) && (bug.m_versionstart <= m_version || bug.m_versionstart == -1) &&
(bug.m_versionend > m_version || bug.m_versionend == -1)) (bug.m_versionend > m_version || bug.m_versionend == -1))
{
m_bugs.emplace(bug.m_bug, bug); m_bugs.emplace(bug.m_bug, bug);
}
} }
} }
bool HasBug(Bug bug) bool HasBug(Bug bug)
{ {
auto it = m_bugs.find(bug); const auto it = m_bugs.find(bug);
if (it == m_bugs.end()) if (it == m_bugs.end())
return false; return false;
return it->second.m_hasbug; return it->second.m_hasbug;