mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-11-23 12:51:06 +00:00
Bug 1294232 - Refactor blocklisting on Linux to support the downloadable blocklist. r=jrmuizel
MozReview-Commit-ID: ESJY9kkqXR8 Differential Revision: https://phabricator.services.mozilla.com/D19190
This commit is contained in:
parent
3befab3ee9
commit
6828eee6b1
@ -291,6 +291,7 @@ function spoofTheme(aId, aName, aDesc) {
|
|||||||
function spoofGfxAdapter() {
|
function spoofGfxAdapter() {
|
||||||
try {
|
try {
|
||||||
let gfxInfo = Cc["@mozilla.org/gfx/info;1"].getService(Ci.nsIGfxInfoDebug);
|
let gfxInfo = Cc["@mozilla.org/gfx/info;1"].getService(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
gfxInfo.spoofVendorID(GFX_VENDOR_ID);
|
gfxInfo.spoofVendorID(GFX_VENDOR_ID);
|
||||||
gfxInfo.spoofDeviceID(GFX_DEVICE_ID);
|
gfxInfo.spoofDeviceID(GFX_DEVICE_ID);
|
||||||
} catch (x) {
|
} catch (x) {
|
||||||
|
@ -30,6 +30,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
switch (Services.appinfo.OS) {
|
switch (Services.appinfo.OS) {
|
||||||
|
@ -30,6 +30,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
switch (Services.appinfo.OS) {
|
switch (Services.appinfo.OS) {
|
||||||
|
@ -30,6 +30,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
switch (Services.appinfo.OS) {
|
switch (Services.appinfo.OS) {
|
||||||
|
@ -31,6 +31,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
switch (Services.appinfo.OS) {
|
switch (Services.appinfo.OS) {
|
||||||
|
@ -30,6 +30,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
switch (Services.appinfo.OS) {
|
switch (Services.appinfo.OS) {
|
||||||
|
@ -30,6 +30,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
switch (Services.appinfo.OS) {
|
switch (Services.appinfo.OS) {
|
||||||
|
@ -30,6 +30,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
switch (Services.appinfo.OS) {
|
switch (Services.appinfo.OS) {
|
||||||
|
@ -30,6 +30,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
gfxInfo.spoofVendorID("0xabcd");
|
gfxInfo.spoofVendorID("0xabcd");
|
||||||
gfxInfo.spoofDeviceID("0x6666");
|
gfxInfo.spoofDeviceID("0x6666");
|
||||||
|
@ -30,6 +30,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
switch (Services.appinfo.OS) {
|
switch (Services.appinfo.OS) {
|
||||||
|
@ -29,6 +29,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
gfxInfo.spoofDriverVersion("8.52.322.2201");
|
gfxInfo.spoofDriverVersion("8.52.322.2201");
|
||||||
|
@ -30,6 +30,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
gfxInfo.spoofDriverVersion("8.52.322.2202");
|
gfxInfo.spoofDriverVersion("8.52.322.2202");
|
||||||
|
@ -30,6 +30,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
gfxInfo.spoofDriverVersion("8.52.322.2201");
|
gfxInfo.spoofDriverVersion("8.52.322.2201");
|
||||||
|
@ -30,6 +30,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
switch (Services.appinfo.OS) {
|
switch (Services.appinfo.OS) {
|
||||||
|
@ -29,6 +29,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
switch (Services.appinfo.OS) {
|
switch (Services.appinfo.OS) {
|
||||||
|
@ -34,6 +34,7 @@ async function run_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
gfxInfo.QueryInterface(Ci.nsIGfxInfoDebug);
|
||||||
|
gfxInfo.fireTestProcess();
|
||||||
|
|
||||||
// Set the vendor/device ID, etc, to match the test file.
|
// Set the vendor/device ID, etc, to match the test file.
|
||||||
switch (Services.appinfo.OS) {
|
switch (Services.appinfo.OS) {
|
||||||
|
@ -58,6 +58,20 @@ typedef uint32_t GLenum;
|
|||||||
#define GL_RENDERER 0x1F01
|
#define GL_RENDERER 0x1F01
|
||||||
#define GL_VERSION 0x1F02
|
#define GL_VERSION 0x1F02
|
||||||
|
|
||||||
|
// GLX_MESA_query_renderer
|
||||||
|
#define GLX_RENDERER_VENDOR_ID_MESA 0x8183
|
||||||
|
#define GLX_RENDERER_DEVICE_ID_MESA 0x8184
|
||||||
|
#define GLX_RENDERER_VERSION_MESA 0x8185
|
||||||
|
#define GLX_RENDERER_ACCELERATED_MESA 0x8186
|
||||||
|
#define GLX_RENDERER_VIDEO_MEMORY_MESA 0x8187
|
||||||
|
#define GLX_RENDERER_UNIFIED_MEMORY_ARCHITECTURE_MESA 0x8188
|
||||||
|
#define GLX_RENDERER_PREFERRED_PROFILE_MESA 0x8189
|
||||||
|
#define GLX_RENDERER_OPENGL_CORE_PROFILE_VERSION_MESA 0x818A
|
||||||
|
#define GLX_RENDERER_OPENGL_COMPATIBILITY_PROFILE_VERSION_MESA 0x818B
|
||||||
|
#define GLX_RENDERER_OPENGL_ES_PROFILE_VERSION_MESA 0x818C
|
||||||
|
#define GLX_RENDERER_OPENGL_ES2_PROFILE_VERSION_MESA 0x818D
|
||||||
|
#define GLX_RENDERER_ID_MESA 0x818E
|
||||||
|
|
||||||
namespace mozilla {
|
namespace mozilla {
|
||||||
namespace widget {
|
namespace widget {
|
||||||
// the read end of the pipe, which will be used by GfxInfo
|
// the read end of the pipe, which will be used by GfxInfo
|
||||||
@ -201,13 +215,13 @@ void glxtest() {
|
|||||||
void *glXBindTexImageEXT = glXGetProcAddress("glXBindTexImageEXT");
|
void *glXBindTexImageEXT = glXGetProcAddress("glXBindTexImageEXT");
|
||||||
|
|
||||||
///// Get GL vendor/renderer/versions strings /////
|
///// Get GL vendor/renderer/versions strings /////
|
||||||
enum { bufsize = 1024 };
|
enum { bufsize = 2048 };
|
||||||
char buf[bufsize];
|
char buf[bufsize];
|
||||||
const GLubyte *vendorString = glGetString(GL_VENDOR);
|
const GLubyte* versionString = glGetString(GL_VERSION);
|
||||||
const GLubyte *rendererString = glGetString(GL_RENDERER);
|
const GLubyte* vendorString = glGetString(GL_VENDOR);
|
||||||
const GLubyte *versionString = glGetString(GL_VERSION);
|
const GLubyte* rendererString = glGetString(GL_RENDERER);
|
||||||
|
|
||||||
if (!vendorString || !rendererString || !versionString)
|
if (!versionString || !vendorString || !rendererString)
|
||||||
fatal_error("glGetString returned null");
|
fatal_error("glGetString returned null");
|
||||||
|
|
||||||
int length =
|
int length =
|
||||||
@ -217,6 +231,46 @@ void glxtest() {
|
|||||||
if (length >= bufsize)
|
if (length >= bufsize)
|
||||||
fatal_error("GL strings length too large for buffer size");
|
fatal_error("GL strings length too large for buffer size");
|
||||||
|
|
||||||
|
// If GLX_MESA_query_renderer is available, populate additional data.
|
||||||
|
typedef Bool (*PFNGLXQUERYCURRENTRENDERERINTEGERMESAPROC) (int attribute, unsigned int* value);
|
||||||
|
PFNGLXQUERYCURRENTRENDERERINTEGERMESAPROC glXQueryCurrentRendererIntegerMESAProc =
|
||||||
|
cast<PFNGLXQUERYCURRENTRENDERERINTEGERMESAPROC>(glXGetProcAddress("glXQueryCurrentRendererIntegerMESA"));
|
||||||
|
if (glXQueryCurrentRendererIntegerMESAProc) {
|
||||||
|
unsigned int vendorId, deviceId, accelerated, videoMemoryMB;
|
||||||
|
glXQueryCurrentRendererIntegerMESAProc(GLX_RENDERER_VENDOR_ID_MESA, &vendorId);
|
||||||
|
glXQueryCurrentRendererIntegerMESAProc(GLX_RENDERER_DEVICE_ID_MESA, &deviceId);
|
||||||
|
glXQueryCurrentRendererIntegerMESAProc(GLX_RENDERER_ACCELERATED_MESA, &accelerated);
|
||||||
|
glXQueryCurrentRendererIntegerMESAProc(GLX_RENDERER_VIDEO_MEMORY_MESA, &videoMemoryMB);
|
||||||
|
|
||||||
|
// Truncate IDs to 4 digits- that's all PCI IDs are.
|
||||||
|
vendorId &= 0xFFFF;
|
||||||
|
deviceId &= 0xFFFF;
|
||||||
|
|
||||||
|
length += snprintf(buf + length, bufsize,
|
||||||
|
"MESA_VENDOR_ID\n0x%04x\n"
|
||||||
|
"MESA_DEVICE_ID\n0x%04x\n"
|
||||||
|
"MESA_ACCELERATED\n%s\n"
|
||||||
|
"MESA_VRAM\n%dMB\n",
|
||||||
|
vendorId, deviceId, accelerated ? "TRUE" : "FALSE",
|
||||||
|
videoMemoryMB);
|
||||||
|
|
||||||
|
if (length >= bufsize)
|
||||||
|
fatal_error("GL strings length too large for buffer size");
|
||||||
|
}
|
||||||
|
|
||||||
|
// From Mesa's GL/internal/dri_interface.h, to be used by DRI clients.
|
||||||
|
typedef const char * (* PFNGLXGETSCREENDRIVERPROC) (Display *dpy, int scrNum);
|
||||||
|
PFNGLXGETSCREENDRIVERPROC glXGetScreenDriverProc =
|
||||||
|
cast<PFNGLXGETSCREENDRIVERPROC>(glXGetProcAddress("glXGetScreenDriver"));
|
||||||
|
if (glXGetScreenDriverProc) {
|
||||||
|
const char* driDriver = glXGetScreenDriverProc(dpy, DefaultScreen(dpy));
|
||||||
|
if (driDriver) {
|
||||||
|
length += snprintf(buf + length, bufsize, "DRI_DRIVER\n%s\n", driDriver);
|
||||||
|
if (length >= bufsize)
|
||||||
|
fatal_error("GL strings length too large for buffer size");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
///// Clean up. Indeed, the parent process might fail to kill us (e.g. if it
|
///// Clean up. Indeed, the parent process might fail to kill us (e.g. if it
|
||||||
///// doesn't need to check GL info) so we might be staying alive for longer
|
///// doesn't need to check GL info) so we might be staying alive for longer
|
||||||
///// than expected, so it's important to consume as little memory as
|
///// than expected, so it's important to consume as little memory as
|
||||||
|
@ -381,6 +381,11 @@ const nsAString& GfxDriverInfo::GetDeviceVendor(DeviceVendor id) {
|
|||||||
// Choose an arbitrary Qualcomm PCI VENdor ID for now.
|
// Choose an arbitrary Qualcomm PCI VENdor ID for now.
|
||||||
// TODO: This should be "QCOM" when Windows device ID parsing is reworked.
|
// TODO: This should be "QCOM" when Windows device ID parsing is reworked.
|
||||||
DECLARE_VENDOR_ID(VendorQualcomm, "0x5143");
|
DECLARE_VENDOR_ID(VendorQualcomm, "0x5143");
|
||||||
|
DECLARE_VENDOR_ID(VendorMesaAll, "mesa/all");
|
||||||
|
DECLARE_VENDOR_ID(VendorMesaLLVMPipe, "mesa/llvmpipe");
|
||||||
|
DECLARE_VENDOR_ID(VendorMesaSoftPipe, "mesa/softpipe");
|
||||||
|
DECLARE_VENDOR_ID(VendorMesaSWRast, "mesa/swrast");
|
||||||
|
DECLARE_VENDOR_ID(VendorMesaUnknown, "mesa/unknown");
|
||||||
// Suppress a warning.
|
// Suppress a warning.
|
||||||
DECLARE_VENDOR_ID(DeviceVendorMax, "");
|
DECLARE_VENDOR_ID(DeviceVendorMax, "");
|
||||||
}
|
}
|
||||||
|
@ -127,6 +127,18 @@ enum DeviceVendor {
|
|||||||
VendorMicrosoft,
|
VendorMicrosoft,
|
||||||
VendorParallels,
|
VendorParallels,
|
||||||
VendorQualcomm,
|
VendorQualcomm,
|
||||||
|
|
||||||
|
// Wildcard for all Mesa drivers.
|
||||||
|
VendorMesaAll,
|
||||||
|
// Note that the following list of Mesa drivers is not comprehensive; we pull
|
||||||
|
// the DRI driver at runtime. These drivers are provided for convenience when
|
||||||
|
// populating the local blocklist.
|
||||||
|
VendorMesaLLVMPipe,
|
||||||
|
VendorMesaSoftPipe,
|
||||||
|
VendorMesaSWRast,
|
||||||
|
// A generic ID to be provided when we can't determine the DRI driver on Mesa.
|
||||||
|
VendorMesaUnknown,
|
||||||
|
|
||||||
DeviceVendorMax
|
DeviceVendorMax
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -276,7 +288,7 @@ inline bool ParseDriverVersion(const nsAString &aVersion,
|
|||||||
uint64_t *aNumericVersion) {
|
uint64_t *aNumericVersion) {
|
||||||
*aNumericVersion = 0;
|
*aNumericVersion = 0;
|
||||||
|
|
||||||
#if defined(XP_WIN)
|
#if defined(XP_WIN) || defined(MOZ_X11)
|
||||||
int a, b, c, d;
|
int a, b, c, d;
|
||||||
char aStr[8], bStr[8], cStr[8], dStr[8];
|
char aStr[8], bStr[8], cStr[8], dStr[8];
|
||||||
/* honestly, why do I even bother */
|
/* honestly, why do I even bother */
|
||||||
|
@ -695,7 +695,7 @@ int32_t GfxInfoBase::FindBlocklistedDeviceInList(
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(XP_WIN) || defined(ANDROID)
|
#if defined(XP_WIN) || defined(ANDROID) || defined(MOZ_X11)
|
||||||
uint64_t driverVersion[2] = {0, 0};
|
uint64_t driverVersion[2] = {0, 0};
|
||||||
if (!adapterInfoFailed[0]) {
|
if (!adapterInfoFailed[0]) {
|
||||||
ParseDriverVersion(adapterDriverVersionString[0], &driverVersion[0]);
|
ParseDriverVersion(adapterDriverVersionString[0], &driverVersion[0]);
|
||||||
@ -728,11 +728,7 @@ int32_t GfxInfoBase::FindBlocklistedDeviceInList(
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!info[i].mAdapterVendor.Equals(
|
if (!DoesVendorMatch(info[i].mAdapterVendor, adapterVendorID[infoIndex])) {
|
||||||
GfxDriverInfo::GetDeviceVendor(VendorAll),
|
|
||||||
nsCaseInsensitiveStringComparator()) &&
|
|
||||||
!info[i].mAdapterVendor.Equals(adapterVendorID[infoIndex],
|
|
||||||
nsCaseInsensitiveStringComparator())) {
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -769,7 +765,7 @@ int32_t GfxInfoBase::FindBlocklistedDeviceInList(
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(XP_WIN) || defined(ANDROID)
|
#if defined(XP_WIN) || defined(ANDROID) || defined(MOZ_X11)
|
||||||
switch (info[i].mComparisonOp) {
|
switch (info[i].mComparisonOp) {
|
||||||
case DRIVER_LESS_THAN:
|
case DRIVER_LESS_THAN:
|
||||||
match = driverVersion[infoIndex] < info[i].mDriverVersion;
|
match = driverVersion[infoIndex] < info[i].mDriverVersion;
|
||||||
@ -883,6 +879,14 @@ void GfxInfoBase::SetFeatureStatus(
|
|||||||
sFeatureStatus = new nsTArray<dom::GfxInfoFeatureStatus>(aFS);
|
sFeatureStatus = new nsTArray<dom::GfxInfoFeatureStatus>(aFS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool GfxInfoBase::DoesVendorMatch(const nsAString& aBlocklistVendor,
|
||||||
|
const nsAString& aAdapterVendor) {
|
||||||
|
return aBlocklistVendor.Equals(aAdapterVendor,
|
||||||
|
nsCaseInsensitiveStringComparator()) ||
|
||||||
|
aBlocklistVendor.Equals(GfxDriverInfo::GetDeviceVendor(VendorAll),
|
||||||
|
nsCaseInsensitiveStringComparator());
|
||||||
|
}
|
||||||
|
|
||||||
nsresult GfxInfoBase::GetFeatureStatusImpl(
|
nsresult GfxInfoBase::GetFeatureStatusImpl(
|
||||||
int32_t aFeature, int32_t* aStatus, nsAString& aSuggestedVersion,
|
int32_t aFeature, int32_t* aStatus, nsAString& aSuggestedVersion,
|
||||||
const nsTArray<GfxDriverInfo>& aDriverInfo, nsACString& aFailureId,
|
const nsTArray<GfxDriverInfo>& aDriverInfo, nsACString& aFailureId,
|
||||||
|
@ -125,6 +125,10 @@ class GfxInfoBase : public nsIGfxInfo,
|
|||||||
virtual const nsTArray<GfxDriverInfo>& GetGfxDriverInfo() = 0;
|
virtual const nsTArray<GfxDriverInfo>& GetGfxDriverInfo() = 0;
|
||||||
|
|
||||||
virtual void DescribeFeatures(JSContext* aCx, JS::Handle<JSObject*> obj);
|
virtual void DescribeFeatures(JSContext* aCx, JS::Handle<JSObject*> obj);
|
||||||
|
|
||||||
|
virtual bool DoesVendorMatch(const nsAString& aBlocklistVendor,
|
||||||
|
const nsAString& aAdapterVendor);
|
||||||
|
|
||||||
bool InitFeatureObject(JSContext* aCx, JS::Handle<JSObject*> aContainer,
|
bool InitFeatureObject(JSContext* aCx, JS::Handle<JSObject*> aContainer,
|
||||||
const char* aName,
|
const char* aName,
|
||||||
mozilla::gfx::FeatureStatus& aKnownStatus,
|
mozilla::gfx::FeatureStatus& aKnownStatus,
|
||||||
|
@ -14,9 +14,15 @@
|
|||||||
#include "nsExceptionHandler.h"
|
#include "nsExceptionHandler.h"
|
||||||
#include "nsICrashReporter.h"
|
#include "nsICrashReporter.h"
|
||||||
#include "prenv.h"
|
#include "prenv.h"
|
||||||
|
#include "nsPrintfCString.h"
|
||||||
|
#include "nsWhitespaceTokenizer.h"
|
||||||
|
|
||||||
#include "GfxInfoX11.h"
|
#include "GfxInfoX11.h"
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
bool fire_glxtest_process();
|
||||||
|
#endif
|
||||||
|
|
||||||
namespace mozilla {
|
namespace mozilla {
|
||||||
namespace widget {
|
namespace widget {
|
||||||
|
|
||||||
@ -30,27 +36,20 @@ pid_t glxtest_pid = 0;
|
|||||||
|
|
||||||
nsresult GfxInfo::Init() {
|
nsresult GfxInfo::Init() {
|
||||||
mGLMajorVersion = 0;
|
mGLMajorVersion = 0;
|
||||||
mMajorVersion = 0;
|
mGLMinorVersion = 0;
|
||||||
mMinorVersion = 0;
|
|
||||||
mRevisionVersion = 0;
|
|
||||||
mIsMesa = false;
|
|
||||||
mIsNVIDIA = false;
|
|
||||||
mIsFGLRX = false;
|
|
||||||
mIsNouveau = false;
|
|
||||||
mIsIntel = false;
|
|
||||||
mIsOldSwrast = false;
|
|
||||||
mIsLlvmpipe = false;
|
|
||||||
mHasTextureFromPixmap = false;
|
mHasTextureFromPixmap = false;
|
||||||
|
mIsMesa = false;
|
||||||
|
mIsAccelerated = true;
|
||||||
return GfxInfoBase::Init();
|
return GfxInfoBase::Init();
|
||||||
}
|
}
|
||||||
|
|
||||||
void GfxInfo::AddCrashReportAnnotations() {
|
void GfxInfo::AddCrashReportAnnotations() {
|
||||||
CrashReporter::AnnotateCrashReport(CrashReporter::Annotation::AdapterVendorID,
|
CrashReporter::AnnotateCrashReport(CrashReporter::Annotation::AdapterVendorID,
|
||||||
mVendor);
|
mVendorId);
|
||||||
CrashReporter::AnnotateCrashReport(CrashReporter::Annotation::AdapterDeviceID,
|
CrashReporter::AnnotateCrashReport(CrashReporter::Annotation::AdapterDeviceID,
|
||||||
mRenderer);
|
mDeviceId);
|
||||||
CrashReporter::AnnotateCrashReport(
|
CrashReporter::AnnotateCrashReport(
|
||||||
CrashReporter::Annotation::AdapterDriverVersion, mVersion);
|
CrashReporter::Annotation::AdapterDriverVersion, mDriverVersion);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GfxInfo::GetData() {
|
void GfxInfo::GetData() {
|
||||||
@ -108,7 +107,18 @@ void GfxInfo::GetData() {
|
|||||||
bool error = waiting_for_glxtest_process_failed || exited_with_error_code ||
|
bool error = waiting_for_glxtest_process_failed || exited_with_error_code ||
|
||||||
received_signal;
|
received_signal;
|
||||||
|
|
||||||
|
nsCString glVendor;
|
||||||
|
nsCString glRenderer;
|
||||||
|
nsCString glVersion;
|
||||||
nsCString textureFromPixmap;
|
nsCString textureFromPixmap;
|
||||||
|
|
||||||
|
// Available if GLX_MESA_query_renderer is supported.
|
||||||
|
nsCString mesaVendor;
|
||||||
|
nsCString mesaDevice;
|
||||||
|
nsCString mesaAccelerated;
|
||||||
|
// Available if using a DRI-based libGL stack.
|
||||||
|
nsCString driDriver;
|
||||||
|
|
||||||
nsCString *stringToFill = nullptr;
|
nsCString *stringToFill = nullptr;
|
||||||
char *bufptr = buf;
|
char *bufptr = buf;
|
||||||
if (!error) {
|
if (!error) {
|
||||||
@ -119,13 +129,23 @@ void GfxInfo::GetData() {
|
|||||||
stringToFill->Assign(line);
|
stringToFill->Assign(line);
|
||||||
stringToFill = nullptr;
|
stringToFill = nullptr;
|
||||||
} else if (!strcmp(line, "VENDOR"))
|
} else if (!strcmp(line, "VENDOR"))
|
||||||
stringToFill = &mVendor;
|
stringToFill = &glVendor;
|
||||||
else if (!strcmp(line, "RENDERER"))
|
else if (!strcmp(line, "RENDERER"))
|
||||||
stringToFill = &mRenderer;
|
stringToFill = &glRenderer;
|
||||||
else if (!strcmp(line, "VERSION"))
|
else if (!strcmp(line, "VERSION"))
|
||||||
stringToFill = &mVersion;
|
stringToFill = &glVersion;
|
||||||
else if (!strcmp(line, "TFP"))
|
else if (!strcmp(line, "TFP"))
|
||||||
stringToFill = &textureFromPixmap;
|
stringToFill = &textureFromPixmap;
|
||||||
|
else if (!strcmp(line, "MESA_VENDOR_ID"))
|
||||||
|
stringToFill = &mesaVendor;
|
||||||
|
else if (!strcmp(line, "MESA_DEVICE_ID"))
|
||||||
|
stringToFill = &mesaDevice;
|
||||||
|
else if (!strcmp(line, "MESA_ACCELERATED"))
|
||||||
|
stringToFill = &mesaAccelerated;
|
||||||
|
else if (!strcmp(line, "MESA_VRAM"))
|
||||||
|
stringToFill = &mAdapterRAM;
|
||||||
|
else if (!strcmp(line, "DRI_DRIVER"))
|
||||||
|
stringToFill = &driDriver;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -140,18 +160,18 @@ void GfxInfo::GetData() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const char *spoofedVendor = PR_GetEnv("MOZ_GFX_SPOOF_GL_VENDOR");
|
const char *spoofedVendor = PR_GetEnv("MOZ_GFX_SPOOF_GL_VENDOR");
|
||||||
if (spoofedVendor) mVendor.Assign(spoofedVendor);
|
if (spoofedVendor) glVendor.Assign(spoofedVendor);
|
||||||
const char *spoofedRenderer = PR_GetEnv("MOZ_GFX_SPOOF_GL_RENDERER");
|
const char *spoofedRenderer = PR_GetEnv("MOZ_GFX_SPOOF_GL_RENDERER");
|
||||||
if (spoofedRenderer) mRenderer.Assign(spoofedRenderer);
|
if (spoofedRenderer) glRenderer.Assign(spoofedRenderer);
|
||||||
const char *spoofedVersion = PR_GetEnv("MOZ_GFX_SPOOF_GL_VERSION");
|
const char *spoofedVersion = PR_GetEnv("MOZ_GFX_SPOOF_GL_VERSION");
|
||||||
if (spoofedVersion) mVersion.Assign(spoofedVersion);
|
if (spoofedVersion) glVersion.Assign(spoofedVersion);
|
||||||
const char *spoofedOS = PR_GetEnv("MOZ_GFX_SPOOF_OS");
|
const char *spoofedOS = PR_GetEnv("MOZ_GFX_SPOOF_OS");
|
||||||
if (spoofedOS) mOS.Assign(spoofedOS);
|
if (spoofedOS) mOS.Assign(spoofedOS);
|
||||||
const char *spoofedOSRelease = PR_GetEnv("MOZ_GFX_SPOOF_OS_RELEASE");
|
const char *spoofedOSRelease = PR_GetEnv("MOZ_GFX_SPOOF_OS_RELEASE");
|
||||||
if (spoofedOSRelease) mOSRelease.Assign(spoofedOSRelease);
|
if (spoofedOSRelease) mOSRelease.Assign(spoofedOSRelease);
|
||||||
|
|
||||||
if (error || mVendor.IsEmpty() || mRenderer.IsEmpty() || mVersion.IsEmpty() ||
|
if (error || glVendor.IsEmpty() || glRenderer.IsEmpty() ||
|
||||||
mOS.IsEmpty() || mOSRelease.IsEmpty()) {
|
glVersion.IsEmpty() || mOS.IsEmpty() || mOSRelease.IsEmpty()) {
|
||||||
mAdapterDescription.AppendLiteral("GLXtest process failed");
|
mAdapterDescription.AppendLiteral("GLXtest process failed");
|
||||||
if (waiting_for_glxtest_process_failed)
|
if (waiting_for_glxtest_process_failed)
|
||||||
mAdapterDescription.AppendPrintf(
|
mAdapterDescription.AppendPrintf(
|
||||||
@ -173,83 +193,134 @@ void GfxInfo::GetData() {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
mAdapterDescription.Append(mVendor);
|
// Scan the GL_VERSION string for the GL and driver versions.
|
||||||
mAdapterDescription.AppendLiteral(" -- ");
|
nsCWhitespaceTokenizer tokenizer(glVersion);
|
||||||
mAdapterDescription.Append(mRenderer);
|
while (tokenizer.hasMoreTokens()) {
|
||||||
|
nsCString token(tokenizer.nextToken());
|
||||||
AddCrashReportAnnotations();
|
unsigned int major = 0, minor = 0, revision = 0, patch = 0;
|
||||||
|
if (sscanf(token.get(), "%u.%u.%u.%u", &major, &minor, &revision, &patch) >=
|
||||||
// determine the major OpenGL version. That's the first integer in the version
|
2) {
|
||||||
// string.
|
// A survey of GL_VENDOR strings indicates that the first version is
|
||||||
mGLMajorVersion = strtol(mVersion.get(), 0, 10);
|
// always the GL version, the second is usually the driver version.
|
||||||
|
if (mGLMajorVersion == 0) {
|
||||||
// determine driver type (vendor) and where in the version string
|
mGLMajorVersion = major;
|
||||||
// the actual driver version numbers should be expected to be found
|
mGLMinorVersion = minor;
|
||||||
// (whereToReadVersionNumbers)
|
} else if (mDriverVersion.IsEmpty()) { // Not already spoofed.
|
||||||
const char *whereToReadVersionNumbers = nullptr;
|
mDriverVersion =
|
||||||
const char *Mesa_in_version_string = strstr(mVersion.get(), "Mesa");
|
nsPrintfCString("%u.%u.%u.%u", major, minor, revision, patch);
|
||||||
if (Mesa_in_version_string) {
|
|
||||||
mIsMesa = true;
|
|
||||||
// with Mesa, the version string contains "Mesa major.minor" and that's all
|
|
||||||
// the version information we get: there is no actual driver version info.
|
|
||||||
whereToReadVersionNumbers = Mesa_in_version_string + strlen("Mesa");
|
|
||||||
if (strcasestr(mVendor.get(), "nouveau")) mIsNouveau = true;
|
|
||||||
if (strcasestr(mRenderer.get(),
|
|
||||||
"intel")) // yes, intel is in the renderer string
|
|
||||||
mIsIntel = true;
|
|
||||||
if (strcasestr(mRenderer.get(), "llvmpipe")) mIsLlvmpipe = true;
|
|
||||||
if (strcasestr(mRenderer.get(), "software rasterizer")) mIsOldSwrast = true;
|
|
||||||
} else if (strstr(mVendor.get(), "NVIDIA Corporation")) {
|
|
||||||
mIsNVIDIA = true;
|
|
||||||
// with the NVIDIA driver, the version string contains "NVIDIA major.minor"
|
|
||||||
// note that here the vendor and version strings behave differently, that's
|
|
||||||
// why we don't put this above alongside Mesa_in_version_string.
|
|
||||||
const char *NVIDIA_in_version_string = strstr(mVersion.get(), "NVIDIA");
|
|
||||||
if (NVIDIA_in_version_string)
|
|
||||||
whereToReadVersionNumbers = NVIDIA_in_version_string + strlen("NVIDIA");
|
|
||||||
} else if (strstr(mVendor.get(), "ATI Technologies Inc")) {
|
|
||||||
mIsFGLRX = true;
|
|
||||||
// with the FGLRX driver, the version string only gives a OpenGL version :/
|
|
||||||
// so let's return that. that can at least give a rough idea of how old the
|
|
||||||
// driver is.
|
|
||||||
whereToReadVersionNumbers = mVersion.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
// read major.minor version numbers of the driver (not to be confused with the
|
|
||||||
// OpenGL version)
|
|
||||||
if (whereToReadVersionNumbers) {
|
|
||||||
// copy into writable buffer, for tokenization
|
|
||||||
strncpy(buf, whereToReadVersionNumbers, buf_size);
|
|
||||||
bufptr = buf;
|
|
||||||
|
|
||||||
// now try to read major.minor version numbers. In case of failure,
|
|
||||||
// gracefully exit: these numbers have been initialized as 0 anyways
|
|
||||||
char *token = NS_strtok(".", &bufptr);
|
|
||||||
if (token) {
|
|
||||||
mMajorVersion = strtol(token, 0, 10);
|
|
||||||
token = NS_strtok(".", &bufptr);
|
|
||||||
if (token) {
|
|
||||||
mMinorVersion = strtol(token, 0, 10);
|
|
||||||
token = NS_strtok(".", &bufptr);
|
|
||||||
if (token) mRevisionVersion = strtol(token, 0, 10);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
static inline uint64_t version(uint32_t major, uint32_t minor,
|
if (mGLMajorVersion == 0) {
|
||||||
uint32_t revision = 0) {
|
NS_WARNING("Failed to parse GL version!");
|
||||||
return (uint64_t(major) << 32) + (uint64_t(minor) << 16) + uint64_t(revision);
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Mesa always exposes itself in the GL_VERSION string, but not always the
|
||||||
|
// GL_VENDOR string.
|
||||||
|
mIsMesa = glVersion.Find("Mesa") != -1;
|
||||||
|
|
||||||
|
// We need to use custom vendor IDs for mesa so we can treat them
|
||||||
|
// differently than the proprietary drivers.
|
||||||
|
if (mIsMesa) {
|
||||||
|
mIsAccelerated = !mesaAccelerated.Equals("FALSE");
|
||||||
|
// Process software rasterizers before the DRI driver string; we may be
|
||||||
|
// forcing software rasterization on a DRI-accelerated X server by using
|
||||||
|
// LIBGL_ALWAYS_SOFTWARE or a similar restriction.
|
||||||
|
if (strcasestr(glRenderer.get(), "llvmpipe")) {
|
||||||
|
CopyUTF16toUTF8(GfxDriverInfo::GetDeviceVendor(VendorMesaLLVMPipe),
|
||||||
|
mVendorId);
|
||||||
|
mIsAccelerated = false;
|
||||||
|
} else if (strcasestr(glRenderer.get(), "softpipe")) {
|
||||||
|
CopyUTF16toUTF8(GfxDriverInfo::GetDeviceVendor(VendorMesaSoftPipe),
|
||||||
|
mVendorId);
|
||||||
|
mIsAccelerated = false;
|
||||||
|
} else if (strcasestr(glRenderer.get(), "software rasterizer") ||
|
||||||
|
!mIsAccelerated) {
|
||||||
|
// Fallback to reporting swrast if GLX_MESA_query_renderer tells us
|
||||||
|
// we're using an unaccelerated context.
|
||||||
|
CopyUTF16toUTF8(GfxDriverInfo::GetDeviceVendor(VendorMesaSWRast),
|
||||||
|
mVendorId);
|
||||||
|
mIsAccelerated = false;
|
||||||
|
} else if (!driDriver.IsEmpty()) {
|
||||||
|
mVendorId = nsPrintfCString("mesa/%s", driDriver.get());
|
||||||
|
} else {
|
||||||
|
// Some other mesa configuration where we couldn't get enough info.
|
||||||
|
NS_WARNING("Failed to detect Mesa driver being used!");
|
||||||
|
CopyUTF16toUTF8(GfxDriverInfo::GetDeviceVendor(VendorMesaUnknown),
|
||||||
|
mVendorId);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!mesaDevice.IsEmpty()) {
|
||||||
|
mDeviceId = mesaDevice;
|
||||||
|
} else {
|
||||||
|
NS_WARNING(
|
||||||
|
"Failed to get Mesa device ID! GLX_MESA_query_renderer unsupported?");
|
||||||
|
}
|
||||||
|
} else if (glVendor.EqualsLiteral("NVIDIA Corporation")) {
|
||||||
|
CopyUTF16toUTF8(GfxDriverInfo::GetDeviceVendor(VendorNVIDIA), mVendorId);
|
||||||
|
// TODO: Use NV-CONTROL X11 extension to query Device ID and VRAM.
|
||||||
|
} else if (glVendor.EqualsLiteral("ATI Technologies Inc.")) {
|
||||||
|
CopyUTF16toUTF8(GfxDriverInfo::GetDeviceVendor(VendorATI), mVendorId);
|
||||||
|
// TODO: Look into ways to find the device ID on FGLRX.
|
||||||
|
} else {
|
||||||
|
NS_WARNING("Failed to detect GL vendor!");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fallback to GL_VENDOR and GL_RENDERER.
|
||||||
|
if (mVendorId.IsEmpty()) {
|
||||||
|
mVendorId.Assign(glVendor.get());
|
||||||
|
}
|
||||||
|
if (mDeviceId.IsEmpty()) {
|
||||||
|
mDeviceId.Assign(glRenderer.get());
|
||||||
|
}
|
||||||
|
|
||||||
|
mAdapterDescription.Assign(glRenderer);
|
||||||
|
|
||||||
|
AddCrashReportAnnotations();
|
||||||
}
|
}
|
||||||
|
|
||||||
const nsTArray<GfxDriverInfo> &GfxInfo::GetGfxDriverInfo() {
|
const nsTArray<GfxDriverInfo> &GfxInfo::GetGfxDriverInfo() {
|
||||||
// Nothing here yet.
|
if (!sDriverInfo->Length()) {
|
||||||
// if (!sDriverInfo->Length()) {
|
// Mesa 10.0 provides the GLX_MESA_query_renderer extension, which allows us
|
||||||
//
|
// to query device IDs backing a GL context for blacklisting.
|
||||||
//}
|
APPEND_TO_DRIVER_BLOCKLIST(
|
||||||
|
OperatingSystem::Linux,
|
||||||
|
(nsAString &)GfxDriverInfo::GetDeviceVendor(VendorMesaAll),
|
||||||
|
GfxDriverInfo::allDevices, GfxDriverInfo::allFeatures,
|
||||||
|
nsIGfxInfo::FEATURE_BLOCKED_DRIVER_VERSION, DRIVER_LESS_THAN,
|
||||||
|
V(10, 0, 0, 0), "FEATURE_FAILURE_OLD_MESA", "Mesa 10.0");
|
||||||
|
|
||||||
|
// NVIDIA baseline (ported from old blocklist)
|
||||||
|
APPEND_TO_DRIVER_BLOCKLIST(
|
||||||
|
OperatingSystem::Linux,
|
||||||
|
(nsAString &)GfxDriverInfo::GetDeviceVendor(VendorNVIDIA),
|
||||||
|
GfxDriverInfo::allDevices, GfxDriverInfo::allFeatures,
|
||||||
|
nsIGfxInfo::FEATURE_BLOCKED_DRIVER_VERSION, DRIVER_LESS_THAN,
|
||||||
|
V(257, 21, 0, 0), "FEATURE_FAILURE_OLD_NVIDIA", "NVIDIA 257.21");
|
||||||
|
|
||||||
|
// fglrx baseline (chosen arbitrarily as 2013-07-22 release).
|
||||||
|
APPEND_TO_DRIVER_BLOCKLIST(
|
||||||
|
OperatingSystem::Linux,
|
||||||
|
(nsAString &)GfxDriverInfo::GetDeviceVendor(VendorATI),
|
||||||
|
GfxDriverInfo::allDevices, GfxDriverInfo::allFeatures,
|
||||||
|
nsIGfxInfo::FEATURE_BLOCKED_DRIVER_VERSION, DRIVER_LESS_THAN,
|
||||||
|
V(13, 15, 100, 1), "FEATURE_FAILURE_OLD_FGLRX", "fglrx 13.15.100.1");
|
||||||
|
}
|
||||||
return *sDriverInfo;
|
return *sDriverInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool GfxInfo::DoesVendorMatch(const nsAString &aBlocklistVendor,
|
||||||
|
const nsAString &aAdapterVendor) {
|
||||||
|
if (mIsMesa &&
|
||||||
|
aBlocklistVendor.Equals(GfxDriverInfo::GetDeviceVendor(VendorMesaAll),
|
||||||
|
nsCaseInsensitiveStringComparator())) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return GfxInfoBase::DoesVendorMatch(aBlocklistVendor, aAdapterVendor);
|
||||||
|
}
|
||||||
|
|
||||||
nsresult GfxInfo::GetFeatureStatusImpl(
|
nsresult GfxInfo::GetFeatureStatusImpl(
|
||||||
int32_t aFeature, int32_t *aStatus, nsAString &aSuggestedDriverVersion,
|
int32_t aFeature, int32_t *aStatus, nsAString &aSuggestedDriverVersion,
|
||||||
const nsTArray<GfxDriverInfo> &aDriverInfo, nsACString &aFailureId,
|
const nsTArray<GfxDriverInfo> &aDriverInfo, nsACString &aFailureId,
|
||||||
@ -268,6 +339,13 @@ nsresult GfxInfo::GetFeatureStatusImpl(
|
|||||||
|
|
||||||
GetData();
|
GetData();
|
||||||
|
|
||||||
|
if (mGLMajorVersion == 0) {
|
||||||
|
// If we failed to get a GL version, glxtest failed.
|
||||||
|
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_DEVICE;
|
||||||
|
aFailureId = "FEATURE_FAILURE_GLXTEST_FAILED";
|
||||||
|
return NS_OK;
|
||||||
|
}
|
||||||
|
|
||||||
if (mGLMajorVersion == 1) {
|
if (mGLMajorVersion == 1) {
|
||||||
// We're on OpenGL 1. In most cases that indicates really old hardware.
|
// We're on OpenGL 1. In most cases that indicates really old hardware.
|
||||||
// We better block them, rather than rely on them to fail gracefully,
|
// We better block them, rather than rely on them to fail gracefully,
|
||||||
@ -277,103 +355,13 @@ nsresult GfxInfo::GetFeatureStatusImpl(
|
|||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Don't evaluate any special cases if we're checking the downloaded
|
// Blacklist software GL implementations from using layers acceleration.
|
||||||
// blocklist.
|
// On the test infrastructure, we'll force-enable layers acceleration.
|
||||||
if (!aDriverInfo.Length()) {
|
if (aFeature == nsIGfxInfo::FEATURE_OPENGL_LAYERS && !mIsAccelerated &&
|
||||||
// Blacklist software GL implementations from using layers acceleration.
|
!PR_GetEnv("MOZ_LAYERS_ALLOW_SOFTWARE_GL")) {
|
||||||
// On the test infrastructure, we'll force-enable layers acceleration.
|
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_DEVICE;
|
||||||
if (aFeature == nsIGfxInfo::FEATURE_OPENGL_LAYERS &&
|
aFailureId = "FEATURE_FAILURE_SOFTWARE_GL";
|
||||||
(mIsLlvmpipe || mIsOldSwrast) &&
|
return NS_OK;
|
||||||
!PR_GetEnv("MOZ_LAYERS_ALLOW_SOFTWARE_GL")) {
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_DEVICE;
|
|
||||||
aFailureId = "FEATURE_FAILURE_SOFTWARE_GL";
|
|
||||||
return NS_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (aFeature == nsIGfxInfo::FEATURE_WEBRENDER) {
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_OS_VERSION;
|
|
||||||
aFailureId = "FEATURE_UNQUALIFIED_WEBRENDER_LINUX";
|
|
||||||
return NS_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Only check features relevant to Linux.
|
|
||||||
if (aFeature == nsIGfxInfo::FEATURE_OPENGL_LAYERS ||
|
|
||||||
aFeature == nsIGfxInfo::FEATURE_WEBGL_OPENGL ||
|
|
||||||
aFeature == nsIGfxInfo::FEATURE_WEBGL2 ||
|
|
||||||
aFeature == nsIGfxInfo::FEATURE_WEBGL_MSAA) {
|
|
||||||
// whitelist the linux test slaves' current configuration.
|
|
||||||
// this is necessary as they're still using the slightly outdated 190.42
|
|
||||||
// driver. this isn't a huge risk, as at least this is the exact setting
|
|
||||||
// in which we do continuous testing, and this only affects GeForce 9400
|
|
||||||
// cards on linux on this precise driver version, which is very few users.
|
|
||||||
// We do the same thing on Windows XP, see in widget/windows/GfxInfo.cpp
|
|
||||||
if (mIsNVIDIA && !strcmp(mRenderer.get(), "GeForce 9400/PCI/SSE2") &&
|
|
||||||
!strcmp(mVersion.get(), "3.2.0 NVIDIA 190.42")) {
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_STATUS_OK;
|
|
||||||
return NS_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mIsMesa) {
|
|
||||||
if (mIsNouveau &&
|
|
||||||
version(mMajorVersion, mMinorVersion) < version(8, 0)) {
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_DRIVER_VERSION;
|
|
||||||
aFailureId = "FEATURE_FAILURE_MESA_1";
|
|
||||||
aSuggestedDriverVersion.AssignLiteral("Mesa 8.0");
|
|
||||||
} else if (version(mMajorVersion, mMinorVersion, mRevisionVersion) <
|
|
||||||
version(7, 10, 3)) {
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_DRIVER_VERSION;
|
|
||||||
aFailureId = "FEATURE_FAILURE_MESA_2";
|
|
||||||
aSuggestedDriverVersion.AssignLiteral("Mesa 7.10.3");
|
|
||||||
} else if (mIsOldSwrast) {
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_DRIVER_VERSION;
|
|
||||||
aFailureId = "FEATURE_FAILURE_SW_RAST";
|
|
||||||
} else if (mIsLlvmpipe &&
|
|
||||||
version(mMajorVersion, mMinorVersion) < version(9, 1)) {
|
|
||||||
// bug 791905, Mesa bug 57733, fixed in Mesa 9.1 according to
|
|
||||||
// https://bugs.freedesktop.org/show_bug.cgi?id=57733#c3
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_DRIVER_VERSION;
|
|
||||||
aFailureId = "FEATURE_FAILURE_MESA_3";
|
|
||||||
} else if (aFeature == nsIGfxInfo::FEATURE_WEBGL_MSAA) {
|
|
||||||
if (mIsIntel &&
|
|
||||||
version(mMajorVersion, mMinorVersion) < version(8, 1)) {
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_DRIVER_VERSION;
|
|
||||||
aFailureId = "FEATURE_FAILURE_MESA_4";
|
|
||||||
aSuggestedDriverVersion.AssignLiteral("Mesa 8.1");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
} else if (mIsNVIDIA) {
|
|
||||||
if (version(mMajorVersion, mMinorVersion, mRevisionVersion) <
|
|
||||||
version(257, 21)) {
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_DRIVER_VERSION;
|
|
||||||
aFailureId = "FEATURE_FAILURE_OLD_NV";
|
|
||||||
aSuggestedDriverVersion.AssignLiteral("NVIDIA 257.21");
|
|
||||||
}
|
|
||||||
} else if (mIsFGLRX) {
|
|
||||||
// FGLRX does not report a driver version number, so we have the OpenGL
|
|
||||||
// version instead. by requiring OpenGL 3, we effectively require recent
|
|
||||||
// drivers.
|
|
||||||
if (version(mMajorVersion, mMinorVersion, mRevisionVersion) <
|
|
||||||
version(3, 0)) {
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_DRIVER_VERSION;
|
|
||||||
aFailureId = "FEATURE_FAILURE_OLD_FGLRX";
|
|
||||||
aSuggestedDriverVersion.AssignLiteral("<Something recent>");
|
|
||||||
}
|
|
||||||
// Bug 724640: FGLRX + Linux 2.6.32 is a crashy combo
|
|
||||||
bool unknownOS = mOS.IsEmpty() || mOSRelease.IsEmpty();
|
|
||||||
bool badOS =
|
|
||||||
mOS.Find("Linux", true) != -1 && mOSRelease.Find("2.6.32") != -1;
|
|
||||||
if (unknownOS || badOS) {
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_OS_VERSION;
|
|
||||||
aFailureId = "FEATURE_FAILURE_OLD_OS";
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// like on windows, let's block unknown vendors. Think of virtual
|
|
||||||
// machines. Also, this case is hit whenever the GLXtest probe failed to
|
|
||||||
// get driver info or crashed.
|
|
||||||
*aStatus = nsIGfxInfo::FEATURE_BLOCKED_DEVICE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return GfxInfoBase::GetFeatureStatusImpl(
|
return GfxInfoBase::GetFeatureStatusImpl(
|
||||||
@ -410,7 +398,8 @@ GfxInfo::GetAdapterDescription2(nsAString &aAdapterDescription) {
|
|||||||
|
|
||||||
NS_IMETHODIMP
|
NS_IMETHODIMP
|
||||||
GfxInfo::GetAdapterRAM(nsAString &aAdapterRAM) {
|
GfxInfo::GetAdapterRAM(nsAString &aAdapterRAM) {
|
||||||
aAdapterRAM.Truncate();
|
GetData();
|
||||||
|
CopyUTF8toUTF16(mAdapterRAM, aAdapterRAM);
|
||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -431,7 +420,7 @@ GfxInfo::GetAdapterDriver2(nsAString &aAdapterDriver) {
|
|||||||
NS_IMETHODIMP
|
NS_IMETHODIMP
|
||||||
GfxInfo::GetAdapterDriverVersion(nsAString &aAdapterDriverVersion) {
|
GfxInfo::GetAdapterDriverVersion(nsAString &aAdapterDriverVersion) {
|
||||||
GetData();
|
GetData();
|
||||||
CopyASCIItoUTF16(mVersion, aAdapterDriverVersion);
|
CopyASCIItoUTF16(mDriverVersion, aAdapterDriverVersion);
|
||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -454,7 +443,7 @@ GfxInfo::GetAdapterDriverDate2(nsAString &aAdapterDriverDate) {
|
|||||||
NS_IMETHODIMP
|
NS_IMETHODIMP
|
||||||
GfxInfo::GetAdapterVendorID(nsAString &aAdapterVendorID) {
|
GfxInfo::GetAdapterVendorID(nsAString &aAdapterVendorID) {
|
||||||
GetData();
|
GetData();
|
||||||
CopyUTF8toUTF16(mVendor, aAdapterVendorID);
|
CopyUTF8toUTF16(mVendorId, aAdapterVendorID);
|
||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -466,7 +455,7 @@ GfxInfo::GetAdapterVendorID2(nsAString &aAdapterVendorID) {
|
|||||||
NS_IMETHODIMP
|
NS_IMETHODIMP
|
||||||
GfxInfo::GetAdapterDeviceID(nsAString &aAdapterDeviceID) {
|
GfxInfo::GetAdapterDeviceID(nsAString &aAdapterDeviceID) {
|
||||||
GetData();
|
GetData();
|
||||||
CopyUTF8toUTF16(mRenderer, aAdapterDeviceID);
|
CopyUTF8toUTF16(mDeviceId, aAdapterDeviceID);
|
||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -494,17 +483,23 @@ GfxInfo::GetIsGPU2Active(bool *aIsGPU2Active) { return NS_ERROR_FAILURE; }
|
|||||||
// We don't support spoofing anything on Linux
|
// We don't support spoofing anything on Linux
|
||||||
|
|
||||||
NS_IMETHODIMP GfxInfo::SpoofVendorID(const nsAString &aVendorID) {
|
NS_IMETHODIMP GfxInfo::SpoofVendorID(const nsAString &aVendorID) {
|
||||||
CopyUTF16toUTF8(aVendorID, mVendor);
|
GetData();
|
||||||
|
CopyUTF16toUTF8(aVendorID, mVendorId);
|
||||||
|
mIsAccelerated = !(mVendorId.EqualsLiteral("mesa/llvmpipe") ||
|
||||||
|
mVendorId.EqualsLiteral("mesa/softpipe") ||
|
||||||
|
mVendorId.EqualsLiteral("mesa/swrast"));
|
||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
NS_IMETHODIMP GfxInfo::SpoofDeviceID(const nsAString &aDeviceID) {
|
NS_IMETHODIMP GfxInfo::SpoofDeviceID(const nsAString &aDeviceID) {
|
||||||
CopyUTF16toUTF8(aDeviceID, mRenderer);
|
GetData();
|
||||||
|
CopyUTF16toUTF8(aDeviceID, mDeviceId);
|
||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
NS_IMETHODIMP GfxInfo::SpoofDriverVersion(const nsAString &aDriverVersion) {
|
NS_IMETHODIMP GfxInfo::SpoofDriverVersion(const nsAString &aDriverVersion) {
|
||||||
CopyUTF16toUTF8(aDriverVersion, mVersion);
|
GetData();
|
||||||
|
CopyUTF16toUTF8(aDriverVersion, mDriverVersion);
|
||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -513,6 +508,16 @@ NS_IMETHODIMP GfxInfo::SpoofOSVersion(uint32_t aVersion) {
|
|||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NS_IMETHODIMP GfxInfo::FireTestProcess() {
|
||||||
|
// If the pid is zero, then we have never run the test process to query for
|
||||||
|
// driver information. This would normally be run on startup, but we need to
|
||||||
|
// manually invoke it for XPC shell tests.
|
||||||
|
if (glxtest_pid == 0) {
|
||||||
|
fire_glxtest_process();
|
||||||
|
}
|
||||||
|
return NS_OK;
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
} // end namespace widget
|
} // end namespace widget
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
#define __GfxInfoX11_h__
|
#define __GfxInfoX11_h__
|
||||||
|
|
||||||
#include "GfxInfoBase.h"
|
#include "GfxInfoBase.h"
|
||||||
|
#include "nsString.h"
|
||||||
|
|
||||||
namespace mozilla {
|
namespace mozilla {
|
||||||
namespace widget {
|
namespace widget {
|
||||||
@ -60,17 +61,21 @@ class GfxInfo final : public GfxInfoBase {
|
|||||||
OperatingSystem* aOS = nullptr) override;
|
OperatingSystem* aOS = nullptr) override;
|
||||||
virtual const nsTArray<GfxDriverInfo>& GetGfxDriverInfo() override;
|
virtual const nsTArray<GfxDriverInfo>& GetGfxDriverInfo() override;
|
||||||
|
|
||||||
|
virtual bool DoesVendorMatch(const nsAString& aBlocklistVendor,
|
||||||
|
const nsAString& aAdapterVendor) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
nsCString mVendor;
|
nsCString mVendorId;
|
||||||
nsCString mRenderer;
|
nsCString mDeviceId;
|
||||||
nsCString mVersion;
|
nsCString mDriverVersion;
|
||||||
nsCString mAdapterDescription;
|
nsCString mAdapterDescription;
|
||||||
|
nsCString mAdapterRAM;
|
||||||
nsCString mOS;
|
nsCString mOS;
|
||||||
nsCString mOSRelease;
|
nsCString mOSRelease;
|
||||||
bool mIsMesa, mIsNVIDIA, mIsFGLRX, mIsNouveau, mIsIntel, mIsOldSwrast,
|
|
||||||
mIsLlvmpipe;
|
|
||||||
bool mHasTextureFromPixmap;
|
bool mHasTextureFromPixmap;
|
||||||
int mGLMajorVersion, mMajorVersion, mMinorVersion, mRevisionVersion;
|
unsigned int mGLMajorVersion, mGLMinorVersion;
|
||||||
|
bool mIsMesa;
|
||||||
|
bool mIsAccelerated;
|
||||||
|
|
||||||
void AddCrashReportAnnotations();
|
void AddCrashReportAnnotations();
|
||||||
};
|
};
|
||||||
|
@ -533,6 +533,10 @@ NS_IMETHODIMP GfxInfo::SpoofOSVersion(uint32_t aVersion) {
|
|||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NS_IMETHODIMP GfxInfo::FireTestProcess() {
|
||||||
|
return NS_OK;
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
nsString GfxInfo::Model() {
|
nsString GfxInfo::Model() {
|
||||||
|
@ -354,4 +354,9 @@ NS_IMETHODIMP GfxInfo::SpoofOSVersion(uint32_t aVersion) {
|
|||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* void fireTestProcess (); */
|
||||||
|
NS_IMETHODIMP GfxInfo::FireTestProcess() {
|
||||||
|
return NS_OK;
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -16,4 +16,9 @@ interface nsIGfxInfoDebug : nsISupports
|
|||||||
void spoofDriverVersion(in AString aDriverVersion);
|
void spoofDriverVersion(in AString aDriverVersion);
|
||||||
|
|
||||||
void spoofOSVersion(in unsigned long aVersion);
|
void spoofOSVersion(in unsigned long aVersion);
|
||||||
|
|
||||||
|
/* Manually invoke any test processes required to query for driver
|
||||||
|
information. This is used by XPC shell tests which do not run these queries
|
||||||
|
by default. */
|
||||||
|
void fireTestProcess();
|
||||||
};
|
};
|
||||||
|
@ -1827,4 +1827,8 @@ NS_IMETHODIMP GfxInfo::SpoofOSVersion(uint32_t aVersion) {
|
|||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NS_IMETHODIMP GfxInfo::FireTestProcess() {
|
||||||
|
return NS_OK;
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user