| OLD | NEW | 
|---|
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 #include "cc/debug/rendering_stats.h" | 5 #include "cc/debug/rendering_stats.h" | 
| 6 | 6 | 
| 7 namespace cc { | 7 namespace cc { | 
| 8 | 8 | 
| 9 RenderingStats::TimeDeltaList::TimeDeltaList() { | 9 RenderingStats::TimeDeltaList::TimeDeltaList() { | 
| 10 } | 10 } | 
| 11 | 11 | 
| 12 RenderingStats::TimeDeltaList::~TimeDeltaList() { | 12 RenderingStats::TimeDeltaList::~TimeDeltaList() { | 
| 13 } | 13 } | 
| 14 | 14 | 
| 15 void RenderingStats::TimeDeltaList::Append(base::TimeDelta value) { | 15 void RenderingStats::TimeDeltaList::Append(base::TimeDelta value) { | 
| 16   values.push_back(value); | 16   values.push_back(value); | 
| 17 } | 17 } | 
| 18 | 18 | 
| 19 scoped_ptr<base::ListValue> | 19 void RenderingStats::TimeDeltaList::AddToTracedValue( | 
| 20 RenderingStats::TimeDeltaList::AsListValueInMilliseconds() const { | 20     base::debug::TracedValue* list_value) const { | 
| 21   scoped_ptr<base::ListValue> list_value(new base::ListValue); |  | 
| 22   std::list<base::TimeDelta>::const_iterator iter; | 21   std::list<base::TimeDelta>::const_iterator iter; | 
| 23   for (iter = values.begin(); iter != values.end(); ++iter) { | 22   for (iter = values.begin(); iter != values.end(); ++iter) { | 
| 24     list_value->AppendDouble(iter->InMillisecondsF()); | 23     list_value->AppendDouble(iter->InMillisecondsF()); | 
| 25   } | 24   } | 
| 26   return list_value.Pass(); |  | 
| 27 } | 25 } | 
| 28 | 26 | 
| 29 void RenderingStats::TimeDeltaList::Add(const TimeDeltaList& other) { | 27 void RenderingStats::TimeDeltaList::Add(const TimeDeltaList& other) { | 
| 30   values.insert(values.end(), other.values.begin(), other.values.end()); | 28   values.insert(values.end(), other.values.begin(), other.values.end()); | 
| 31 } | 29 } | 
| 32 | 30 | 
| 33 RenderingStats::MainThreadRenderingStats::MainThreadRenderingStats() | 31 RenderingStats::MainThreadRenderingStats::MainThreadRenderingStats() | 
| 34     : frame_count(0), painted_pixel_count(0), recorded_pixel_count(0) { | 32     : frame_count(0), painted_pixel_count(0), recorded_pixel_count(0) { | 
| 35 } | 33 } | 
| 36 | 34 | 
| 37 RenderingStats::MainThreadRenderingStats::~MainThreadRenderingStats() { | 35 RenderingStats::MainThreadRenderingStats::~MainThreadRenderingStats() { | 
| 38 } | 36 } | 
| 39 | 37 | 
| 40 scoped_refptr<base::debug::ConvertableToTraceFormat> | 38 scoped_refptr<base::debug::ConvertableToTraceFormat> | 
| 41 RenderingStats::MainThreadRenderingStats::AsTraceableData() const { | 39 RenderingStats::MainThreadRenderingStats::AsTraceableData() const { | 
| 42   scoped_ptr<base::DictionaryValue> record_data(new base::DictionaryValue()); | 40   scoped_refptr<base::debug::TracedValue> record_data = | 
|  | 41       new base::debug::TracedValue(); | 
| 43   record_data->SetInteger("frame_count", frame_count); | 42   record_data->SetInteger("frame_count", frame_count); | 
| 44   record_data->SetDouble("paint_time", paint_time.InSecondsF()); | 43   record_data->SetDouble("paint_time", paint_time.InSecondsF()); | 
| 45   record_data->SetInteger("painted_pixel_count", painted_pixel_count); | 44   record_data->SetInteger("painted_pixel_count", painted_pixel_count); | 
| 46   record_data->SetDouble("record_time", record_time.InSecondsF()); | 45   record_data->SetDouble("record_time", record_time.InSecondsF()); | 
| 47   record_data->SetInteger("recorded_pixel_count", recorded_pixel_count); | 46   record_data->SetInteger("recorded_pixel_count", recorded_pixel_count); | 
| 48   return TracedValue::FromValue(record_data.release()); | 47   return record_data; | 
| 49 } | 48 } | 
| 50 | 49 | 
| 51 void RenderingStats::MainThreadRenderingStats::Add( | 50 void RenderingStats::MainThreadRenderingStats::Add( | 
| 52     const MainThreadRenderingStats& other) { | 51     const MainThreadRenderingStats& other) { | 
| 53   frame_count += other.frame_count; | 52   frame_count += other.frame_count; | 
| 54   paint_time += other.paint_time; | 53   paint_time += other.paint_time; | 
| 55   painted_pixel_count += other.painted_pixel_count; | 54   painted_pixel_count += other.painted_pixel_count; | 
| 56   record_time += other.record_time; | 55   record_time += other.record_time; | 
| 57   recorded_pixel_count += other.recorded_pixel_count; | 56   recorded_pixel_count += other.recorded_pixel_count; | 
| 58 } | 57 } | 
| 59 | 58 | 
| 60 RenderingStats::ImplThreadRenderingStats::ImplThreadRenderingStats() | 59 RenderingStats::ImplThreadRenderingStats::ImplThreadRenderingStats() | 
| 61     : frame_count(0), | 60     : frame_count(0), | 
| 62       rasterized_pixel_count(0), | 61       rasterized_pixel_count(0), | 
| 63       visible_content_area(0), | 62       visible_content_area(0), | 
| 64       approximated_visible_content_area(0) { | 63       approximated_visible_content_area(0) { | 
| 65 } | 64 } | 
| 66 | 65 | 
| 67 RenderingStats::ImplThreadRenderingStats::~ImplThreadRenderingStats() { | 66 RenderingStats::ImplThreadRenderingStats::~ImplThreadRenderingStats() { | 
| 68 } | 67 } | 
| 69 | 68 | 
| 70 scoped_refptr<base::debug::ConvertableToTraceFormat> | 69 scoped_refptr<base::debug::ConvertableToTraceFormat> | 
| 71 RenderingStats::ImplThreadRenderingStats::AsTraceableData() const { | 70 RenderingStats::ImplThreadRenderingStats::AsTraceableData() const { | 
| 72   scoped_ptr<base::DictionaryValue> record_data(new base::DictionaryValue()); | 71   scoped_refptr<base::debug::TracedValue> record_data = | 
|  | 72       new base::debug::TracedValue(); | 
| 73   record_data->SetInteger("frame_count", frame_count); | 73   record_data->SetInteger("frame_count", frame_count); | 
| 74   record_data->SetDouble("rasterize_time", rasterize_time.InSecondsF()); | 74   record_data->SetDouble("rasterize_time", rasterize_time.InSecondsF()); | 
| 75   record_data->SetInteger("rasterized_pixel_count", rasterized_pixel_count); | 75   record_data->SetInteger("rasterized_pixel_count", rasterized_pixel_count); | 
| 76   record_data->SetInteger("visible_content_area", visible_content_area); | 76   record_data->SetInteger("visible_content_area", visible_content_area); | 
| 77   record_data->SetInteger("approximated_visible_content_area", | 77   record_data->SetInteger("approximated_visible_content_area", | 
| 78                           approximated_visible_content_area); | 78                           approximated_visible_content_area); | 
| 79   record_data->Set("draw_duration_ms", | 79   record_data->BeginArray("draw_duration_ms"); | 
| 80                    draw_duration.AsListValueInMilliseconds().release()); | 80   draw_duration.AddToTracedValue(record_data.get()); | 
| 81   record_data->Set( | 81   record_data->EndArray(); | 
| 82       "draw_duration_estimate_ms", | 82 | 
| 83       draw_duration_estimate.AsListValueInMilliseconds().release()); | 83   record_data->BeginArray("draw_duration_estimate_ms"); | 
| 84   record_data->Set( | 84   draw_duration_estimate.AddToTracedValue(record_data.get()); | 
| 85       "begin_main_frame_to_commit_duration_ms", | 85   record_data->EndArray(); | 
| 86       begin_main_frame_to_commit_duration.AsListValueInMilliseconds() | 86 | 
| 87           .release()); | 87   record_data->BeginArray("begin_main_frame_to_commit_duration_ms"); | 
| 88   record_data->Set( | 88   begin_main_frame_to_commit_duration.AddToTracedValue(record_data.get()); | 
| 89       "begin_main_frame_to_commit_duration_estimate_ms", | 89   record_data->EndArray(); | 
| 90       begin_main_frame_to_commit_duration_estimate.AsListValueInMilliseconds() | 90 | 
| 91           .release()); | 91   record_data->BeginArray("begin_main_frame_to_commit_duration_estimate_ms"); | 
| 92   record_data->Set( | 92   begin_main_frame_to_commit_duration_estimate.AddToTracedValue( | 
| 93       "commit_to_activate_duration_ms", | 93       record_data.get()); | 
| 94       commit_to_activate_duration.AsListValueInMilliseconds().release()); | 94   record_data->EndArray(); | 
| 95   record_data->Set( | 95 | 
| 96       "commit_to_activate_duration_estimate_ms", | 96   record_data->BeginArray("commit_to_activate_duration_ms"); | 
| 97       commit_to_activate_duration_estimate.AsListValueInMilliseconds() | 97   commit_to_activate_duration.AddToTracedValue(record_data.get()); | 
| 98           .release()); | 98   record_data->EndArray(); | 
| 99   return TracedValue::FromValue(record_data.release()); | 99 | 
|  | 100   record_data->BeginArray("commit_to_activate_duration_estimate_ms"); | 
|  | 101   commit_to_activate_duration_estimate.AddToTracedValue(record_data.get()); | 
|  | 102   record_data->EndArray(); | 
|  | 103   return record_data; | 
| 100 } | 104 } | 
| 101 | 105 | 
| 102 void RenderingStats::ImplThreadRenderingStats::Add( | 106 void RenderingStats::ImplThreadRenderingStats::Add( | 
| 103     const ImplThreadRenderingStats& other) { | 107     const ImplThreadRenderingStats& other) { | 
| 104   frame_count += other.frame_count; | 108   frame_count += other.frame_count; | 
| 105   rasterize_time += other.rasterize_time; | 109   rasterize_time += other.rasterize_time; | 
| 106   analysis_time += other.analysis_time; | 110   analysis_time += other.analysis_time; | 
| 107   rasterized_pixel_count += other.rasterized_pixel_count; | 111   rasterized_pixel_count += other.rasterized_pixel_count; | 
| 108   visible_content_area += other.visible_content_area; | 112   visible_content_area += other.visible_content_area; | 
| 109   approximated_visible_content_area += other.approximated_visible_content_area; | 113   approximated_visible_content_area += other.approximated_visible_content_area; | 
| 110 | 114 | 
| 111   draw_duration.Add(other.draw_duration); | 115   draw_duration.Add(other.draw_duration); | 
| 112   draw_duration_estimate.Add(other.draw_duration_estimate); | 116   draw_duration_estimate.Add(other.draw_duration_estimate); | 
| 113   begin_main_frame_to_commit_duration.Add( | 117   begin_main_frame_to_commit_duration.Add( | 
| 114       other.begin_main_frame_to_commit_duration); | 118       other.begin_main_frame_to_commit_duration); | 
| 115   begin_main_frame_to_commit_duration_estimate.Add( | 119   begin_main_frame_to_commit_duration_estimate.Add( | 
| 116       other.begin_main_frame_to_commit_duration_estimate); | 120       other.begin_main_frame_to_commit_duration_estimate); | 
| 117   commit_to_activate_duration.Add(other.commit_to_activate_duration); | 121   commit_to_activate_duration.Add(other.commit_to_activate_duration); | 
| 118   commit_to_activate_duration_estimate.Add( | 122   commit_to_activate_duration_estimate.Add( | 
| 119       other.commit_to_activate_duration_estimate); | 123       other.commit_to_activate_duration_estimate); | 
| 120 } | 124 } | 
| 121 | 125 | 
| 122 void RenderingStats::Add(const RenderingStats& other) { | 126 void RenderingStats::Add(const RenderingStats& other) { | 
| 123   main_stats.Add(other.main_stats); | 127   main_stats.Add(other.main_stats); | 
| 124   impl_stats.Add(other.impl_stats); | 128   impl_stats.Add(other.impl_stats); | 
| 125 } | 129 } | 
| 126 | 130 | 
| 127 }  // namespace cc | 131 }  // namespace cc | 
| OLD | NEW | 
|---|