mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-04-02 04:20:22 +00:00
Disable primitive restart on buggy OS X Intel HD 3000 drivers.
This commit is contained in:
parent
de16b7207c
commit
6d63db96e9
@ -260,6 +260,7 @@ void InitDriverInfo()
|
|||||||
DriverDetails::Vendor vendor = DriverDetails::VENDOR_UNKNOWN;
|
DriverDetails::Vendor vendor = DriverDetails::VENDOR_UNKNOWN;
|
||||||
DriverDetails::Driver driver = DriverDetails::DRIVER_UNKNOWN;
|
DriverDetails::Driver driver = DriverDetails::DRIVER_UNKNOWN;
|
||||||
double version = 0.0;
|
double version = 0.0;
|
||||||
|
u32 family = 0;
|
||||||
|
|
||||||
// Get the vendor first
|
// Get the vendor first
|
||||||
if (svendor == "NVIDIA Corporation" && srenderer != "NVIDIA Tegra")
|
if (svendor == "NVIDIA Corporation" && srenderer != "NVIDIA Tegra")
|
||||||
@ -321,11 +322,23 @@ void InitDriverInfo()
|
|||||||
version = 100*major + 10*minor + release;
|
version = 100*major + 10*minor + release;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case DriverDetails::VENDOR_INTEL: // Happens in OS X
|
||||||
|
sscanf(g_ogl_config.gl_renderer, "Intel HD Graphics %d", &family);
|
||||||
|
/*
|
||||||
|
int glmajor = 0;
|
||||||
|
int glminor = 0;
|
||||||
|
int major = 0;
|
||||||
|
int minor = 0;
|
||||||
|
int release = 0;
|
||||||
|
sscanf(g_ogl_config.gl_version, "%d.%d INTEL-%d.%d.%d", &glmajor, &glminor, &major, &minor, &release);
|
||||||
|
version = 10000*major + 1000*minor + release;
|
||||||
|
*/
|
||||||
|
break;
|
||||||
// We don't care about these
|
// We don't care about these
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
DriverDetails::Init(vendor, driver, version);
|
DriverDetails::Init(vendor, driver, version, family);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Init functions
|
// Init functions
|
||||||
@ -466,7 +479,8 @@ Renderer::Renderer()
|
|||||||
|
|
||||||
g_Config.backend_info.bSupportsDualSourceBlend = TO_BOOL(GLEW_ARB_blend_func_extended);
|
g_Config.backend_info.bSupportsDualSourceBlend = TO_BOOL(GLEW_ARB_blend_func_extended);
|
||||||
g_Config.backend_info.bSupportsGLSLUBO = TO_BOOL(GLEW_ARB_uniform_buffer_object);
|
g_Config.backend_info.bSupportsGLSLUBO = TO_BOOL(GLEW_ARB_uniform_buffer_object);
|
||||||
g_Config.backend_info.bSupportsPrimitiveRestart = TO_BOOL(GLEW_VERSION_3_1) || TO_BOOL(GLEW_NV_primitive_restart);
|
g_Config.backend_info.bSupportsPrimitiveRestart = !DriverDetails::HasBug(DriverDetails::BUG_PRIMITIVERESTART) &&
|
||||||
|
(TO_BOOL(GLEW_VERSION_3_1) || TO_BOOL(GLEW_NV_primitive_restart));
|
||||||
g_Config.backend_info.bSupportsEarlyZ = TO_BOOL(GLEW_ARB_shader_image_load_store);
|
g_Config.backend_info.bSupportsEarlyZ = TO_BOOL(GLEW_ARB_shader_image_load_store);
|
||||||
|
|
||||||
g_ogl_config.bSupportsGLSLCache = TO_BOOL(GLEW_ARB_get_program_binary);
|
g_ogl_config.bSupportsGLSLCache = TO_BOOL(GLEW_ARB_get_program_binary);
|
||||||
|
@ -14,6 +14,7 @@ namespace DriverDetails
|
|||||||
u32 m_os; // Which OS has the issue
|
u32 m_os; // Which OS has the issue
|
||||||
Vendor m_vendor; // Which vendor has the error
|
Vendor m_vendor; // Which vendor has the error
|
||||||
Driver m_driver; // Which driver has the error
|
Driver m_driver; // Which driver has the error
|
||||||
|
s32 m_family; // Which family of hardware has the issue
|
||||||
Bug m_bug; // Which bug it is
|
Bug m_bug; // Which bug it is
|
||||||
double m_versionstart; // When it started
|
double m_versionstart; // When it started
|
||||||
double m_versionend; // When it ended
|
double m_versionend; // When it ended
|
||||||
@ -33,34 +34,37 @@ namespace DriverDetails
|
|||||||
|
|
||||||
Vendor m_vendor = VENDOR_UNKNOWN;
|
Vendor m_vendor = VENDOR_UNKNOWN;
|
||||||
Driver m_driver = DRIVER_UNKNOWN;
|
Driver m_driver = DRIVER_UNKNOWN;
|
||||||
|
s32 m_family = 0.0;
|
||||||
double m_version = 0.0;
|
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
|
||||||
BugInfo m_known_bugs[] = {
|
BugInfo m_known_bugs[] = {
|
||||||
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, BUG_NODYNUBOACCESS, 14.0, 46.0, true},
|
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, -1, BUG_NODYNUBOACCESS, 14.0, 46.0, true},
|
||||||
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, BUG_BROKENCENTROID, 14.0, 46.0, true},
|
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, -1, BUG_BROKENCENTROID, 14.0, 46.0, true},
|
||||||
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, BUG_BROKENINFOLOG, -1.0, 46.0, true},
|
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, -1, BUG_BROKENINFOLOG, -1.0, 46.0, true},
|
||||||
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, BUG_ANNIHILATEDUBOS, 41.0, 46.0, true},
|
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, -1, BUG_ANNIHILATEDUBOS, 41.0, 46.0, true},
|
||||||
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, BUG_BROKENSWAP, -1.0, 46.0, true},
|
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, -1, BUG_BROKENSWAP, -1.0, 46.0, true},
|
||||||
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, BUG_BROKENBUFFERSTREAM, -1.0, -1.0, true},
|
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, -1, BUG_BROKENBUFFERSTREAM, -1.0, -1.0, true},
|
||||||
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, BUG_BROKENTEXTURESIZE, -1.0, -1.0, true},
|
{OS_ALL, VENDOR_QUALCOMM, DRIVER_QUALCOMM_3XX, -1, BUG_BROKENTEXTURESIZE, -1.0, -1.0, true},
|
||||||
{OS_ALL, VENDOR_ARM, DRIVER_ARM_T6XX, BUG_BROKENBUFFERSTREAM, -1.0, -1.0, true},
|
{OS_ALL, VENDOR_ARM, DRIVER_ARM_T6XX, -1, BUG_BROKENBUFFERSTREAM, -1.0, -1.0, true},
|
||||||
{OS_ALL, VENDOR_MESA, DRIVER_NOUVEAU, BUG_BROKENUBO, 900, 916, true},
|
{OS_ALL, VENDOR_MESA, DRIVER_NOUVEAU, -1, BUG_BROKENUBO, 900, 916, true},
|
||||||
{OS_ALL, VENDOR_MESA, DRIVER_R600, BUG_BROKENUBO, 900, 913, true},
|
{OS_ALL, VENDOR_MESA, DRIVER_R600, -1, BUG_BROKENUBO, 900, 913, true},
|
||||||
{OS_ALL, VENDOR_MESA, DRIVER_I965, BUG_BROKENUBO, 900, 920, true},
|
{OS_ALL, VENDOR_MESA, DRIVER_I965, -1, BUG_BROKENUBO, 900, 920, true},
|
||||||
{OS_ALL, VENDOR_ATI, DRIVER_ATI, BUG_BROKENHACKEDBUFFER, -1.0, -1.0, true},
|
{OS_ALL, VENDOR_ATI, DRIVER_ATI, -1, BUG_BROKENHACKEDBUFFER, -1.0, -1.0, true},
|
||||||
{OS_LINUX, VENDOR_ATI, DRIVER_ATI, BUG_BROKENPINNEDMEMORY, -1.0, -1.0, true},
|
{OS_LINUX, VENDOR_ATI, DRIVER_ATI, -1, BUG_BROKENPINNEDMEMORY, -1.0, -1.0, true},
|
||||||
{OS_ALL, VENDOR_MESA, DRIVER_NOUVEAU, BUG_BROKENHACKEDBUFFER, -1.0, -1.0, true},
|
{OS_ALL, VENDOR_MESA, DRIVER_NOUVEAU, -1, BUG_BROKENHACKEDBUFFER, -1.0, -1.0, true},
|
||||||
|
{OS_OSX, VENDOR_INTEL, DRIVER_INTEL, 3000, BUG_PRIMITIVERESTART, -1.0, -1.0, true},
|
||||||
};
|
};
|
||||||
|
|
||||||
std::map<Bug, BugInfo> m_bugs;
|
std::map<Bug, BugInfo> m_bugs;
|
||||||
|
|
||||||
void Init(Vendor vendor, Driver driver, const double version)
|
void Init(Vendor vendor, Driver driver, const double version, const s32 family)
|
||||||
{
|
{
|
||||||
m_vendor = vendor;
|
m_vendor = vendor;
|
||||||
m_driver = driver;
|
m_driver = driver;
|
||||||
m_version = version;
|
m_version = version;
|
||||||
|
m_family = family;
|
||||||
|
|
||||||
if (driver == DRIVER_UNKNOWN)
|
if (driver == DRIVER_UNKNOWN)
|
||||||
switch(vendor)
|
switch(vendor)
|
||||||
@ -91,6 +95,7 @@ namespace DriverDetails
|
|||||||
( bug.m_os & m_os ) &&
|
( 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 ) &&
|
||||||
( bug.m_driver == m_driver || bug.m_driver == DRIVER_ALL ) &&
|
( bug.m_driver == m_driver || bug.m_driver == DRIVER_ALL ) &&
|
||||||
|
( bug.m_family == m_family || bug.m_family == -1) &&
|
||||||
( 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 )
|
||||||
)
|
)
|
||||||
|
@ -141,10 +141,18 @@ namespace DriverDetails
|
|||||||
// Ended Version: -1
|
// Ended Version: -1
|
||||||
// If a shader includes a textureSize function call then the shader compiler will call abort()
|
// If a shader includes a textureSize function call then the shader compiler will call abort()
|
||||||
BUG_BROKENTEXTURESIZE,
|
BUG_BROKENTEXTURESIZE,
|
||||||
|
// Bug: Intel HD 3000 on OS X has broken primitive restart
|
||||||
|
// Affected devices: Intel HD 3000
|
||||||
|
// Affected OS: OS X
|
||||||
|
// Started Version: -1
|
||||||
|
// Ended Version: -1
|
||||||
|
// The drivers on OS X has broken primitive restart.
|
||||||
|
// Intel HD 4000 series isn't affected by the bug
|
||||||
|
BUG_PRIMITIVERESTART,
|
||||||
};
|
};
|
||||||
|
|
||||||
// Initializes our internal vendor, device family, and driver version
|
// Initializes our internal vendor, device family, and driver version
|
||||||
void Init(Vendor vendor, Driver driver, const double version);
|
void Init(Vendor vendor, Driver driver, const double version, const s32 family);
|
||||||
|
|
||||||
// Once Vendor and driver version is set, this will return if it has the applicable bug passed to it.
|
// Once Vendor and driver version is set, this will return if it has the applicable bug passed to it.
|
||||||
bool HasBug(Bug bug);
|
bool HasBug(Bug bug);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user