summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--content/browser/gpu/gpu_driver_bug_list.cc35
-rw-r--r--gpu/command_buffer/service/feature_info.cc108
-rw-r--r--gpu/command_buffer/service/feature_info.h20
-rw-r--r--gpu/command_buffer/service/feature_info_unittest.cc20
-rw-r--r--gpu/command_buffer/service/gpu_driver_bug_workaround_type.h69
5 files changed, 76 insertions, 176 deletions
diff --git a/content/browser/gpu/gpu_driver_bug_list.cc b/content/browser/gpu/gpu_driver_bug_list.cc
index d8ed706..9ab93f2 100644
--- a/content/browser/gpu/gpu_driver_bug_list.cc
+++ b/content/browser/gpu/gpu_driver_bug_list.cc
@@ -31,38 +31,9 @@ GpuDriverBugList* GpuDriverBugList::Create() {
GpuDriverBugList* list = new GpuDriverBugList();
const DriverBugInfo kFeatureList[] = {
- { gpu::CLEAR_ALPHA_IN_READPIXELS, "clear_alpha_in_readpixels" },
- { gpu::CLEAR_UNIFORMS_BEFORE_PROGRAM_USE,
- "clear_uniforms_before_program_use" },
- { gpu::DELETE_INSTEAD_OF_RESIZE_FBO, "delete_instead_of_resize_fbo" },
- { gpu::DISABLE_ANGLE_FRAMEBUFFER_MULTISAMPLE,
- "disable_angle_framebuffer_multisample" },
- { gpu::DISABLE_DEPTH_TEXTURE, "disable_depth_texture" },
- { gpu::DISABLE_EXT_OCCLUSION_QUERY, "disable_ext_occlusion_query" },
- { gpu::ENABLE_CHROMIUM_FAST_NPOT_MO8_TEXTURES,
- "enable_chromium_fast_npot_mo8_textures" },
- { gpu::EXIT_ON_CONTEXT_LOST, "exit_on_context_lost" },
- { gpu::FLUSH_ON_CONTEXT_SWITCH, "flush_on_context_switch" },
- { gpu::MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_1024,
- "max_cube_map_texture_size_limit_1024" },
- { gpu::MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_4096,
- "max_cube_map_texture_size_limit_4096" },
- { gpu::MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_512,
- "max_cube_map_texture_size_limit_512" },
- { gpu::MAX_TEXTURE_SIZE_LIMIT_4096, "max_texture_size_limit_4096" },
- { gpu::NEEDS_GLSL_BUILT_IN_FUNCTION_EMULATION,
- "needs_glsl_built_in_function_emulation" },
- { gpu::NEEDS_OFFSCREEN_BUFFER_WORKAROUND,
- "needs_offscreen_buffer_workaround" },
- { gpu::RESTORE_SCISSOR_ON_FBO_CHANGE, "restore_scissor_on_fbo_change" },
- { gpu::REVERSE_POINT_SPRITE_COORD_ORIGIN,
- "reverse_point_sprite_coord_origin" },
- { gpu::SET_TEXTURE_FILTER_BEFORE_GENERATING_MIPMAP,
- "set_texture_filter_before_generating_mipmap" },
- { gpu::USE_CLIENT_SIDE_ARRAYS_FOR_STREAM_BUFFERS,
- "use_client_side_arrays_for_stream_buffers" },
- { gpu::USE_CURRENT_PROGRAM_AFTER_SUCCESSFUL_LINK,
- "use_current_program_after_successful_link" }
+#define GPU_OP(type, name) { gpu::type, #name },
+ GPU_DRIVER_BUG_WORKAROUNDS(GPU_OP)
+#undef GPU_OP
};
DCHECK_EQ(static_cast<int>(arraysize(kFeatureList)),
gpu::NUMBER_OF_GPU_DRIVER_BUG_WORKAROUND_TYPES);
diff --git a/gpu/command_buffer/service/feature_info.cc b/gpu/command_buffer/service/feature_info.cc
index 19b8bc6..8516a20 100644
--- a/gpu/command_buffer/service/feature_info.cc
+++ b/gpu/command_buffer/service/feature_info.cc
@@ -11,7 +11,6 @@
#include "base/strings/string_number_conversions.h"
#include "base/strings/string_split.h"
#include "gpu/command_buffer/service/gl_utils.h"
-#include "gpu/command_buffer/service/gpu_driver_bug_workaround_type.h"
#include "gpu/command_buffer/service/gpu_switches.h"
#include "ui/gl/gl_implementation.h"
#if defined(OS_MACOSX)
@@ -76,78 +75,24 @@ void StringToWorkarounds(
bool succeed = base::StringToInt(pieces[i], &number);
DCHECK(succeed);
switch (number) {
- case gpu::CLEAR_ALPHA_IN_READPIXELS:
- workarounds->clear_alpha_in_readpixels = true;
- break;
- case gpu::CLEAR_UNIFORMS_BEFORE_PROGRAM_USE:
- workarounds->clear_uniforms_before_program_use = true;
- break;
- case gpu::DELETE_INSTEAD_OF_RESIZE_FBO:
- workarounds->delete_instead_of_resize_fbo = true;
- break;
- case gpu::DISABLE_ANGLE_FRAMEBUFFER_MULTISAMPLE:
- workarounds->disable_angle_framebuffer_multisample = true;
- break;
- case gpu::DISABLE_DEPTH_TEXTURE:
- workarounds->disable_depth_texture = true;
- break;
- case gpu::DISABLE_EXT_OCCLUSION_QUERY:
- workarounds->disable_ext_occlusion_query = true;
- break;
- case gpu::ENABLE_CHROMIUM_FAST_NPOT_MO8_TEXTURES:
- workarounds->enable_chromium_fast_npot_mo8_textures = true;
- break;
- case gpu::EXIT_ON_CONTEXT_LOST:
- workarounds->exit_on_context_lost = true;
- break;
- case gpu::FLUSH_ON_CONTEXT_SWITCH:
- workarounds->flush_on_context_switch = true;
- break;
- case gpu::MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_1024:
- if (workarounds->max_cube_map_texture_size == 0 ||
- workarounds->max_cube_map_texture_size > 1024)
- workarounds->max_cube_map_texture_size = 1024;
- break;
- case gpu::MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_4096:
- if (workarounds->max_cube_map_texture_size == 0 ||
- workarounds->max_cube_map_texture_size > 4096)
- workarounds->max_cube_map_texture_size = 4096;
- break;
- case gpu::MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_512:
- if (workarounds->max_cube_map_texture_size == 0 ||
- workarounds->max_cube_map_texture_size > 512)
- workarounds->max_cube_map_texture_size = 512;
- break;
- case gpu::MAX_TEXTURE_SIZE_LIMIT_4096:
- if (workarounds->max_texture_size == 0 ||
- workarounds->max_texture_size > 4096)
- workarounds->max_texture_size = 4096;
- break;
- case gpu::NEEDS_GLSL_BUILT_IN_FUNCTION_EMULATION:
- workarounds->needs_glsl_built_in_function_emulation = true;
- break;
- case gpu::NEEDS_OFFSCREEN_BUFFER_WORKAROUND:
- workarounds->needs_offscreen_buffer_workaround = true;
- break;
- case gpu::RESTORE_SCISSOR_ON_FBO_CHANGE:
- workarounds->restore_scissor_on_fbo_change = true;
- break;
- case REVERSE_POINT_SPRITE_COORD_ORIGIN:
- workarounds->reverse_point_sprite_coord_origin = true;
- break;
- case gpu::SET_TEXTURE_FILTER_BEFORE_GENERATING_MIPMAP:
- workarounds->set_texture_filter_before_generating_mipmap = true;
- break;
- case gpu::USE_CLIENT_SIDE_ARRAYS_FOR_STREAM_BUFFERS:
- workarounds->use_client_side_arrays_for_stream_buffers = true;
- break;
- case gpu::USE_CURRENT_PROGRAM_AFTER_SUCCESSFUL_LINK:
- workarounds->use_current_program_after_successful_link = true;
- break;
+#define GPU_OP(type, name) \
+ case gpu::type: \
+ workarounds->name = true; \
+ break;
+ GPU_DRIVER_BUG_WORKAROUNDS(GPU_OP)
+#undef GPU_OP
default:
NOTIMPLEMENTED();
}
}
+ if (workarounds->max_texture_size_limit_4096)
+ workarounds->max_texture_size = 4096;
+ if (workarounds->max_cube_map_texture_size_limit_4096)
+ workarounds->max_cube_map_texture_size = 4096;
+ if (workarounds->max_cube_map_texture_size_limit_1024)
+ workarounds->max_cube_map_texture_size = 1024;
+ if (workarounds->max_cube_map_texture_size_limit_512)
+ workarounds->max_cube_map_texture_size = 512;
}
} // anonymous namespace.
@@ -173,25 +118,12 @@ FeatureInfo::FeatureFlags::FeatureFlags()
ext_draw_buffers(false) {
}
-FeatureInfo::Workarounds::Workarounds()
- : clear_alpha_in_readpixels(false),
- clear_uniforms_before_program_use(false),
- delete_instead_of_resize_fbo(false),
- disable_angle_framebuffer_multisample(false),
- disable_depth_texture(false),
- disable_ext_occlusion_query(false),
- enable_chromium_fast_npot_mo8_textures(false),
- exit_on_context_lost(false),
- flush_on_context_switch(false),
- needs_glsl_built_in_function_emulation(false),
- needs_offscreen_buffer_workaround(false),
- restore_scissor_on_fbo_change(false),
- reverse_point_sprite_coord_origin(false),
- set_texture_filter_before_generating_mipmap(false),
- use_client_side_arrays_for_stream_buffers(false),
- use_current_program_after_successful_link(false),
- max_texture_size(0),
- max_cube_map_texture_size(0) {
+FeatureInfo::Workarounds::Workarounds() :
+#define GPU_OP(type, name) name(false),
+ GPU_DRIVER_BUG_WORKAROUNDS(GPU_OP)
+#undef GPU_OP
+ max_texture_size(0),
+ max_cube_map_texture_size(0) {
}
FeatureInfo::FeatureInfo() {
diff --git a/gpu/command_buffer/service/feature_info.h b/gpu/command_buffer/service/feature_info.h
index f72be0d..3605976 100644
--- a/gpu/command_buffer/service/feature_info.h
+++ b/gpu/command_buffer/service/feature_info.h
@@ -12,6 +12,7 @@
#include "base/sys_info.h"
#include "gpu/command_buffer/service/gles2_cmd_decoder.h"
#include "gpu/command_buffer/service/gles2_cmd_validation.h"
+#include "gpu/command_buffer/service/gpu_driver_bug_workaround_type.h"
#include "gpu/gpu_export.h"
class CommandLine;
@@ -48,22 +49,9 @@ class GPU_EXPORT FeatureInfo : public base::RefCounted<FeatureInfo> {
struct Workarounds {
Workarounds();
- bool clear_alpha_in_readpixels;
- bool clear_uniforms_before_program_use;
- bool delete_instead_of_resize_fbo;
- bool disable_angle_framebuffer_multisample;
- bool disable_depth_texture;
- bool disable_ext_occlusion_query;
- bool enable_chromium_fast_npot_mo8_textures;
- bool exit_on_context_lost;
- bool flush_on_context_switch;
- bool needs_glsl_built_in_function_emulation;
- bool needs_offscreen_buffer_workaround;
- bool restore_scissor_on_fbo_change;
- bool reverse_point_sprite_coord_origin;
- bool set_texture_filter_before_generating_mipmap;
- bool use_client_side_arrays_for_stream_buffers;
- bool use_current_program_after_successful_link;
+#define GPU_OP(type, name) bool name;
+ GPU_DRIVER_BUG_WORKAROUNDS(GPU_OP)
+#undef GPU_OP
// Note: 0 here means use driver limit.
GLint max_texture_size;
diff --git a/gpu/command_buffer/service/feature_info_unittest.cc b/gpu/command_buffer/service/feature_info_unittest.cc
index b525a23..0fcc3a7 100644
--- a/gpu/command_buffer/service/feature_info_unittest.cc
+++ b/gpu/command_buffer/service/feature_info_unittest.cc
@@ -94,23 +94,9 @@ TEST_F(FeatureInfoTest, Basic) {
).use_arb_occlusion_query_for_occlusion_query_boolean);
EXPECT_FALSE(info_->feature_flags().native_vertex_array_object);
- EXPECT_FALSE(info_->workarounds().clear_alpha_in_readpixels);
- EXPECT_FALSE(info_->workarounds().clear_uniforms_before_program_use);
- EXPECT_FALSE(info_->workarounds().delete_instead_of_resize_fbo);
- EXPECT_FALSE(info_->workarounds().disable_angle_framebuffer_multisample);
- EXPECT_FALSE(info_->workarounds().disable_depth_texture);
- EXPECT_FALSE(info_->workarounds().disable_ext_occlusion_query);
- EXPECT_FALSE(info_->workarounds().enable_chromium_fast_npot_mo8_textures);
- EXPECT_FALSE(info_->workarounds().exit_on_context_lost);
- EXPECT_FALSE(info_->workarounds().flush_on_context_switch);
- EXPECT_FALSE(info_->workarounds().needs_glsl_built_in_function_emulation);
- EXPECT_FALSE(info_->workarounds().needs_offscreen_buffer_workaround);
- EXPECT_FALSE(info_->workarounds().restore_scissor_on_fbo_change);
- EXPECT_FALSE(info_->workarounds().reverse_point_sprite_coord_origin);
- EXPECT_FALSE(
- info_->workarounds().set_texture_filter_before_generating_mipmap);
- EXPECT_FALSE(info_->workarounds().use_client_side_arrays_for_stream_buffers);
- EXPECT_FALSE(info_->workarounds().use_current_program_after_successful_link);
+#define GPU_OP(type, name) EXPECT_FALSE(info_->workarounds().name);
+ GPU_DRIVER_BUG_WORKAROUNDS(GPU_OP)
+#undef GPU_OP
EXPECT_EQ(0, info_->workarounds().max_texture_size);
EXPECT_EQ(0, info_->workarounds().max_cube_map_texture_size);
diff --git a/gpu/command_buffer/service/gpu_driver_bug_workaround_type.h b/gpu/command_buffer/service/gpu_driver_bug_workaround_type.h
index c0ad655..8c21d2e 100644
--- a/gpu/command_buffer/service/gpu_driver_bug_workaround_type.h
+++ b/gpu/command_buffer/service/gpu_driver_bug_workaround_type.h
@@ -7,32 +7,55 @@
#include "gpu/gpu_export.h"
+#define GPU_DRIVER_BUG_WORKAROUNDS(GPU_OP) \
+ GPU_OP(CLEAR_ALPHA_IN_READPIXELS, \
+ clear_alpha_in_readpixels) \
+ GPU_OP(CLEAR_UNIFORMS_BEFORE_PROGRAM_USE, \
+ clear_uniforms_before_program_use) \
+ GPU_OP(DELETE_INSTEAD_OF_RESIZE_FBO, \
+ delete_instead_of_resize_fbo) \
+ GPU_OP(DISABLE_ANGLE_FRAMEBUFFER_MULTISAMPLE, \
+ disable_angle_framebuffer_multisample) \
+ GPU_OP(DISABLE_DEPTH_TEXTURE, \
+ disable_depth_texture) \
+ GPU_OP(DISABLE_EXT_OCCLUSION_QUERY, \
+ disable_ext_occlusion_query) \
+ GPU_OP(ENABLE_CHROMIUM_FAST_NPOT_MO8_TEXTURES, \
+ enable_chromium_fast_npot_mo8_textures) \
+ GPU_OP(EXIT_ON_CONTEXT_LOST, \
+ exit_on_context_lost) \
+ GPU_OP(FLUSH_ON_CONTEXT_SWITCH, \
+ flush_on_context_switch) \
+ GPU_OP(MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_1024, \
+ max_cube_map_texture_size_limit_1024) \
+ GPU_OP(MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_4096, \
+ max_cube_map_texture_size_limit_4096) \
+ GPU_OP(MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_512, \
+ max_cube_map_texture_size_limit_512) \
+ GPU_OP(MAX_TEXTURE_SIZE_LIMIT_4096, \
+ max_texture_size_limit_4096) \
+ GPU_OP(NEEDS_GLSL_BUILT_IN_FUNCTION_EMULATION, \
+ needs_glsl_built_in_function_emulation) \
+ GPU_OP(NEEDS_OFFSCREEN_BUFFER_WORKAROUND, \
+ needs_offscreen_buffer_workaround) \
+ GPU_OP(RESTORE_SCISSOR_ON_FBO_CHANGE, \
+ restore_scissor_on_fbo_change) \
+ GPU_OP(REVERSE_POINT_SPRITE_COORD_ORIGIN, \
+ reverse_point_sprite_coord_origin) \
+ GPU_OP(SET_TEXTURE_FILTER_BEFORE_GENERATING_MIPMAP, \
+ set_texture_filter_before_generating_mipmap) \
+ GPU_OP(USE_CLIENT_SIDE_ARRAYS_FOR_STREAM_BUFFERS, \
+ use_client_side_arrays_for_stream_buffers) \
+ GPU_OP(USE_CURRENT_PROGRAM_AFTER_SUCCESSFUL_LINK, \
+ use_current_program_after_successful_link)
+
namespace gpu {
-// Provides flags indicating which gpu features are blacklisted for the system
-// on which chrome is currently running.
-// If a bit is set to 1, corresponding feature is blacklisted.
+// Provides all types of GPU driver bug workarounds.
enum GPU_EXPORT GpuDriverBugWorkaroundType {
- CLEAR_ALPHA_IN_READPIXELS = 0,
- CLEAR_UNIFORMS_BEFORE_PROGRAM_USE,
- DELETE_INSTEAD_OF_RESIZE_FBO,
- DISABLE_ANGLE_FRAMEBUFFER_MULTISAMPLE,
- DISABLE_DEPTH_TEXTURE,
- DISABLE_EXT_OCCLUSION_QUERY,
- ENABLE_CHROMIUM_FAST_NPOT_MO8_TEXTURES,
- EXIT_ON_CONTEXT_LOST,
- FLUSH_ON_CONTEXT_SWITCH,
- MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_1024,
- MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_4096,
- MAX_CUBE_MAP_TEXTURE_SIZE_LIMIT_512,
- MAX_TEXTURE_SIZE_LIMIT_4096,
- NEEDS_GLSL_BUILT_IN_FUNCTION_EMULATION,
- NEEDS_OFFSCREEN_BUFFER_WORKAROUND,
- RESTORE_SCISSOR_ON_FBO_CHANGE,
- REVERSE_POINT_SPRITE_COORD_ORIGIN,
- SET_TEXTURE_FILTER_BEFORE_GENERATING_MIPMAP,
- USE_CLIENT_SIDE_ARRAYS_FOR_STREAM_BUFFERS,
- USE_CURRENT_PROGRAM_AFTER_SUCCESSFUL_LINK,
+#define GPU_OP(type, name) type,
+ GPU_DRIVER_BUG_WORKAROUNDS(GPU_OP)
+#undef GPU_OP
NUMBER_OF_GPU_DRIVER_BUG_WORKAROUND_TYPES
};