зеркало из https://github.com/AvaloniaUI/angle.git
Infra: Enable angle_deqp_gl46_tests on SwiftShader
This change disables the WGL frontend by default on Windows when building ANGLE for desktop GL. This is because the WGL frontend is not yet fully implemented and it causes some of the trace tests to fail. The WGL frontend should be enabled by default on windows when more of its functionality gets implemented. Test: angle_deqp_gl46_tests --use-angle=swiftshader Bug: angleproject:7566 Bug: angleproject:7628 Change-Id: I69c695eb56d3858f715eeb86d28cc805e25c60eb Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/3858142 Reviewed-by: Jamie Madill <jmadill@chromium.org> Reviewed-by: Geoff Lang <geofflang@chromium.org> Reviewed-by: Cody Northrop <cnorthrop@google.com> Commit-Queue: Cody Northrop <cnorthrop@google.com>
This commit is contained in:
Родитель
80f6a63afc
Коммит
3960e63b1a
26
BUILD.gn
26
BUILD.gn
|
@ -1307,7 +1307,7 @@ template("angle_libGLESv2") {
|
|||
if (angle_enable_gl_desktop_frontend) {
|
||||
sources += libglesv2_gl_sources
|
||||
defines += [ "ANGLE_ENABLE_GL_DESKTOP_FRONTEND" ]
|
||||
if (is_win) {
|
||||
if (angle_expose_wgl_entry_points) {
|
||||
sources += [
|
||||
"src/libGLESv2/entry_points_wgl.cpp",
|
||||
"src/libGLESv2/entry_points_wgl.h",
|
||||
|
@ -1315,13 +1315,15 @@ template("angle_libGLESv2") {
|
|||
"src/libGLESv2/proc_table_wgl_autogen.cpp",
|
||||
]
|
||||
defines += [ "ANGLE_EXPOSE_WGL_ENTRY_POINTS" ]
|
||||
} else {
|
||||
} else if (angle_expose_glx_entry_points) {
|
||||
sources += [
|
||||
"src/libGLESv2/entry_points_glx.cpp",
|
||||
"src/libGLESv2/entry_points_glx.h",
|
||||
"src/libGLESv2/proc_table_glx.h",
|
||||
"src/libGLESv2/proc_table_glx_autogen.cpp",
|
||||
]
|
||||
} else {
|
||||
#TODO(http://anglebug.com/7533): Add CGL entry points for mac support
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1330,10 +1332,12 @@ template("angle_libGLESv2") {
|
|||
}
|
||||
|
||||
if (is_win) {
|
||||
sources += [
|
||||
"src/libGLESv2/${invoker.output_name}_autogen.def",
|
||||
"src/libGLESv2/libGLESv2.rc",
|
||||
]
|
||||
if (angle_expose_wgl_entry_points) {
|
||||
sources += [ "src/libGLESv2/opengl32_with_wgl_autogen.def" ]
|
||||
} else {
|
||||
sources += [ "src/libGLESv2/${invoker.output_name}_autogen.def" ]
|
||||
}
|
||||
sources += [ "src/libGLESv2/libGLESv2.rc" ]
|
||||
deps += [ ":angle_version" ]
|
||||
}
|
||||
}
|
||||
|
@ -1377,7 +1381,7 @@ angle_static_library("libGLESv2_static") {
|
|||
if (angle_enable_gl_desktop_frontend) {
|
||||
sources += libglesv2_gl_sources
|
||||
defines = [ "ANGLE_ENABLE_GL_DESKTOP_FRONTEND" ]
|
||||
if (is_win) {
|
||||
if (angle_expose_wgl_entry_points) {
|
||||
sources += [
|
||||
"src/libGLESv2/entry_points_wgl.cpp",
|
||||
"src/libGLESv2/entry_points_wgl.h",
|
||||
|
@ -1385,13 +1389,15 @@ angle_static_library("libGLESv2_static") {
|
|||
"src/libGLESv2/proc_table_wgl_autogen.cpp",
|
||||
]
|
||||
defines += [ "ANGLE_EXPOSE_WGL_ENTRY_POINTS" ]
|
||||
} else {
|
||||
} else if (angle_expose_glx_entry_points) {
|
||||
sources += [
|
||||
"src/libGLESv2/entry_points_glx.cpp",
|
||||
"src/libGLESv2/entry_points_glx.h",
|
||||
"src/libGLESv2/proc_table_glx.h",
|
||||
"src/libGLESv2/proc_table_glx_autogen.cpp",
|
||||
]
|
||||
} else {
|
||||
#TODO(http://anglebug.com/7533): Add CGL entry points for mac support
|
||||
}
|
||||
}
|
||||
if (angle_enable_cl) {
|
||||
|
@ -1478,6 +1484,10 @@ angle_shared_library("libEGL") {
|
|||
deps += [ ":angle_version" ]
|
||||
}
|
||||
|
||||
if (angle_enable_gl_desktop_frontend) {
|
||||
defines += [ "ANGLE_ENABLE_GL_DESKTOP_FRONTEND" ]
|
||||
}
|
||||
|
||||
public_deps = [ ":includes" ]
|
||||
|
||||
data_deps = [ ":libGLESv2" ]
|
||||
|
|
|
@ -30,10 +30,13 @@ declare_args() {
|
|||
}
|
||||
|
||||
declare_args() {
|
||||
# Expose WGL entry points by default when using Desktop GL on Windows
|
||||
angle_expose_wgl_entry_points = angle_enable_gl_desktop_frontend && is_win
|
||||
# Expose WGL entry points, which is necessary for running windows desktop GL applications against ANGLE.
|
||||
# TODO(http://anglebug.com/7628): This condition should be `angle_enable_gl_desktop_frontend && is_win`
|
||||
# This is disabled by default on Windows because it was causing some test failures. Once the WGL frontend
|
||||
# has more functionality implemented, we can re-enable this.
|
||||
angle_expose_wgl_entry_points = false
|
||||
|
||||
# Expose GLX entry points by default when using Desktop GL on Linux
|
||||
# Expose GLX entry points by default when using Desktop GL on Linux.
|
||||
angle_expose_glx_entry_points = angle_enable_gl_desktop_frontend && is_linux
|
||||
}
|
||||
|
||||
|
|
|
@ -1903,6 +1903,36 @@
|
|||
"test_id_prefix": "ninja://src/tests:angle_deqp_egl_tests/",
|
||||
"use_isolated_scripts_api": true
|
||||
},
|
||||
{
|
||||
"args": [
|
||||
"angle_deqp_gl46_tests",
|
||||
"--use-angle=swiftshader",
|
||||
"--bot-mode",
|
||||
"--xvfb"
|
||||
],
|
||||
"merge": {
|
||||
"args": [],
|
||||
"script": "//testing/merge_scripts/standard_isolated_script_merge.py"
|
||||
},
|
||||
"swarming": {
|
||||
"can_use_on_swarming_builders": true,
|
||||
"containment_type": "AUTO",
|
||||
"dimension_sets": [
|
||||
{
|
||||
"cpu": "x86-64",
|
||||
"gpu": "none",
|
||||
"os": "Ubuntu-18.04",
|
||||
"pool": "chromium.tests.gpu"
|
||||
}
|
||||
],
|
||||
"hard_timeout": 900,
|
||||
"io_timeout": 900,
|
||||
"service_account": "chromium-tester@chops-service-accounts.iam.gserviceaccount.com"
|
||||
},
|
||||
"test": "angle_deqp_gl46_tests",
|
||||
"test_id_prefix": "ninja://src/tests:angle_deqp_gl46_tests/",
|
||||
"use_isolated_scripts_api": true
|
||||
},
|
||||
{
|
||||
"args": [
|
||||
"angle_deqp_gles2_tests",
|
||||
|
@ -2399,6 +2429,36 @@
|
|||
"test_id_prefix": "ninja://src/tests:angle_deqp_egl_tests/",
|
||||
"use_isolated_scripts_api": true
|
||||
},
|
||||
{
|
||||
"args": [
|
||||
"angle_deqp_gl46_tests",
|
||||
"--use-angle=swiftshader",
|
||||
"--bot-mode",
|
||||
"--xvfb"
|
||||
],
|
||||
"merge": {
|
||||
"args": [],
|
||||
"script": "//testing/merge_scripts/standard_isolated_script_merge.py"
|
||||
},
|
||||
"swarming": {
|
||||
"can_use_on_swarming_builders": true,
|
||||
"containment_type": "AUTO",
|
||||
"dimension_sets": [
|
||||
{
|
||||
"cpu": "x86-64",
|
||||
"gpu": "none",
|
||||
"os": "Ubuntu-18.04",
|
||||
"pool": "chromium.tests.gpu"
|
||||
}
|
||||
],
|
||||
"hard_timeout": 900,
|
||||
"io_timeout": 900,
|
||||
"service_account": "chromium-tester@chops-service-accounts.iam.gserviceaccount.com"
|
||||
},
|
||||
"test": "angle_deqp_gl46_tests",
|
||||
"test_id_prefix": "ninja://src/tests:angle_deqp_gl46_tests/",
|
||||
"use_isolated_scripts_api": true
|
||||
},
|
||||
{
|
||||
"args": [
|
||||
"angle_deqp_gles2_tests",
|
||||
|
@ -3103,6 +3163,36 @@
|
|||
"test_id_prefix": "ninja://src/tests:angle_deqp_egl_tests/",
|
||||
"use_isolated_scripts_api": true
|
||||
},
|
||||
{
|
||||
"args": [
|
||||
"angle_deqp_gl46_tests",
|
||||
"--use-angle=swiftshader",
|
||||
"--bot-mode",
|
||||
"--xvfb"
|
||||
],
|
||||
"merge": {
|
||||
"args": [],
|
||||
"script": "//testing/merge_scripts/standard_isolated_script_merge.py"
|
||||
},
|
||||
"swarming": {
|
||||
"can_use_on_swarming_builders": true,
|
||||
"containment_type": "AUTO",
|
||||
"dimension_sets": [
|
||||
{
|
||||
"cpu": "x86-64",
|
||||
"gpu": "none",
|
||||
"os": "Ubuntu-18.04",
|
||||
"pool": "chromium.tests.gpu"
|
||||
}
|
||||
],
|
||||
"hard_timeout": 900,
|
||||
"io_timeout": 900,
|
||||
"service_account": "chromium-tester@chops-service-accounts.iam.gserviceaccount.com"
|
||||
},
|
||||
"test": "angle_deqp_gl46_tests",
|
||||
"test_id_prefix": "ninja://src/tests:angle_deqp_gl46_tests/",
|
||||
"use_isolated_scripts_api": true
|
||||
},
|
||||
{
|
||||
"args": [
|
||||
"angle_deqp_gles2_tests",
|
||||
|
@ -5067,6 +5157,35 @@
|
|||
"test_id_prefix": "ninja://src/tests:angle_deqp_egl_tests/",
|
||||
"use_isolated_scripts_api": true
|
||||
},
|
||||
{
|
||||
"args": [
|
||||
"angle_deqp_gl46_tests",
|
||||
"--use-angle=swiftshader",
|
||||
"--bot-mode"
|
||||
],
|
||||
"merge": {
|
||||
"args": [],
|
||||
"script": "//testing/merge_scripts/standard_isolated_script_merge.py"
|
||||
},
|
||||
"swarming": {
|
||||
"can_use_on_swarming_builders": true,
|
||||
"containment_type": "AUTO",
|
||||
"dimension_sets": [
|
||||
{
|
||||
"cpu": "x86-64",
|
||||
"gpu": "none",
|
||||
"os": "Windows-10",
|
||||
"pool": "chromium.tests.gpu"
|
||||
}
|
||||
],
|
||||
"hard_timeout": 900,
|
||||
"io_timeout": 900,
|
||||
"service_account": "chromium-tester@chops-service-accounts.iam.gserviceaccount.com"
|
||||
},
|
||||
"test": "angle_deqp_gl46_tests",
|
||||
"test_id_prefix": "ninja://src/tests:angle_deqp_gl46_tests/",
|
||||
"use_isolated_scripts_api": true
|
||||
},
|
||||
{
|
||||
"args": [
|
||||
"angle_deqp_gles2_tests",
|
||||
|
@ -5609,6 +5728,35 @@
|
|||
"test_id_prefix": "ninja://src/tests:angle_deqp_egl_tests/",
|
||||
"use_isolated_scripts_api": true
|
||||
},
|
||||
{
|
||||
"args": [
|
||||
"angle_deqp_gl46_tests",
|
||||
"--use-angle=swiftshader",
|
||||
"--bot-mode"
|
||||
],
|
||||
"merge": {
|
||||
"args": [],
|
||||
"script": "//testing/merge_scripts/standard_isolated_script_merge.py"
|
||||
},
|
||||
"swarming": {
|
||||
"can_use_on_swarming_builders": true,
|
||||
"containment_type": "AUTO",
|
||||
"dimension_sets": [
|
||||
{
|
||||
"cpu": "x86-64",
|
||||
"gpu": "none",
|
||||
"os": "Windows-10",
|
||||
"pool": "chromium.tests.gpu"
|
||||
}
|
||||
],
|
||||
"hard_timeout": 900,
|
||||
"io_timeout": 900,
|
||||
"service_account": "chromium-tester@chops-service-accounts.iam.gserviceaccount.com"
|
||||
},
|
||||
"test": "angle_deqp_gl46_tests",
|
||||
"test_id_prefix": "ninja://src/tests:angle_deqp_gl46_tests/",
|
||||
"use_isolated_scripts_api": true
|
||||
},
|
||||
{
|
||||
"args": [
|
||||
"angle_deqp_gles2_tests",
|
||||
|
|
|
@ -53,23 +53,23 @@
|
|||
# is not necessarily so (i.e., we might have mac, win, and linux
|
||||
# bots all using the 'release_bot' config).
|
||||
'configs': {
|
||||
'angle_asan_bot': ['angle', 'opencl', 'traces', 'goma', 'asan', 'release'],
|
||||
'angle_asan_bot': ['angle', 'opencl', 'traces', 'goma', 'asan', 'release', 'desktop'],
|
||||
'angle_goma_android_arm64_debug_bot': ['angle', 'opencl', 'traces', 'goma', 'android', 'arm64', 'debug'],
|
||||
'angle_goma_android_arm64_release_bot': ['angle', 'opencl', 'traces', 'goma', 'android', 'arm64', 'release'],
|
||||
'angle_goma_android_arm_debug_bot': ['angle', 'opencl', 'traces', 'goma', 'android', 'arm', 'debug'],
|
||||
'angle_goma_android_arm_release_bot': ['angle', 'opencl', 'traces', 'goma', 'android', 'arm', 'release'],
|
||||
'angle_goma_android_perf_bot': ['angle', 'traces', 'goma', 'android', 'arm64', 'perf'],
|
||||
'angle_goma_debug_bot': ['angle', 'opencl', 'traces', 'goma', 'debug'],
|
||||
'angle_goma_debug_bot': ['angle', 'opencl', 'traces', 'goma', 'debug', 'desktop'],
|
||||
'angle_goma_perf_bot': ['angle', 'traces', 'goma', 'perf'],
|
||||
'angle_goma_release_bot': ['angle', 'opencl', 'traces', 'goma', 'release'],
|
||||
'angle_goma_x86_debug_bot': ['angle', 'opencl', 'traces', 'goma', 'x86', 'debug'],
|
||||
'angle_goma_x86_release_bot': ['angle', 'opencl', 'traces', 'goma', 'x86', 'release'],
|
||||
'angle_non_clang_debug_bot': ['angle', 'opencl', 'non_clang', 'debug'],
|
||||
'angle_non_clang_release_bot': ['angle', 'opencl', 'non_clang', 'release'],
|
||||
'angle_goma_release_bot': ['angle', 'opencl', 'traces', 'goma', 'release', 'desktop'],
|
||||
'angle_goma_x86_debug_bot': ['angle', 'opencl', 'traces', 'goma', 'x86', 'debug', 'desktop'],
|
||||
'angle_goma_x86_release_bot': ['angle', 'opencl', 'traces', 'goma', 'x86', 'release', 'desktop'],
|
||||
'angle_non_clang_debug_bot': ['angle', 'opencl', 'non_clang', 'debug', 'desktop'],
|
||||
'angle_non_clang_release_bot': ['angle', 'opencl', 'non_clang', 'release', 'desktop'],
|
||||
'angle_non_clang_x86_debug_bot': ['angle', 'opencl', 'non_clang', 'x86', 'debug'],
|
||||
'angle_non_clang_x86_release_bot': ['angle', 'opencl', 'non_clang', 'x86', 'release'],
|
||||
'angle_tsan_bot': ['angle', 'opencl', 'traces', 'goma', 'tsan', 'release'],
|
||||
'angle_ubsan_bot': ['angle', 'opencl', 'traces', 'goma', 'ubsan', 'release'],
|
||||
'angle_tsan_bot': ['angle', 'opencl', 'traces', 'goma', 'tsan', 'release', 'desktop'],
|
||||
'angle_ubsan_bot': ['angle', 'opencl', 'traces', 'goma', 'ubsan', 'release', 'desktop'],
|
||||
'angle_winuwp_non_clang_debug_bot': ['angle', 'winuwp', 'non_clang', 'debug'],
|
||||
'angle_winuwp_non_clang_release_bot': ['angle', 'winuwp', 'non_clang', 'release'],
|
||||
},
|
||||
|
@ -95,6 +95,9 @@
|
|||
'debug': {
|
||||
'gn_args': 'is_debug=true',
|
||||
},
|
||||
'desktop': {
|
||||
'gn_args': 'angle_enable_gl_desktop_frontend=true',
|
||||
},
|
||||
'goma': {
|
||||
'gn_args': 'use_goma=true',
|
||||
},
|
||||
|
|
|
@ -31,6 +31,11 @@
|
|||
"script": "//scripts/run_gtest_angle_test.py",
|
||||
"type": "script",
|
||||
},
|
||||
"angle_deqp_gl46_tests": {
|
||||
"label": "//src/tests:angle_deqp_gl46_tests",
|
||||
"script": "//scripts/run_gtest_angle_test.py",
|
||||
"type": "script",
|
||||
},
|
||||
"angle_deqp_gles2_tests": {
|
||||
"label": "//src/tests:angle_deqp_gles2_tests",
|
||||
"script": "//scripts/run_gtest_angle_test.py",
|
||||
|
|
|
@ -821,6 +821,20 @@
|
|||
},
|
||||
},
|
||||
|
||||
'swangle_deqp_gl46_tests': {
|
||||
'angle_deqp_gl46_tests': {
|
||||
'args': [
|
||||
'angle_deqp_gl46_tests',
|
||||
'--use-angle=swiftshader',
|
||||
'--bot-mode',
|
||||
],
|
||||
'linux_args': [
|
||||
'--xvfb',
|
||||
],
|
||||
'use_isolated_scripts_api': True,
|
||||
},
|
||||
},
|
||||
|
||||
'swangle_deqp_gles2_slow_tests': {
|
||||
'angle_deqp_gles2_tests': {
|
||||
'args': [
|
||||
|
@ -1180,6 +1194,7 @@
|
|||
|
||||
'swangle_gtests': [
|
||||
'swangle_deqp_egl_tests',
|
||||
'swangle_deqp_gl46_tests',
|
||||
'swangle_deqp_gles2_tests',
|
||||
'swangle_deqp_gles31_rotate180_tests',
|
||||
'swangle_deqp_gles31_rotate270_tests',
|
||||
|
|
|
@ -1,10 +1,10 @@
|
|||
{
|
||||
"scripts/gen_vk_gl_cts_build.py":
|
||||
"8abffec79db397a338cd1e7479150070",
|
||||
"24739596e62c08ed31dbd22a5b8e77be",
|
||||
"src/tests/deqp_support/BUILD.gn":
|
||||
"235621d23c9fc11885f6a29541679898",
|
||||
"src/tests/deqp_support/deqp_data_autogen.gni":
|
||||
"a0682f2bfc3f3dadfbcee16ab727ca64",
|
||||
"66f7f626b3f33cd2aaaceb0592680be9",
|
||||
"third_party/VK-GL-CTS/src/CMakeLists.txt":
|
||||
"a67323a0062016d215a0a219272ec139",
|
||||
"third_party/VK-GL-CTS/src/execserver/CMakeLists.txt":
|
||||
|
|
|
@ -6,7 +6,7 @@
|
|||
"scripts/entry_point_packed_gl_enums.json":
|
||||
"413cb2b6fb98a4465d50d59d55757cf3",
|
||||
"scripts/generate_entry_points.py":
|
||||
"b90b38e9891bfef0922702ff0ae101cd",
|
||||
"63853a09d94fcc2fbf07467836b680ad",
|
||||
"scripts/gl.xml":
|
||||
"c79f59912f42e96ea958dddb5e029d47",
|
||||
"scripts/gl_angle_ext.xml":
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
{
|
||||
"infra/specs/angle.json":
|
||||
"5122739559cc6f92a36a99c81a1d8cfd",
|
||||
"7776dc30a62c7c3c83ddb601231161d0",
|
||||
"infra/specs/generate_test_spec_json.py":
|
||||
"be4569626aa91f8872664e2d9cef4ac2",
|
||||
"infra/specs/mixins.pyl":
|
||||
|
@ -8,7 +8,7 @@
|
|||
"infra/specs/test_suite_exceptions.pyl":
|
||||
"a68dc6291f827463cca5fb8101999325",
|
||||
"infra/specs/test_suites.pyl":
|
||||
"aa45ad51d12ab4bd9217778404d7ad31",
|
||||
"2a7d7b099e98e57e2cf3653ee5104d82",
|
||||
"infra/specs/variants.pyl":
|
||||
"8cfcaa99fa07ad2a2d5d14f220fd5037",
|
||||
"infra/specs/waterfalls.pyl":
|
||||
|
|
|
@ -22,7 +22,6 @@ def initDataDirectories(dataDirectories):
|
|||
dataDirectories.append(os.path.join("external", "openglcts", "data", "gles3"))
|
||||
dataDirectories.append(os.path.join("external", "openglcts", "data", "gles31"))
|
||||
dataDirectories.append(os.path.join("external", "openglcts", "data", "gles32"))
|
||||
dataDirectories.append(os.path.join("external", "openglcts", "data", "gl46"))
|
||||
|
||||
|
||||
def initPathReplacements(pathReplacements):
|
||||
|
|
|
@ -3255,8 +3255,9 @@ def main():
|
|||
for lib in ["libGLESv2" + suffix for suffix in ["", "_no_capture", "_with_capture"]]:
|
||||
write_windows_def_file(everything, lib, lib, "libGLESv2", libgles_ep_exports)
|
||||
|
||||
write_windows_def_file(everything, "opengl32", "opengl32", "libGLESv2",
|
||||
write_windows_def_file(everything, "opengl32_with_wgl", "opengl32", "libGLESv2",
|
||||
libgl_ep_exports + sorted(wgl_commands))
|
||||
write_windows_def_file(everything, "opengl32", "opengl32", "libGLESv2", libgl_ep_exports)
|
||||
write_windows_def_file("egl.xml and egl_angle_ext.xml", "libEGL", "libEGL", "libEGL",
|
||||
libegl_windows_def_exports)
|
||||
|
||||
|
|
|
@ -151,8 +151,12 @@ Version GetClientVersion(egl::Display *display,
|
|||
{
|
||||
if (clientType == EGL_OPENGL_API)
|
||||
{
|
||||
return std::max(display->getImplementation()->getMaxSupportedDesktopVersion(),
|
||||
requestedVersion);
|
||||
Optional<gl::Version> maxSupportedDesktopVersion =
|
||||
display->getImplementation()->getMaxSupportedDesktopVersion();
|
||||
if (maxSupportedDesktopVersion.valid())
|
||||
return std::max(maxSupportedDesktopVersion.value(), requestedVersion);
|
||||
else
|
||||
return requestedVersion;
|
||||
}
|
||||
else if (requestedVersion.major == 1)
|
||||
{
|
||||
|
|
|
@ -1035,6 +1035,7 @@ Error Display::initialize()
|
|||
initDisplayExtensions();
|
||||
initVendorString();
|
||||
initVersionString();
|
||||
initClientAPIString();
|
||||
|
||||
// Populate the Display's EGLDeviceEXT if the Display wasn't created using one
|
||||
if (mPlatform == EGL_PLATFORM_DEVICE_EXT)
|
||||
|
@ -2177,6 +2178,19 @@ void Display::initVersionString()
|
|||
mVersionString = mImplementation->getVersionString(true);
|
||||
}
|
||||
|
||||
void Display::initClientAPIString()
|
||||
{
|
||||
// If the max supported desktop version is not None, we support a desktop GL frontend.
|
||||
if (mImplementation->getMaxSupportedDesktopVersion().valid())
|
||||
{
|
||||
mClientAPIString = "OpenGL_ES OpenGL";
|
||||
}
|
||||
else
|
||||
{
|
||||
mClientAPIString = "OpenGL_ES";
|
||||
}
|
||||
}
|
||||
|
||||
void Display::initializeFrontendFeatures()
|
||||
{
|
||||
// Enable on all Impls
|
||||
|
@ -2218,6 +2232,11 @@ const std::string &Display::getVersionString() const
|
|||
return mVersionString;
|
||||
}
|
||||
|
||||
const std::string &Display::getClientAPIString() const
|
||||
{
|
||||
return mClientAPIString;
|
||||
}
|
||||
|
||||
std::string Display::getBackendRendererDescription() const
|
||||
{
|
||||
return mImplementation->getRendererDescription();
|
||||
|
|
|
@ -264,6 +264,7 @@ class Display final : public LabeledObject,
|
|||
const std::string &getExtensionString() const;
|
||||
const std::string &getVendorString() const;
|
||||
const std::string &getVersionString() const;
|
||||
const std::string &getClientAPIString() const;
|
||||
|
||||
std::string getBackendRendererDescription() const;
|
||||
std::string getBackendVendorString() const;
|
||||
|
@ -344,6 +345,7 @@ class Display final : public LabeledObject,
|
|||
void initDisplayExtensions();
|
||||
void initVendorString();
|
||||
void initVersionString();
|
||||
void initClientAPIString();
|
||||
void initializeFrontendFeatures();
|
||||
|
||||
angle::ScratchBuffer requestScratchBufferImpl(std::vector<angle::ScratchBuffer> *bufferVector);
|
||||
|
@ -390,6 +392,7 @@ class Display final : public LabeledObject,
|
|||
|
||||
std::string mVendorString;
|
||||
std::string mVersionString;
|
||||
std::string mClientAPIString;
|
||||
|
||||
Device *mDevice;
|
||||
Surface *mSurface;
|
||||
|
|
|
@ -15,9 +15,11 @@
|
|||
|
||||
namespace gl
|
||||
{
|
||||
const char kUnknownGLenumString[] = "EnumUnknown";
|
||||
namespace
|
||||
{
|
||||
|
||||
void OutputGLenumString(std::ostream &out, GLESEnum enumGroup, unsigned int value)
|
||||
template <typename EnumType>
|
||||
void OutputGLenumStringImpl(std::ostream &out, EnumType enumGroup, unsigned int value)
|
||||
{
|
||||
const char *enumStr = GLenumToString(enumGroup, value);
|
||||
if (enumStr != kUnknownGLenumString)
|
||||
|
@ -26,7 +28,7 @@ void OutputGLenumString(std::ostream &out, GLESEnum enumGroup, unsigned int valu
|
|||
return;
|
||||
}
|
||||
|
||||
if (enumGroup == GLESEnum::Boolean)
|
||||
if (enumGroup == EnumType::Boolean)
|
||||
{
|
||||
// If an unknown enum was submitted as GLboolean, just write out the value.
|
||||
if (enumStr == kUnknownGLenumString)
|
||||
|
@ -41,10 +43,10 @@ void OutputGLenumString(std::ostream &out, GLESEnum enumGroup, unsigned int valu
|
|||
return;
|
||||
}
|
||||
|
||||
if (enumGroup != GLESEnum::AllEnums)
|
||||
if (enumGroup != EnumType::AllEnums)
|
||||
{
|
||||
// Retry with the "Default" group
|
||||
enumStr = GLenumToString(GLESEnum::AllEnums, value);
|
||||
enumStr = GLenumToString(EnumType::AllEnums, value);
|
||||
if (enumStr != kUnknownGLenumString)
|
||||
{
|
||||
out << enumStr;
|
||||
|
@ -55,17 +57,8 @@ void OutputGLenumString(std::ostream &out, GLESEnum enumGroup, unsigned int valu
|
|||
out << std::hex << "0x" << std::setfill('0') << std::setw(4) << value << std::dec;
|
||||
}
|
||||
|
||||
void OutputGLbitfieldString(std::ostream &out, GLESEnum enumGroup, unsigned int value)
|
||||
{
|
||||
out << GLbitfieldToString(enumGroup, value);
|
||||
}
|
||||
|
||||
const char *GLbooleanToString(unsigned int value)
|
||||
{
|
||||
return GLenumToString(GLESEnum::Boolean, value);
|
||||
}
|
||||
|
||||
std::string GLbitfieldToString(GLESEnum enumGroup, unsigned int value)
|
||||
template <typename EnumType>
|
||||
std::string GLbitfieldToStringImpl(EnumType enumGroup, unsigned int value)
|
||||
{
|
||||
std::stringstream st;
|
||||
|
||||
|
@ -90,6 +83,39 @@ std::string GLbitfieldToString(GLESEnum enumGroup, unsigned int value)
|
|||
|
||||
return st.str();
|
||||
}
|
||||
} // namespace
|
||||
|
||||
const char kUnknownGLenumString[] = "EnumUnknown";
|
||||
|
||||
void OutputGLenumString(std::ostream &out, GLESEnum enumGroup, unsigned int value)
|
||||
{
|
||||
return OutputGLenumStringImpl(out, enumGroup, value);
|
||||
}
|
||||
|
||||
void OutputGLenumString(std::ostream &out, BigGLEnum enumGroup, unsigned int value)
|
||||
{
|
||||
return OutputGLenumStringImpl(out, enumGroup, value);
|
||||
}
|
||||
|
||||
void OutputGLbitfieldString(std::ostream &out, GLESEnum enumGroup, unsigned int value)
|
||||
{
|
||||
out << GLbitfieldToString(enumGroup, value);
|
||||
}
|
||||
|
||||
const char *GLbooleanToString(unsigned int value)
|
||||
{
|
||||
return GLenumToString(GLESEnum::Boolean, value);
|
||||
}
|
||||
|
||||
std::string GLbitfieldToString(GLESEnum enumGroup, unsigned int value)
|
||||
{
|
||||
return GLbitfieldToStringImpl(enumGroup, value);
|
||||
}
|
||||
|
||||
std::string GLbitfieldToString(BigGLEnum enumGroup, unsigned int value)
|
||||
{
|
||||
return GLbitfieldToStringImpl(enumGroup, value);
|
||||
}
|
||||
|
||||
const char *GLinternalFormatToString(unsigned int format)
|
||||
{
|
||||
|
|
|
@ -20,7 +20,9 @@ const char *GLbooleanToString(unsigned int value);
|
|||
const char *GLenumToString(GLESEnum enumGroup, unsigned int value);
|
||||
const char *GLenumToString(BigGLEnum enumGroup, unsigned int value);
|
||||
std::string GLbitfieldToString(GLESEnum enumGroup, unsigned int value);
|
||||
std::string GLbitfieldToString(BigGLEnum enumGroup, unsigned int value);
|
||||
void OutputGLenumString(std::ostream &out, GLESEnum enumGroup, unsigned int value);
|
||||
void OutputGLenumString(std::ostream &out, BigGLEnum enumGroup, unsigned int value);
|
||||
void OutputGLbitfieldString(std::ostream &out, GLESEnum enumGroup, unsigned int value);
|
||||
const char *GLinternalFormatToString(unsigned int format);
|
||||
|
||||
|
|
|
@ -9,6 +9,7 @@
|
|||
#ifndef LIBANGLE_RENDERER_DISPLAYIMPL_H_
|
||||
#define LIBANGLE_RENDERER_DISPLAYIMPL_H_
|
||||
|
||||
#include "common/Optional.h"
|
||||
#include "common/angleutils.h"
|
||||
#include "libANGLE/Caps.h"
|
||||
#include "libANGLE/Config.h"
|
||||
|
@ -104,11 +105,8 @@ class DisplayImpl : public EGLImplFactory, public angle::Subject
|
|||
virtual egl::Error waitNative(const gl::Context *context, EGLint engine) = 0;
|
||||
virtual gl::Version getMaxSupportedESVersion() const = 0;
|
||||
virtual gl::Version getMaxConformantESVersion() const = 0;
|
||||
gl::Version getMaxSupportedDesktopVersion() const
|
||||
{
|
||||
// TODO(eddiehatfield): We should make this virtual and implement for all backends.
|
||||
return {4, 6};
|
||||
}
|
||||
// If desktop GL is not supported in any capacity for a given backend, this returns None.
|
||||
virtual Optional<gl::Version> getMaxSupportedDesktopVersion() const = 0;
|
||||
const egl::Caps &getCaps() const;
|
||||
|
||||
virtual void setBlobCacheFuncs(EGLSetBlobFuncANDROID set, EGLGetBlobFuncANDROID get) {}
|
||||
|
|
|
@ -429,6 +429,11 @@ gl::Version DisplayD3D::getMaxConformantESVersion() const
|
|||
return mRenderer->getMaxConformantESVersion();
|
||||
}
|
||||
|
||||
Optional<gl::Version> DisplayD3D::getMaxSupportedDesktopVersion() const
|
||||
{
|
||||
return Optional<gl::Version>::Invalid();
|
||||
}
|
||||
|
||||
void DisplayD3D::handleResult(HRESULT hr,
|
||||
const char *message,
|
||||
const char *file,
|
||||
|
|
|
@ -92,6 +92,7 @@ class DisplayD3D : public DisplayImpl, public d3d::Context
|
|||
egl::Error waitNative(const gl::Context *context, EGLint engine) override;
|
||||
gl::Version getMaxSupportedESVersion() const override;
|
||||
gl::Version getMaxConformantESVersion() const override;
|
||||
Optional<gl::Version> getMaxSupportedDesktopVersion() const override;
|
||||
|
||||
void handleResult(HRESULT hr,
|
||||
const char *message,
|
||||
|
|
|
@ -157,6 +157,11 @@ gl::Version DisplayGL::getMaxConformantESVersion() const
|
|||
return std::min(getMaxSupportedESVersion(), gl::Version(3, 0));
|
||||
}
|
||||
|
||||
Optional<gl::Version> DisplayGL::getMaxSupportedDesktopVersion() const
|
||||
{
|
||||
return Optional<gl::Version>::Invalid();
|
||||
}
|
||||
|
||||
void DisplayGL::generateExtensions(egl::DisplayExtensions *outExtensions) const
|
||||
{
|
||||
// Advertise robust resource initialization on all OpenGL backends for testing even though it is
|
||||
|
|
|
@ -55,6 +55,7 @@ class DisplayGL : public DisplayImpl
|
|||
gl::Context *context) override;
|
||||
|
||||
gl::Version getMaxConformantESVersion() const override;
|
||||
Optional<gl::Version> getMaxSupportedDesktopVersion() const override;
|
||||
|
||||
virtual RendererGL *getRenderer() const = 0;
|
||||
|
||||
|
|
|
@ -91,6 +91,7 @@ class DisplayMtl : public DisplayImpl
|
|||
const egl::AttributeMap &attribs) override;
|
||||
gl::Version getMaxSupportedESVersion() const override;
|
||||
gl::Version getMaxConformantESVersion() const override;
|
||||
Optional<gl::Version> getMaxSupportedDesktopVersion() const override;
|
||||
|
||||
EGLSyncImpl *createSync(const egl::AttributeMap &attribs) override;
|
||||
|
||||
|
|
|
@ -427,6 +427,11 @@ gl::Version DisplayMtl::getMaxConformantESVersion() const
|
|||
return std::min(getMaxSupportedESVersion(), gl::Version(3, 0));
|
||||
}
|
||||
|
||||
Optional<gl::Version> DisplayMtl::getMaxSupportedDesktopVersion() const
|
||||
{
|
||||
return Optional<gl::Version>::Invalid();
|
||||
}
|
||||
|
||||
EGLSyncImpl *DisplayMtl::createSync(const egl::AttributeMap &attribs)
|
||||
{
|
||||
return new EGLSyncMtl(attribs);
|
||||
|
|
|
@ -142,6 +142,11 @@ gl::Version DisplayNULL::getMaxSupportedESVersion() const
|
|||
return gl::Version(3, 2);
|
||||
}
|
||||
|
||||
Optional<gl::Version> DisplayNULL::getMaxSupportedDesktopVersion() const
|
||||
{
|
||||
return Optional<gl::Version>::Invalid();
|
||||
}
|
||||
|
||||
gl::Version DisplayNULL::getMaxConformantESVersion() const
|
||||
{
|
||||
return getMaxSupportedESVersion();
|
||||
|
|
|
@ -50,6 +50,7 @@ class DisplayNULL : public DisplayImpl
|
|||
egl::Error waitNative(const gl::Context *context, EGLint engine) override;
|
||||
gl::Version getMaxSupportedESVersion() const override;
|
||||
gl::Version getMaxConformantESVersion() const override;
|
||||
Optional<gl::Version> getMaxSupportedDesktopVersion() const override;
|
||||
|
||||
SurfaceImpl *createWindowSurface(const egl::SurfaceState &state,
|
||||
EGLNativeWindowType window,
|
||||
|
|
|
@ -211,6 +211,11 @@ gl::Version DisplayVk::getMaxConformantESVersion() const
|
|||
return mRenderer->getMaxConformantESVersion();
|
||||
}
|
||||
|
||||
Optional<gl::Version> DisplayVk::getMaxSupportedDesktopVersion() const
|
||||
{
|
||||
return gl::Version{4, 6};
|
||||
}
|
||||
|
||||
egl::Error DisplayVk::validateImageClientBuffer(const gl::Context *context,
|
||||
EGLenum target,
|
||||
EGLClientBuffer clientBuffer,
|
||||
|
|
|
@ -177,6 +177,7 @@ class DisplayVk : public DisplayImpl, public vk::Context
|
|||
|
||||
gl::Version getMaxSupportedESVersion() const override;
|
||||
gl::Version getMaxConformantESVersion() const override;
|
||||
Optional<gl::Version> getMaxSupportedDesktopVersion() const override;
|
||||
|
||||
egl::Error validateImageClientBuffer(const gl::Context *context,
|
||||
EGLenum target,
|
||||
|
|
|
@ -1215,13 +1215,13 @@ egl::Config GenerateDefaultConfig(DisplayVk *display,
|
|||
const VkPhysicalDeviceProperties &physicalDeviceProperties =
|
||||
renderer->getPhysicalDeviceProperties();
|
||||
gl::Version maxSupportedESVersion = renderer->getMaxSupportedESVersion();
|
||||
gl::Version maxSupportedDesktopVersion = display->getMaxSupportedDesktopVersion();
|
||||
Optional<gl::Version> maxSupportedDesktopVersion = display->getMaxSupportedDesktopVersion();
|
||||
|
||||
// ES3 features are required to emulate ES1
|
||||
EGLint es1Support = (maxSupportedESVersion.major >= 3 ? EGL_OPENGL_ES_BIT : 0);
|
||||
EGLint es2Support = (maxSupportedESVersion.major >= 2 ? EGL_OPENGL_ES2_BIT : 0);
|
||||
EGLint es3Support = (maxSupportedESVersion.major >= 3 ? EGL_OPENGL_ES3_BIT : 0);
|
||||
EGLint desktopSupport = (maxSupportedDesktopVersion.major != 0 ? EGL_OPENGL_BIT : 0);
|
||||
EGLint desktopSupport = (maxSupportedDesktopVersion.valid() ? EGL_OPENGL_BIT : 0);
|
||||
|
||||
egl::Config config;
|
||||
|
||||
|
|
|
@ -2451,7 +2451,15 @@ bool ValidateCreateContext(const ValidationContext *val,
|
|||
break;
|
||||
|
||||
case EGL_OPENGL_API:
|
||||
// TODO: validate desktop OpenGL versions and profile mask
|
||||
// The requested configuration must use EGL_OPENGL_BIT if EGL_OPENGL_BIT is the
|
||||
// currently bound API.
|
||||
if ((configuration != EGL_NO_CONFIG_KHR) &&
|
||||
!(configuration->renderableType & EGL_OPENGL_BIT))
|
||||
{
|
||||
val->setError(EGL_BAD_CONFIG);
|
||||
return false;
|
||||
}
|
||||
// TODO(http://anglebug.com/7533): validate desktop OpenGL versions and profile mask
|
||||
break;
|
||||
|
||||
default:
|
||||
|
|
|
@ -544,7 +544,7 @@ const char *QueryString(Thread *thread, Display *display, EGLint name)
|
|||
switch (name)
|
||||
{
|
||||
case EGL_CLIENT_APIS:
|
||||
result = "OpenGL_ES";
|
||||
result = display->getClientAPIString().c_str();
|
||||
break;
|
||||
case EGL_EXTENSIONS:
|
||||
if (display == EGL_NO_DISPLAY)
|
||||
|
|
|
@ -2250,29 +2250,3 @@ EXPORTS
|
|||
glMultiDrawElementsIndirectCount
|
||||
glPolygonOffsetClamp
|
||||
glSpecializeShader
|
||||
|
||||
; WGL 1.0
|
||||
wglChoosePixelFormat
|
||||
wglCopyContext
|
||||
wglCreateContext
|
||||
wglCreateLayerContext
|
||||
wglDeleteContext
|
||||
wglDescribeLayerPlane
|
||||
wglDescribePixelFormat
|
||||
wglGetCurrentContext
|
||||
wglGetCurrentDC
|
||||
wglGetEnhMetaFilePixelFormat
|
||||
wglGetLayerPaletteEntries
|
||||
wglGetPixelFormat
|
||||
wglGetProcAddress
|
||||
wglMakeCurrent
|
||||
wglRealizeLayerPalette
|
||||
wglSetLayerPaletteEntries
|
||||
wglSetPixelFormat
|
||||
wglShareLists
|
||||
wglSwapBuffers
|
||||
wglSwapLayerBuffers
|
||||
wglUseFontBitmapsA
|
||||
wglUseFontBitmapsW
|
||||
wglUseFontOutlinesA
|
||||
wglUseFontOutlinesW
|
||||
|
|
Разница между файлами не показана из-за своего большого размера
Загрузить разницу
|
@ -1445,7 +1445,9 @@ if (build_angle_deqp_tests && !is_fuchsia) {
|
|||
_android_mustpass = "$deqp_path/android/cts/main"
|
||||
_aosp_mustpass =
|
||||
"$deqp_path/external/openglcts/data/mustpass/gles/aosp_mustpass/main"
|
||||
_khronos_mustpass =
|
||||
_khronos_gl_mustpass =
|
||||
"$deqp_path/external/openglcts/data/mustpass/gl/khronos_mustpass/main"
|
||||
_khronos_gles_mustpass =
|
||||
"$deqp_path/external/openglcts/data/mustpass/gles/khronos_mustpass/main"
|
||||
|
||||
angle_deqp_source_set("angle_deqp_gles2_common") {
|
||||
|
@ -1563,18 +1565,23 @@ if (build_angle_deqp_tests && !is_fuchsia) {
|
|||
if (api == "gles2") {
|
||||
# Make sure we include something so that angle_deqp_libtester_main.cpp can find something.
|
||||
data = [ "$root_gen_dir/vk_gl_cts_data/data/gles2/shaders/misc.test" ]
|
||||
mustpass_dir = _khronos_gles_mustpass
|
||||
} else if (api == "gles3") {
|
||||
data = angle_deqp_external_openglcts_data_gles3
|
||||
mustpass_dir = _khronos_gles_mustpass
|
||||
} else if (api == "gles31") {
|
||||
data = angle_deqp_external_openglcts_data_gles31
|
||||
mustpass_dir = _khronos_gles_mustpass
|
||||
} else if (api == "gles32") {
|
||||
data = angle_deqp_external_openglcts_data_gles32
|
||||
mustpass_dir = _khronos_gles_mustpass
|
||||
} else if (api == "gl46") {
|
||||
data = angle_deqp_external_openglcts_data_gl46
|
||||
# Use this as a placeholder, the gl46 test suite does not need data
|
||||
data = [ "$root_gen_dir/vk_gl_cts_data/data/gles2/shaders/misc.test" ]
|
||||
mustpass_dir = _khronos_gl_mustpass
|
||||
} else {
|
||||
assert(false)
|
||||
}
|
||||
mustpass_dir = _khronos_mustpass
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1605,7 +1612,7 @@ if (build_angle_deqp_tests && !is_fuchsia) {
|
|||
# The core Desktop GL CTS is in the same category as these KHR tests.
|
||||
angle_deqp_khr_gtest("gl46") {
|
||||
defines = [ "ANGLE_DEQP_GL_TESTS" ]
|
||||
mustpass_name = "gl46-khr-master.txt"
|
||||
mustpass_name = "gl46-master.txt"
|
||||
api = "gl46"
|
||||
}
|
||||
|
||||
|
|
|
@ -497,8 +497,6 @@ angle_deqp_external_openglcts_data_gles32 = [
|
|||
"$root_gen_dir/vk_gl_cts_data/data/gl_cts/data/gles32/compressed_texture/etc_sRGBA8_240x240_ref.bin",
|
||||
]
|
||||
|
||||
angle_deqp_external_openglcts_data_gl46 = []
|
||||
|
||||
angle_deqp_data_copy_targets = [
|
||||
"deqp_support:vk_gl_cts_data_data_gles2_data",
|
||||
"deqp_support:vk_gl_cts_data_data_gles2_data_etc1",
|
||||
|
|
|
@ -148,6 +148,11 @@
|
|||
5170 VULKAN LINUX : dEQP-EGL.functional.swap_buffers_with_damage.resize_after_swap.* = SKIP
|
||||
5170 VULKAN LINUX : dEQP-EGL.functional.swap_buffers_with_damage.resize_before_swap.* = SKIP
|
||||
|
||||
// Tests that fail when the GL desktop frontend is enabled
|
||||
// TODO(http://anglebug.com/7566): Get these tests to pass.
|
||||
7533 : dEQP-EGL.functional.create_context_ext.gl_30.* = SKIP
|
||||
7533 : dEQP-EGL.functional.create_context_ext.robust_gl_30.* = SKIP
|
||||
|
||||
//// Metal
|
||||
|
||||
6485 MAC METAL : dEQP-EGL.functional.multithread.pbuffer_single_window = SKIP
|
||||
|
|
|
@ -0,0 +1,78 @@
|
|||
// Copyright 2022 The ANGLE Project Authors. All rights reserved.
|
||||
// Use of this source code is governed by a BSD-style license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
// See README.md for format.
|
||||
|
||||
7566 SWIFTSHADER : KHR-GL46.aggressive_optimizations.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.blend_equation_advanced.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.buffer_storage.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.clip_control.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.clip_distance.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.CommonBugs.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.compute_shader.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.conditional_render_inverted.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.constant_expressions.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.copy_image.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.cull_distance.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.direct_state_access.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.draw_indirect_43.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.draw_indirect.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.explicit_uniform_location.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.exposed_extensions.validate_extensions = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.geometry_shader.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.get_texture_sub_image.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.glsl_noperspective.functionaltest = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.gl_spirv.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.gpu_shader5.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.gpu_shader_fp64.fp64.state_query = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.incomplete_texture_access.sampler = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.indirect_parameters_tests.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.internalformat.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.layout_binding.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.layout_location.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.limits.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.map_buffer_alignment.query = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.multi_bind.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.nearest_edge.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.packed_depth_stencil.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.packed_pixels.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.pipeline_statistics_query_tests_ARB.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.pixelstoragemodes.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.polygon_offset_clamp.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.program_interface_query.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.sample_variables.mask.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.separable_programs_tf.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.sepshaderobjs.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shader_atomic_counter_ops_tests.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shader_atomic_counters.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shader_draw_parameters_tests.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shader_group_vote.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shader_image_load_store.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shader_image_size.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shader_multisample_interpolation.render.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shaders30.declarations.declarations.redeclare_gl_Frag* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shaders30.glsl_constructors.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shaders42.declarations.declarations.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shaders44.preprocessor.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shaders.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shader_storage_buffer_object.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.shading_language_420pack.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.spirv_extensions.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.stencil_texturing.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.sync.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.tessellation_shader.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.texture_barrier.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.texture_border_clamp.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.texture_buffer.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.texture_cube_map_array.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.texture_filter_anisotropic.drawing = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.texture_gather.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.texture_size_promotion.functional = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.texture_swizzle.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.transform_feedback_overflow_query_ARB.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.transform_feedback.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.vertex_attrib_binding.* = SKIP
|
||||
7566 SWIFTSHADER : KHR-GL46.viewport_array.* = SKIP
|
||||
|
||||
7566 SWIFTSHADER UBSAN : KHR-GL46.shader_bitfield_operation.bitfieldInsert.int_3 = SKIP
|
Загрузка…
Ссылка в новой задаче