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

Side by Side Diff: Source/core/inspector/TimelineTraceEventProcessor.cpp

Issue 46663010: DevTools: Show GPU utilization bar on timeline (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 7 years, 1 month 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2013 Google Inc. All rights reserved. 2 * Copyright (C) 2013 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after
141 #endif 141 #endif
142 142
143 void TimelineRecordStack::send(PassRefPtr<JSONObject> record) 143 void TimelineRecordStack::send(PassRefPtr<JSONObject> record)
144 { 144 {
145 InspectorTimelineAgent* timelineAgent = m_timelineAgent.get(); 145 InspectorTimelineAgent* timelineAgent = m_timelineAgent.get();
146 if (!timelineAgent) 146 if (!timelineAgent)
147 return; 147 return;
148 timelineAgent->sendEvent(record); 148 timelineAgent->sendEvent(record);
149 } 149 }
150 150
151 TimelineTraceEventProcessor::TimelineTraceEventProcessor(WeakPtr<InspectorTimeli neAgent> timelineAgent, InspectorClient *client) 151 TimelineTraceEventProcessor::TimelineTraceEventProcessor(WeakPtr<InspectorTimeli neAgent> timelineAgent, InspectorClient *client, bool collectGpuEvents)
152 : m_timelineAgent(timelineAgent) 152 : m_timelineAgent(timelineAgent)
153 , m_timeConverter(timelineAgent.get()->timeConverter()) 153 , m_timeConverter(timelineAgent.get()->timeConverter())
154 , m_inspectorClient(client) 154 , m_inspectorClient(client)
155 , m_pageId(reinterpret_cast<unsigned long long>(m_timelineAgent.get()->page( ))) 155 , m_pageId(reinterpret_cast<unsigned long long>(m_timelineAgent.get()->page( )))
156 , m_layerTreeId(m_timelineAgent.get()->layerTreeId()) 156 , m_layerTreeId(m_timelineAgent.get()->layerTreeId())
157 , m_lastEventProcessingTime(0) 157 , m_lastEventProcessingTime(0)
158 , m_processEventsTaskInFlight(false) 158 , m_processEventsTaskInFlight(false)
159 , m_layerId(0) 159 , m_layerId(0)
160 , m_paintSetupStart(0) 160 , m_paintSetupStart(0)
161 , m_paintSetupEnd(0) 161 , m_paintSetupEnd(0)
162 , m_gpuTaskStart(0)
162 { 163 {
163 registerHandler(InstrumentationEvents::BeginFrame, TRACE_EVENT_PHASE_INSTANT , &TimelineTraceEventProcessor::onBeginFrame); 164 registerHandler(InstrumentationEvents::BeginFrame, TRACE_EVENT_PHASE_INSTANT , &TimelineTraceEventProcessor::onBeginFrame);
164 registerHandler(InstrumentationEvents::UpdateLayer, TRACE_EVENT_PHASE_BEGIN, &TimelineTraceEventProcessor::onUpdateLayerBegin); 165 registerHandler(InstrumentationEvents::UpdateLayer, TRACE_EVENT_PHASE_BEGIN, &TimelineTraceEventProcessor::onUpdateLayerBegin);
165 registerHandler(InstrumentationEvents::UpdateLayer, TRACE_EVENT_PHASE_END, & TimelineTraceEventProcessor::onUpdateLayerEnd); 166 registerHandler(InstrumentationEvents::UpdateLayer, TRACE_EVENT_PHASE_END, & TimelineTraceEventProcessor::onUpdateLayerEnd);
166 registerHandler(InstrumentationEvents::PaintLayer, TRACE_EVENT_PHASE_BEGIN, &TimelineTraceEventProcessor::onPaintLayerBegin); 167 registerHandler(InstrumentationEvents::PaintLayer, TRACE_EVENT_PHASE_BEGIN, &TimelineTraceEventProcessor::onPaintLayerBegin);
167 registerHandler(InstrumentationEvents::PaintLayer, TRACE_EVENT_PHASE_END, &T imelineTraceEventProcessor::onPaintLayerEnd); 168 registerHandler(InstrumentationEvents::PaintLayer, TRACE_EVENT_PHASE_END, &T imelineTraceEventProcessor::onPaintLayerEnd);
168 registerHandler(InstrumentationEvents::PaintSetup, TRACE_EVENT_PHASE_BEGIN, &TimelineTraceEventProcessor::onPaintSetupBegin); 169 registerHandler(InstrumentationEvents::PaintSetup, TRACE_EVENT_PHASE_BEGIN, &TimelineTraceEventProcessor::onPaintSetupBegin);
169 registerHandler(InstrumentationEvents::PaintSetup, TRACE_EVENT_PHASE_END, &T imelineTraceEventProcessor::onPaintSetupEnd); 170 registerHandler(InstrumentationEvents::PaintSetup, TRACE_EVENT_PHASE_END, &T imelineTraceEventProcessor::onPaintSetupEnd);
170 registerHandler(InstrumentationEvents::RasterTask, TRACE_EVENT_PHASE_BEGIN, &TimelineTraceEventProcessor::onRasterTaskBegin); 171 registerHandler(InstrumentationEvents::RasterTask, TRACE_EVENT_PHASE_BEGIN, &TimelineTraceEventProcessor::onRasterTaskBegin);
171 registerHandler(InstrumentationEvents::RasterTask, TRACE_EVENT_PHASE_END, &T imelineTraceEventProcessor::onRasterTaskEnd); 172 registerHandler(InstrumentationEvents::RasterTask, TRACE_EVENT_PHASE_END, &T imelineTraceEventProcessor::onRasterTaskEnd);
172 registerHandler(InstrumentationEvents::ImageDecodeTask, TRACE_EVENT_PHASE_BE GIN, &TimelineTraceEventProcessor::onImageDecodeTaskBegin); 173 registerHandler(InstrumentationEvents::ImageDecodeTask, TRACE_EVENT_PHASE_BE GIN, &TimelineTraceEventProcessor::onImageDecodeTaskBegin);
173 registerHandler(InstrumentationEvents::ImageDecodeTask, TRACE_EVENT_PHASE_EN D, &TimelineTraceEventProcessor::onImageDecodeTaskEnd); 174 registerHandler(InstrumentationEvents::ImageDecodeTask, TRACE_EVENT_PHASE_EN D, &TimelineTraceEventProcessor::onImageDecodeTaskEnd);
174 registerHandler(InstrumentationEvents::Layer, TRACE_EVENT_PHASE_DELETE_OBJEC T, &TimelineTraceEventProcessor::onLayerDeleted); 175 registerHandler(InstrumentationEvents::Layer, TRACE_EVENT_PHASE_DELETE_OBJEC T, &TimelineTraceEventProcessor::onLayerDeleted);
175 registerHandler(InstrumentationEvents::Paint, TRACE_EVENT_PHASE_INSTANT, &Ti melineTraceEventProcessor::onPaint); 176 registerHandler(InstrumentationEvents::Paint, TRACE_EVENT_PHASE_INSTANT, &Ti melineTraceEventProcessor::onPaint);
176 registerHandler(PlatformInstrumentation::ImageDecodeEvent, TRACE_EVENT_PHASE _BEGIN, &TimelineTraceEventProcessor::onImageDecodeBegin); 177 registerHandler(PlatformInstrumentation::ImageDecodeEvent, TRACE_EVENT_PHASE _BEGIN, &TimelineTraceEventProcessor::onImageDecodeBegin);
177 registerHandler(PlatformInstrumentation::ImageDecodeEvent, TRACE_EVENT_PHASE _END, &TimelineTraceEventProcessor::onImageDecodeEnd); 178 registerHandler(PlatformInstrumentation::ImageDecodeEvent, TRACE_EVENT_PHASE _END, &TimelineTraceEventProcessor::onImageDecodeEnd);
178 registerHandler(PlatformInstrumentation::DrawLazyPixelRefEvent, TRACE_EVENT_ PHASE_INSTANT, &TimelineTraceEventProcessor::onDrawLazyPixelRef); 179 registerHandler(PlatformInstrumentation::DrawLazyPixelRefEvent, TRACE_EVENT_ PHASE_INSTANT, &TimelineTraceEventProcessor::onDrawLazyPixelRef);
179 registerHandler(PlatformInstrumentation::LazyPixelRef, TRACE_EVENT_PHASE_DEL ETE_OBJECT, &TimelineTraceEventProcessor::onLazyPixelRefDeleted); 180 registerHandler(PlatformInstrumentation::LazyPixelRef, TRACE_EVENT_PHASE_DEL ETE_OBJECT, &TimelineTraceEventProcessor::onLazyPixelRefDeleted);
181 if (collectGpuEvents) {
182 // FIXME: Instead of filtering GPU events here on the client side
183 // just don't enable collection in the GPU process.
184 // Make sure GPU process agent can handle both client types connected
185 // simultaneously: ones that need GPU events and ones that do not.
186 registerHandler(PlatformInstrumentation::GpuTask, TRACE_EVENT_PHASE_BEGI N, &TimelineTraceEventProcessor::onGpuTaskBegin);
187 registerHandler(PlatformInstrumentation::GpuTask, TRACE_EVENT_PHASE_END, &TimelineTraceEventProcessor::onGpuTaskEnd);
188 }
180 189
181 TraceEventDispatcher::instance()->addProcessor(this, m_inspectorClient); 190 TraceEventDispatcher::instance()->addProcessor(this, m_inspectorClient);
182 } 191 }
183 192
184 TimelineTraceEventProcessor::~TimelineTraceEventProcessor() 193 TimelineTraceEventProcessor::~TimelineTraceEventProcessor()
185 { 194 {
186 } 195 }
187 196
188 void TimelineTraceEventProcessor::registerHandler(const char* name, char phase, TraceEventHandler handler) 197 void TimelineTraceEventProcessor::registerHandler(const char* name, char phase, TraceEventHandler handler)
189 { 198 {
(...skipping 220 matching lines...) Expand 10 before | Expand all | Expand 10 after
410 if (const ImageResource* resource = renderImage->cachedImage()) 419 if (const ImageResource* resource = renderImage->cachedImage())
411 url = resource->url().string(); 420 url = resource->url().string();
412 m_pixelRefToImageInfo.set(pixelRefId, ImageInfo(nodeId, url)); 421 m_pixelRefToImageInfo.set(pixelRefId, ImageInfo(nodeId, url));
413 } 422 }
414 423
415 void TimelineTraceEventProcessor::onLazyPixelRefDeleted(const TraceEvent& event) 424 void TimelineTraceEventProcessor::onLazyPixelRefDeleted(const TraceEvent& event)
416 { 425 {
417 m_pixelRefToImageInfo.remove(event.id()); 426 m_pixelRefToImageInfo.remove(event.id());
418 } 427 }
419 428
429 void TimelineTraceEventProcessor::onGpuTaskBegin(const TraceEvent& event)
430 {
431 m_gpuTaskStart = m_timeConverter.fromMonotonicallyIncreasingTime(event.times tamp());
432 m_gpuTaskRendererPid = event.asUInt(PlatformInstrumentation::GpuTaskRenderer Pid);
433 }
434
435 void TimelineTraceEventProcessor::onGpuTaskEnd(const TraceEvent& event)
436 {
437 InspectorTimelineAgent* timelineAgent = m_timelineAgent.get();
438 if (!timelineAgent || !m_gpuTaskStart)
439 return;
440 RefPtr<JSONObject> gpuEvent = TimelineRecordFactory::createBackgroundRecord( m_gpuTaskStart, "gpu");
441 RefPtr<JSONObject> data = JSONObject::create();
442 gpuEvent->setString("type", TimelineRecordType::GpuTask);
443 gpuEvent->setNumber("endTime", m_timeConverter.fromMonotonicallyIncreasingTi me(event.timestamp()));
444 gpuEvent->setObject("data", data);
445 data->setString("name", event.name());
446 data->setNumber("rendererPid", m_gpuTaskRendererPid);
447 timelineAgent->sendEvent(gpuEvent);
448 m_gpuTaskStart = 0;
449 }
450
420 PassRefPtr<JSONObject> TimelineTraceEventProcessor::createRecord(const TraceEven t& event, const String& recordType, PassRefPtr<JSONObject> data) 451 PassRefPtr<JSONObject> TimelineTraceEventProcessor::createRecord(const TraceEven t& event, const String& recordType, PassRefPtr<JSONObject> data)
421 { 452 {
422 double startTime = m_timeConverter.fromMonotonicallyIncreasingTime(event.tim estamp()); 453 double startTime = m_timeConverter.fromMonotonicallyIncreasingTime(event.tim estamp());
423 RefPtr<JSONObject> record = TimelineRecordFactory::createBackgroundRecord(st artTime, String::number(event.threadIdentifier())); 454 RefPtr<JSONObject> record = TimelineRecordFactory::createBackgroundRecord(st artTime, String::number(event.threadIdentifier()));
424 record->setString("type", recordType); 455 record->setString("type", recordType);
425 record->setObject("data", data ? data : JSONObject::create()); 456 record->setObject("data", data ? data : JSONObject::create());
426 return record.release(); 457 return record.release();
427 } 458 }
428 459
429 void TimelineTraceEventProcessor::processBackgroundEvents() 460 void TimelineTraceEventProcessor::processBackgroundEvents()
(...skipping 17 matching lines...) Expand all
447 } 478 }
448 479
449 void TimelineTraceEventProcessor::processBackgroundEventsTask() 480 void TimelineTraceEventProcessor::processBackgroundEventsTask()
450 { 481 {
451 m_processEventsTaskInFlight = false; 482 m_processEventsTaskInFlight = false;
452 processBackgroundEvents(); 483 processBackgroundEvents();
453 } 484 }
454 485
455 } // namespace WebCore 486 } // namespace WebCore
456 487
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698