summaryrefslogtreecommitdiffstats
path: root/content/common
diff options
context:
space:
mode:
authorzmo@chromium.org <zmo@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-05-10 23:02:42 +0000
committerzmo@chromium.org <zmo@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-05-10 23:02:42 +0000
commita094e2cb67f9c134163a4418315d8d245e406fbe (patch)
tree47f0ee5de8d8216bcb12c2dbd5c65569b13fe200 /content/common
parente9165b203749b1b3b37a93d3e640781384191cb9 (diff)
downloadchromium_src-a094e2cb67f9c134163a4418315d8d245e406fbe.zip
chromium_src-a094e2cb67f9c134163a4418315d8d245e406fbe.tar.gz
chromium_src-a094e2cb67f9c134163a4418315d8d245e406fbe.tar.bz2
Change GPUInfo to handle multiple GPUs.
At the moment we always select one GPU as primary and the others as secondary. In preliminary GPU info collection (without creating a GL context and collect GL VENDOR/RENDERER strings), we actually don't know which GPU is in use. The current logic is that if one GPU is Intel, we assume the other is primary. I agree a better logic is needed. However, at the moment, logging/crash reports all requires ONE GPU vendor_id/device_id, so even though we don't know which GPU is active, we still need to randomly select one. This needs more thinking and design, so I think it's reasonable to leave it to a possible future CL. Also, the logic on collecting GPU info through libpci is changed to collect multiple GPUs. If one is Intel and one is NVIDIA, we assume it's optimus and we disable GPU features. This logic is hardwired in Chrome in this CL. The plan is to push the logic to blacklist, but I'll leave it to a seperate CL. BUG=126307,75220 TEST=about:gpu page on a Linux system with optimus GPU R=kbr TBR=jam Review URL: https://chromiumcodereview.appspot.com/10389051 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@136429 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/common')
-rw-r--r--content/common/gpu/gpu_info_unittest.cc7
-rw-r--r--content/common/gpu/gpu_messages.h11
2 files changed, 13 insertions, 5 deletions
diff --git a/content/common/gpu/gpu_info_unittest.cc b/content/common/gpu/gpu_info_unittest.cc
index 1ce8410..dafaf45 100644
--- a/content/common/gpu/gpu_info_unittest.cc
+++ b/content/common/gpu/gpu_info_unittest.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -10,8 +10,9 @@ TEST(GPUInfoBasicTest, EmptyGPUInfo) {
content::GPUInfo gpu_info;
EXPECT_EQ(gpu_info.finalized, false);
EXPECT_EQ(gpu_info.initialization_time.ToInternalValue(), 0);
- EXPECT_EQ(gpu_info.vendor_id, 0u);
- EXPECT_EQ(gpu_info.device_id, 0u);
+ EXPECT_EQ(gpu_info.gpu.vendor_id, 0u);
+ EXPECT_EQ(gpu_info.gpu.device_id, 0u);
+ EXPECT_EQ(gpu_info.secondary_gpus.size(), 0u);
EXPECT_EQ(gpu_info.driver_vendor, "");
EXPECT_EQ(gpu_info.driver_version, "");
EXPECT_EQ(gpu_info.driver_date, "");
diff --git a/content/common/gpu/gpu_messages.h b/content/common/gpu/gpu_messages.h
index f6cd6cc..90089dd 100644
--- a/content/common/gpu/gpu_messages.h
+++ b/content/common/gpu/gpu_messages.h
@@ -100,12 +100,19 @@ IPC_STRUCT_TRAITS_BEGIN(content::GpuPerformanceStats)
IPC_STRUCT_TRAITS_MEMBER(overall)
IPC_STRUCT_TRAITS_END()
+IPC_STRUCT_TRAITS_BEGIN(content::GPUInfo::GPUDevice)
+ IPC_STRUCT_TRAITS_MEMBER(vendor_id)
+ IPC_STRUCT_TRAITS_MEMBER(device_id)
+ IPC_STRUCT_TRAITS_MEMBER(vendor_string)
+ IPC_STRUCT_TRAITS_MEMBER(device_string)
+IPC_STRUCT_TRAITS_END()
+
IPC_STRUCT_TRAITS_BEGIN(content::GPUInfo)
IPC_STRUCT_TRAITS_MEMBER(finalized)
IPC_STRUCT_TRAITS_MEMBER(initialization_time)
IPC_STRUCT_TRAITS_MEMBER(optimus)
- IPC_STRUCT_TRAITS_MEMBER(vendor_id)
- IPC_STRUCT_TRAITS_MEMBER(device_id)
+ IPC_STRUCT_TRAITS_MEMBER(gpu)
+ IPC_STRUCT_TRAITS_MEMBER(secondary_gpus)
IPC_STRUCT_TRAITS_MEMBER(driver_vendor)
IPC_STRUCT_TRAITS_MEMBER(driver_version)
IPC_STRUCT_TRAITS_MEMBER(driver_date)