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

Unified Diff: services/ui/gpu/gpu_service.cc

Issue 2801723002: GpuService: introduce GetGpuMemoryBufferAttribs as a mojo interface
Patch Set: cache GpuMemoryBufferAttribs, rename GetSupportedGpuMemoryBufferAttribsForUsage Created 3 years, 8 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 | « services/ui/gpu/gpu_service.h ('k') | services/ui/gpu/interfaces/gpu_service.mojom » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: services/ui/gpu/gpu_service.cc
diff --git a/services/ui/gpu/gpu_service.cc b/services/ui/gpu/gpu_service.cc
index 03c8823b173a4a67a5d29dfcc68e03b1f5a9d8e0..fd74de305674af77fcf9ce337737986b7c250466 100644
--- a/services/ui/gpu/gpu_service.cc
+++ b/services/ui/gpu/gpu_service.cc
@@ -241,6 +241,37 @@ void GpuService::DestroyGpuMemoryBuffer(gfx::GpuMemoryBufferId id,
gpu_channel_manager_->DestroyGpuMemoryBuffer(id, client_id, sync_token);
}
+void GpuService::GetGpuMemoryBufferAttribs(
+ const GetGpuMemoryBufferAttribsCallback& callback) {
+ if (gpu_memory_buffer_attribs_.size() > 0) {
+ callback.Run(gpu_memory_buffer_attribs_);
+ return;
+ }
+
+ for (int i = 0; i < static_cast<int>(gfx::BufferUsage::LAST); i++) {
+ gfx::GpuMemoryBufferAttribVector tmp =
+ gpu_memory_buffer_factory_->GetGpuMemoryBufferAttribsForUsage(
+ static_cast<gfx::BufferUsage>(i));
+ if (tmp.size() == 0)
+ continue;
+
+ gfx::GpuMemoryBufferAttribVector intersection;
+ std::sort(tmp.begin(), tmp.end());
+
+ if (gpu_memory_buffer_attribs_.size() == 0)
+ gpu_memory_buffer_attribs_ = std::move(tmp);
+ else {
+ std::set_intersection(gpu_memory_buffer_attribs_.begin(),
+ gpu_memory_buffer_attribs_.end(),
+ tmp.begin(), tmp.end(),
+ std::back_inserter(intersection));
+ gpu_memory_buffer_attribs_ = std::move(intersection);
+ }
+ }
+
+ callback.Run(gpu_memory_buffer_attribs_);
+}
+
void GpuService::GetVideoMemoryUsageStats(
const GetVideoMemoryUsageStatsCallback& callback) {
if (io_runner_->BelongsToCurrentThread()) {
« no previous file with comments | « services/ui/gpu/gpu_service.h ('k') | services/ui/gpu/interfaces/gpu_service.mojom » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698