Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(347)

Unified Diff: content/gpu/gpu_child_thread.cc

Issue 1753383003: Get rid of gpu related switches by passing gpu::GpuPreferences via IPC. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase Created 4 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « content/gpu/gpu_child_thread.h ('k') | content/gpu/in_process_gpu_thread.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/gpu/gpu_child_thread.cc
diff --git a/content/gpu/gpu_child_thread.cc b/content/gpu/gpu_child_thread.cc
index 1bb3df07e35f42846c9f352ac69012eda1b1bc1c..5b20df9338266167bd7042e35271fed2886e83a8 100644
--- a/content/gpu/gpu_child_thread.cc
+++ b/content/gpu/gpu_child_thread.cc
@@ -46,15 +46,6 @@ namespace {
static base::LazyInstance<scoped_refptr<ThreadSafeSender> >
g_thread_safe_sender = LAZY_INSTANCE_INITIALIZER;
-bool GetSizeTFromSwitch(const base::CommandLine* command_line,
- const base::StringPiece& switch_string,
- size_t* value) {
- if (!command_line->HasSwitch(switch_string))
- return false;
- std::string switch_value(command_line->GetSwitchValueASCII(switch_string));
- return base::StringToSizeT(switch_value, value);
-}
-
bool GpuProcessLogMessageHandler(int severity,
const char* file, int line,
size_t message_start,
@@ -158,7 +149,6 @@ GpuChildThread::GpuChildThread(
GpuMemoryBufferFactory* gpu_memory_buffer_factory,
gpu::SyncPointManager* sync_point_manager)
: ChildThreadImpl(GetOptions(gpu_memory_buffer_factory)),
- gpu_preferences_(GetGpuPreferencesFromCommandLine()),
dead_on_arrival_(dead_on_arrival),
sync_point_manager_(sync_point_manager),
gpu_info_(gpu_info),
@@ -348,7 +338,8 @@ void GpuChildThread::StoreShaderToDisk(int32_t client_id,
Send(new GpuHostMsg_CacheShader(client_id, key, shader));
}
-void GpuChildThread::OnInitialize() {
+void GpuChildThread::OnInitialize(const gpu::GpuPreferences& gpu_preferences) {
+ gpu_preferences_ = gpu_preferences;
// Record initialization only after collecting the GPU info because that can
// take a significant amount of time.
gpu_info_.initialization_time = base::Time::Now() - process_start_time_;
@@ -399,70 +390,6 @@ void GpuChildThread::StopWatchdog() {
}
}
-// static
-gpu::GpuPreferences GpuChildThread::GetGpuPreferencesFromCommandLine() {
- // TODO(penghuang): share below code with
- // android_webview/browser/deferred_gpu_command_service.cc
- // http://crbug.com/590825
- // For any modification of below code, deferred_gpu_command_service.cc should
- // be updated as well.
- DCHECK(base::CommandLine::InitializedForCurrentProcess());
- const base::CommandLine* command_line =
- base::CommandLine::ForCurrentProcess();
- gpu::GpuPreferences gpu_preferences;
- gpu_preferences.single_process =
- command_line->HasSwitch(switches::kSingleProcess);
- gpu_preferences.in_process_gpu =
- command_line->HasSwitch(switches::kInProcessGPU);
- gpu_preferences.ui_prioritize_in_gpu_process =
- command_line->HasSwitch(switches::kUIPrioritizeInGpuProcess);
- gpu_preferences.compile_shader_always_succeeds =
- command_line->HasSwitch(switches::kCompileShaderAlwaysSucceeds);
- gpu_preferences.disable_gl_error_limit =
- command_line->HasSwitch(switches::kDisableGLErrorLimit);
- gpu_preferences.disable_glsl_translator =
- command_line->HasSwitch(switches::kDisableGLSLTranslator);
- gpu_preferences.disable_gpu_driver_bug_workarounds =
- command_line->HasSwitch(switches::kDisableGpuDriverBugWorkarounds);
- gpu_preferences.disable_shader_name_hashing =
- command_line->HasSwitch(switches::kDisableShaderNameHashing);
- gpu_preferences.enable_gpu_command_logging =
- command_line->HasSwitch(switches::kEnableGPUCommandLogging);
- gpu_preferences.enable_gpu_debugging =
- command_line->HasSwitch(switches::kEnableGPUDebugging);
- gpu_preferences.enable_gpu_service_logging_gpu =
- command_line->HasSwitch(switches::kEnableGPUServiceLoggingGPU);
- gpu_preferences.disable_gpu_program_cache =
- command_line->HasSwitch(switches::kDisableGpuProgramCache);
- gpu_preferences.enforce_gl_minimums =
- command_line->HasSwitch(switches::kEnforceGLMinimums);
- if (GetSizeTFromSwitch(command_line, switches::kForceGpuMemAvailableMb,
- &gpu_preferences.force_gpu_mem_available)) {
- gpu_preferences.force_gpu_mem_available *= 1024 * 1024;
- }
- if (GetSizeTFromSwitch(command_line, switches::kGpuProgramCacheSizeKb,
- &gpu_preferences.gpu_program_cache_size)) {
- gpu_preferences.gpu_program_cache_size *= 1024;
- }
- gpu_preferences.enable_share_group_async_texture_upload =
- command_line->HasSwitch(switches::kEnableShareGroupAsyncTextureUpload);
- gpu_preferences.enable_subscribe_uniform_extension =
- command_line->HasSwitch(switches::kEnableSubscribeUniformExtension);
- gpu_preferences.enable_threaded_texture_mailboxes =
- command_line->HasSwitch(switches::kEnableThreadedTextureMailboxes);
- gpu_preferences.gl_shader_interm_output =
- command_line->HasSwitch(switches::kGLShaderIntermOutput);
- gpu_preferences.emulate_shader_precision =
- command_line->HasSwitch(switches::kEmulateShaderPrecision);
- gpu_preferences.enable_gpu_service_logging =
- command_line->HasSwitch(switches::kEnableGPUServiceLogging);
- gpu_preferences.enable_gpu_service_tracing =
- command_line->HasSwitch(switches::kEnableGPUServiceTracing);
- gpu_preferences.enable_unsafe_es3_apis =
- command_line->HasSwitch(switches::kEnableUnsafeES3APIs);
- return gpu_preferences;
-}
-
void GpuChildThread::OnCollectGraphicsInfo() {
#if defined(OS_WIN)
// GPU full info collection should only happen on un-sandboxed GPU process
« no previous file with comments | « content/gpu/gpu_child_thread.h ('k') | content/gpu/in_process_gpu_thread.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698