// Copyright 2013 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. #include "content/common/gpu/devtools_gpu_agent.h" #include "base/logging.h" #include "content/common/devtools_messages.h" #include "content/common/gpu/gpu_channel.h" #include "content/common/gpu/gpu_channel_manager.h" namespace content { DevToolsGpuAgent::DevToolsGpuAgent(GpuChannel* gpu_channel) : gpu_channel_(gpu_channel), route_id_(MSG_ROUTING_NONE) { } DevToolsGpuAgent::~DevToolsGpuAgent() { } void DevToolsGpuAgent::StartEventsRecording(int32* route_id) { DCHECK(CalledOnValidThread()); if (route_id_ != MSG_ROUTING_NONE) { // Events recording is already in progress, so "fail" the call by // returning MSG_ROUTING_NONE as the route id. *route_id = MSG_ROUTING_NONE; return; } route_id_ = gpu_channel_->GenerateRouteID(); *route_id = route_id_; tasks_.reset(new GpuTaskInfoList()); GpuEventsDispatcher* dispatcher = gpu_channel_->gpu_channel_manager()->gpu_devtools_events_dispatcher(); dispatcher->AddProcessor(this); } void DevToolsGpuAgent::StopEventsRecording() { DCHECK(CalledOnValidThread()); if (route_id_ == MSG_ROUTING_NONE) return; GpuEventsDispatcher* dispatcher = gpu_channel_->gpu_channel_manager()->gpu_devtools_events_dispatcher(); dispatcher->RemoveProcessor(this); route_id_ = MSG_ROUTING_NONE; } void DevToolsGpuAgent::ProcessEvent( TimeTicks timestamp, GpuEventsDispatcher::EventPhase phase, GpuCommandBufferStub* stub) { DCHECK(CalledOnValidThread()); if (route_id_ == MSG_ROUTING_NONE) return; GpuTaskInfo task; task.timestamp = (timestamp - TimeTicks()).InSecondsF(); task.phase = phase; task.foreign = stub->channel() != gpu_channel_; task.used_gpu_memory_bytes = stub->GetMemoryUsage(); const int kFlushIntervalMs = 100; const unsigned kMaxPendingItems = 100; if (!tasks_->empty() && ((timestamp - last_flush_time_).InMilliseconds() >= kFlushIntervalMs || tasks_->size() >= kMaxPendingItems)) { Send(new DevToolsAgentMsg_GpuTasksChunk(route_id_, *tasks_)); tasks_->clear(); last_flush_time_ = timestamp; } tasks_->push_back(task); } bool DevToolsGpuAgent::Send(IPC::Message* msg) { scoped_ptr<IPC::Message> message(msg); return gpu_channel_ && gpu_channel_->Send(message.release()); } } // namespace content