2013-06-11 07:33:56 -06:00
|
|
|
// Copyright 2013 Dolphin Emulator Project
|
|
|
|
// Licensed under GPLv2
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
#pragma once
|
|
|
|
#include "CommonTypes.h"
|
|
|
|
|
|
|
|
namespace DriverDetails
|
|
|
|
{
|
2013-12-05 08:32:27 -07:00
|
|
|
// Enum of supported operating systems
|
|
|
|
enum OS
|
|
|
|
{
|
|
|
|
OS_ALL = (1 << 0),
|
|
|
|
OS_WINDOWS = (1 << 1),
|
|
|
|
OS_LINUX = (1 << 2),
|
|
|
|
OS_OSX = (1 << 3),
|
|
|
|
OS_ANDROID = (1 << 4),
|
|
|
|
};
|
2013-06-11 07:33:56 -06:00
|
|
|
// Enum of known vendors
|
|
|
|
// Tegra and Nvidia are separated out due to such substantial differences
|
|
|
|
enum Vendor
|
|
|
|
{
|
2013-08-23 02:52:29 -06:00
|
|
|
VENDOR_ALL = 0,
|
|
|
|
VENDOR_NVIDIA,
|
2013-06-11 07:33:56 -06:00
|
|
|
VENDOR_ATI,
|
|
|
|
VENDOR_INTEL,
|
|
|
|
VENDOR_ARM,
|
|
|
|
VENDOR_QUALCOMM,
|
|
|
|
VENDOR_IMGTEC,
|
|
|
|
VENDOR_TEGRA,
|
|
|
|
VENDOR_VIVANTE,
|
2013-08-23 02:52:29 -06:00
|
|
|
VENDOR_MESA,
|
2013-06-11 07:33:56 -06:00
|
|
|
VENDOR_UNKNOWN
|
|
|
|
};
|
|
|
|
|
2013-08-21 04:34:42 -06:00
|
|
|
// Enum of known drivers
|
|
|
|
enum Driver
|
|
|
|
{
|
2013-08-23 02:52:29 -06:00
|
|
|
DRIVER_ALL = 0,
|
|
|
|
DRIVER_NVIDIA, // Official Nvidia, including mobile GPU
|
2013-08-21 04:34:42 -06:00
|
|
|
DRIVER_NOUVEAU, // OSS nouveau
|
2013-08-21 04:41:32 -06:00
|
|
|
DRIVER_ATI, // Official ATI
|
2013-08-23 02:52:29 -06:00
|
|
|
DRIVER_R600, // OSS Radeon
|
2013-08-21 04:34:42 -06:00
|
|
|
DRIVER_INTEL, // Official Intel
|
2013-08-23 02:52:29 -06:00
|
|
|
DRIVER_I965, // OSS Intel
|
|
|
|
DRIVER_ARM_4XX, // Official Mali driver
|
|
|
|
DRIVER_ARM_T6XX, // Official Mali driver
|
2013-08-21 04:34:42 -06:00
|
|
|
DRIVER_LIMA, // OSS Mali driver
|
2013-08-23 02:52:29 -06:00
|
|
|
DRIVER_QUALCOMM_3XX, // Official Adreno driver 3xx
|
|
|
|
DRIVER_QUALCOMM_2XX, // Official Adreno driver 2xx
|
2013-08-21 04:34:42 -06:00
|
|
|
DRIVER_FREEDRENO, // OSS Adreno driver
|
|
|
|
DRIVER_IMGTEC, // OSS PowerVR driver
|
|
|
|
DRIVER_VIVANTE, // Official vivante driver
|
|
|
|
DRIVER_UNKNOWN // Unknown driver, default to official hardware driver
|
|
|
|
};
|
|
|
|
|
2013-06-11 07:33:56 -06:00
|
|
|
// Enum of known bugs
|
|
|
|
// These can be vendor specific, but we put them all in here
|
|
|
|
// For putting a new bug in here, make sure to put a detailed comment above the enum
|
|
|
|
// This'll ensure we know exactly what the issue is.
|
|
|
|
enum Bug
|
|
|
|
{
|
|
|
|
// Bug: No Dynamic UBO array object access
|
|
|
|
// Affected Devices: Qualcomm/Adreno
|
|
|
|
// Started Version: 14
|
2013-11-15 15:51:01 -07:00
|
|
|
// Ended Version: 53
|
2013-06-11 07:33:56 -06:00
|
|
|
// Accessing UBO array members dynamically causes the Adreno shader compiler to crash
|
|
|
|
// Errors out with "Internal Error"
|
|
|
|
BUG_NODYNUBOACCESS = 0,
|
|
|
|
// Bug: Centroid is broken in shaders
|
|
|
|
// Affected devices: Qualcomm/Adreno
|
|
|
|
// Started Version: 14
|
|
|
|
// Ended Version: -1
|
|
|
|
// Centroid in/out, used in the shaders, is used for multisample buffers to get the texel correctly
|
|
|
|
// When MSAA is disabled, it acts like a regular in/out
|
|
|
|
// Tends to cause the driver to render full white or black
|
|
|
|
BUG_BROKENCENTROID,
|
2013-06-18 09:24:36 -06:00
|
|
|
// Bug: INFO_LOG_LENGTH broken
|
|
|
|
// Affected devices: Qualcomm/Adreno
|
|
|
|
// Started Version: ? (Noticed on v14)
|
|
|
|
// Ended Version: -1
|
2013-10-28 23:23:17 -06:00
|
|
|
// When compiling a shader, it is important that when it fails,
|
2013-06-18 09:24:36 -06:00
|
|
|
// you first get the length of the information log prior to grabbing it.
|
|
|
|
// This allows you to allocate an array to store all of the log
|
|
|
|
// Adreno devices /always/ return 0 when querying GL_INFO_LOG_LENGTH
|
|
|
|
// They also max out at 1024 bytes(1023 characters + null terminator) for the log
|
|
|
|
BUG_BROKENINFOLOG,
|
2013-08-23 02:52:29 -06:00
|
|
|
// Bug: UBO buffer offset broken
|
|
|
|
// Affected devices: all mesa drivers
|
|
|
|
// Started Version: 9.0 (mesa doesn't support ubo before)
|
|
|
|
// Ended Version: up to 9.2
|
|
|
|
// The offset of glBindBufferRange was ignored on all Mesa Gallium3D drivers until 9.1.3
|
|
|
|
// Nouveau stored the offset as u16 which isn't enough for all cases with range until 9.1.6
|
|
|
|
// I965 has broken data fetches from uniform buffers which results in a dithering until 9.2.0
|
|
|
|
BUG_BROKENUBO,
|
2013-08-26 11:45:19 -06:00
|
|
|
// Bug: The hacked buffer upload method isn't working
|
|
|
|
// This isn't a bug as the hacked buffer itself isn't used to work.
|
|
|
|
// I'm still surprised that it works on so many drivers.
|
|
|
|
// Affected devices: - amd close sourced driver
|
|
|
|
// - nouveau
|
|
|
|
// - maybe also some others
|
|
|
|
// This hack is evil. It's like free(pointer); *pointer = data;
|
|
|
|
BUG_BROKENHACKEDBUFFER,
|
|
|
|
// Bug: The pinned memory extension isn't working for index buffers
|
|
|
|
// Affected devices: AMD as they are the only vendor providing this extension
|
|
|
|
// Started Version: ?
|
2013-11-22 09:45:24 -07:00
|
|
|
// Ended Version: 13.9 working for me (neobrain).
|
2013-12-19 08:40:13 -07:00
|
|
|
// Affected OS: Linux
|
2013-08-26 11:45:19 -06:00
|
|
|
// Pinned memory is disabled for index buffer as the amd driver (the only one with pinned memory support) seems
|
|
|
|
// to be broken. We just get flickering/black rendering when using pinned memory here -- degasus - 2013/08/20
|
2013-12-19 08:40:13 -07:00
|
|
|
// This bug only happens when paired with base_vertex.
|
2013-08-26 11:45:19 -06:00
|
|
|
// Please see issue #6105 on google code. Let's hope buffer storage solves this issues.
|
2013-11-22 09:45:24 -07:00
|
|
|
// TODO: Detect broken drivers.
|
2013-08-26 11:45:19 -06:00
|
|
|
BUG_BROKENPINNEDMEMORY,
|
2013-09-18 01:36:48 -06:00
|
|
|
// Bug: Entirely broken UBOs
|
|
|
|
// Affected devices: Qualcomm/Adreno
|
|
|
|
// Started Version: ? (Noticed on v45)
|
2013-11-15 15:51:01 -07:00
|
|
|
// Ended Version: 53
|
2013-09-18 01:36:48 -06:00
|
|
|
// Uniform buffers are entirely broken on Qualcomm drivers with v45
|
|
|
|
// Trying to use the uniform buffers causes a malloc to fail inside the driver
|
|
|
|
// To be safe, blanket drivers from v41 - v45
|
|
|
|
BUG_ANNIHILATEDUBOS,
|
|
|
|
// Bug : Can't draw on screen text and clear correctly.
|
|
|
|
// Affected devices: Qualcomm/Adreno
|
|
|
|
// Started Version: ?
|
|
|
|
// Ended Version: ?
|
|
|
|
// Current code for drawing on screen text and clearing the framebuffer doesn't work on Adreno
|
|
|
|
// Drawing on screen text causes the whole screen to swizzle in a terrible fashion
|
|
|
|
// Clearing the framebuffer causes one to never see a frame.
|
|
|
|
BUG_BROKENSWAP,
|
2013-10-28 23:23:17 -06:00
|
|
|
// Bug: glBufferSubData/glMapBufferRange stalls + OOM
|
2013-10-16 05:27:58 -06:00
|
|
|
// Affected devices: Adreno a3xx/Mali-t6xx
|
|
|
|
// Started Version: -1
|
|
|
|
// Ended Version: -1
|
|
|
|
// Both Adreno and Mali have issues when you call glBufferSubData or glMapBufferRange
|
|
|
|
// The driver stalls in each instance no matter what you do
|
|
|
|
// Apparently Mali and Adreno share code in this regard since it was wrote by the same person.
|
|
|
|
BUG_BROKENBUFFERSTREAM,
|
2013-12-19 16:30:39 -07:00
|
|
|
// Bug: GLSL ES 3.0 textureSize causes abort
|
|
|
|
// Affected devices: Adreno a3xx
|
|
|
|
// Started Version: v53
|
|
|
|
// Ended Version: -1
|
|
|
|
// If a shader includes a textureSize function call then the shader compiler will call abort()
|
|
|
|
BUG_BROKENTEXTURESIZE,
|
2013-06-11 07:33:56 -06:00
|
|
|
};
|
2013-10-28 23:23:17 -06:00
|
|
|
|
|
|
|
// Initializes our internal vendor, device family, and driver version
|
2013-08-23 02:52:29 -06:00
|
|
|
void Init(Vendor vendor, Driver driver, const double version);
|
2013-10-28 23:23:17 -06:00
|
|
|
|
2013-06-11 07:33:56 -06:00
|
|
|
// Once Vendor and driver version is set, this will return if it has the applicable bug passed to it.
|
2013-07-05 18:56:15 -06:00
|
|
|
bool HasBug(Bug bug);
|
2013-06-11 07:33:56 -06:00
|
|
|
}
|