OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "chrome/renderer/benchmarking_extension.h" | 5 #include "chrome/renderer/benchmarking_extension.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/string_util.h" | |
8 #include "base/metrics/stats_table.h" | 9 #include "base/metrics/stats_table.h" |
9 #include "base/time.h" | 10 #include "base/time.h" |
10 #include "chrome/common/benchmarking_messages.h" | 11 #include "chrome/common/benchmarking_messages.h" |
11 #include "content/public/common/content_switches.h" | 12 #include "content/public/common/content_switches.h" |
12 #include "content/public/renderer/render_thread.h" | 13 #include "content/public/renderer/render_thread.h" |
14 #if !defined(NO_TCMALLOC) && (defined(OS_LINUX) || defined(OS_CHROMEOS)) | |
15 #include "third_party/tcmalloc/chromium/src/gperftools/heap-profiler.h" | |
16 #endif // !defined(NO_TCMALLOC) && (defined(OS_LINUX) || defined(OS_CHROMEOS)) | |
13 #include "third_party/WebKit/Source/WebKit/chromium/public/WebCache.h" | 17 #include "third_party/WebKit/Source/WebKit/chromium/public/WebCache.h" |
14 #include "v8/include/v8.h" | 18 #include "v8/include/v8.h" |
15 | 19 |
16 using WebKit::WebCache; | 20 using WebKit::WebCache; |
17 | 21 |
18 const char kBenchmarkingExtensionName[] = "v8/Benchmarking"; | 22 const char kBenchmarkingExtensionName[] = "v8/Benchmarking"; |
19 | 23 |
20 namespace extensions_v8 { | 24 namespace extensions_v8 { |
21 | 25 |
22 class BenchmarkingWrapper : public v8::Extension { | 26 class BenchmarkingWrapper : public v8::Extension { |
(...skipping 27 matching lines...) Expand all Loading... | |
50 " return GetCounter(name);" | 54 " return GetCounter(name);" |
51 "};" | 55 "};" |
52 "chrome.benchmarking.enableSpdy = function(name) {" | 56 "chrome.benchmarking.enableSpdy = function(name) {" |
53 " native function EnableSpdy();" | 57 " native function EnableSpdy();" |
54 " EnableSpdy(name);" | 58 " EnableSpdy(name);" |
55 "};" | 59 "};" |
56 "chrome.benchmarking.isSingleProcess = function() {" | 60 "chrome.benchmarking.isSingleProcess = function() {" |
57 " native function IsSingleProcess();" | 61 " native function IsSingleProcess();" |
58 " return IsSingleProcess();" | 62 " return IsSingleProcess();" |
59 "};" | 63 "};" |
64 #if !defined(NO_TCMALLOC) && (defined(OS_LINUX) || defined(OS_CHROMEOS)) | |
65 "chrome.benchmarking.heapProfilerDump = function(reason) {" | |
66 " native function HeapProfilerDump();" | |
67 " HeapProfilerDump(reason);" | |
68 "};" | |
69 #endif // !defined(NO_TCMALLOC) && (defined(OS_LINUX) || defined(OS_CHROMEOS)) | |
60 "chrome.Interval = function() {" | 70 "chrome.Interval = function() {" |
61 " var start_ = 0;" | 71 " var start_ = 0;" |
62 " var stop_ = 0;" | 72 " var stop_ = 0;" |
63 " native function HiResTime();" | 73 " native function HiResTime();" |
64 " this.start = function() {" | 74 " this.start = function() {" |
65 " stop_ = 0;" | 75 " stop_ = 0;" |
66 " start_ = HiResTime();" | 76 " start_ = HiResTime();" |
67 " };" | 77 " };" |
68 " this.stop = function() {" | 78 " this.stop = function() {" |
69 " stop_ = HiResTime();" | 79 " stop_ = HiResTime();" |
(...skipping 18 matching lines...) Expand all Loading... | |
88 } else if (name->Equals(v8::String::New("ClearHostResolverCache"))) { | 98 } else if (name->Equals(v8::String::New("ClearHostResolverCache"))) { |
89 return v8::FunctionTemplate::New(ClearHostResolverCache); | 99 return v8::FunctionTemplate::New(ClearHostResolverCache); |
90 } else if (name->Equals(v8::String::New("ClearPredictorCache"))) { | 100 } else if (name->Equals(v8::String::New("ClearPredictorCache"))) { |
91 return v8::FunctionTemplate::New(ClearPredictorCache); | 101 return v8::FunctionTemplate::New(ClearPredictorCache); |
92 } else if (name->Equals(v8::String::New("EnableSpdy"))) { | 102 } else if (name->Equals(v8::String::New("EnableSpdy"))) { |
93 return v8::FunctionTemplate::New(EnableSpdy); | 103 return v8::FunctionTemplate::New(EnableSpdy); |
94 } else if (name->Equals(v8::String::New("GetCounter"))) { | 104 } else if (name->Equals(v8::String::New("GetCounter"))) { |
95 return v8::FunctionTemplate::New(GetCounter); | 105 return v8::FunctionTemplate::New(GetCounter); |
96 } else if (name->Equals(v8::String::New("IsSingleProcess"))) { | 106 } else if (name->Equals(v8::String::New("IsSingleProcess"))) { |
97 return v8::FunctionTemplate::New(IsSingleProcess); | 107 return v8::FunctionTemplate::New(IsSingleProcess); |
108 #if !defined(NO_TCMALLOC) && (defined(OS_LINUX) || defined(OS_CHROMEOS)) | |
109 } else if (name->Equals(v8::String::New("HeapProfilerDump"))) { | |
110 return v8::FunctionTemplate::New(HeapProfilerDump); | |
111 #endif // !defined(NO_TCMALLOC) && (defined(OS_LINUX) || defined(OS_CHROMEOS)) | |
98 } else if (name->Equals(v8::String::New("HiResTime"))) { | 112 } else if (name->Equals(v8::String::New("HiResTime"))) { |
99 return v8::FunctionTemplate::New(HiResTime); | 113 return v8::FunctionTemplate::New(HiResTime); |
100 } | 114 } |
101 | 115 |
102 return v8::Handle<v8::FunctionTemplate>(); | 116 return v8::Handle<v8::FunctionTemplate>(); |
103 } | 117 } |
104 | 118 |
105 static v8::Handle<v8::Value> CloseConnections(const v8::Arguments& args) { | 119 static v8::Handle<v8::Value> CloseConnections(const v8::Arguments& args) { |
106 content::RenderThread::Get()->Send( | 120 content::RenderThread::Get()->Send( |
107 new ChromeViewHostMsg_CloseCurrentConnections()); | 121 new ChromeViewHostMsg_CloseCurrentConnections()); |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
152 | 166 |
153 int counter = base::StatsTable::current()->GetCounterValue(name); | 167 int counter = base::StatsTable::current()->GetCounterValue(name); |
154 return v8::Integer::New(counter); | 168 return v8::Integer::New(counter); |
155 } | 169 } |
156 | 170 |
157 static v8::Handle<v8::Value> IsSingleProcess(const v8::Arguments& args) { | 171 static v8::Handle<v8::Value> IsSingleProcess(const v8::Arguments& args) { |
158 return v8::Boolean::New( | 172 return v8::Boolean::New( |
159 CommandLine::ForCurrentProcess()->HasSwitch(switches::kSingleProcess)); | 173 CommandLine::ForCurrentProcess()->HasSwitch(switches::kSingleProcess)); |
160 } | 174 } |
161 | 175 |
176 #if !defined(NO_TCMALLOC) && (defined(OS_LINUX) || defined(OS_CHROMEOS)) | |
nduca
2013/02/06 07:26:42
Awesome. Now, we've been trying to split apart thi
Dai Mikurube (NOT FULLTIME)
2013/02/06 10:51:15
Hmm, do you mean we should have new memory_benchma
| |
177 static v8::Handle<v8::Value> HeapProfilerDump(const v8::Arguments& args) { | |
178 char reason[256]; | |
179 if (args.Length() && args[0]->IsString()) | |
180 args[0]->ToString()->WriteAscii(reason, 0, sizeof(reason) - 1); | |
181 else | |
182 base::strlcpy(reason, "benchmarking_extension", sizeof(reason)); | |
183 | |
184 ::HeapProfilerDump(reason); | |
185 return v8::Undefined(); | |
186 } | |
187 #endif // !defined(NO_TCMALLOC) && (defined(OS_LINUX) || defined(OS_CHROMEOS)) | |
188 | |
162 static v8::Handle<v8::Value> HiResTime(const v8::Arguments& args) { | 189 static v8::Handle<v8::Value> HiResTime(const v8::Arguments& args) { |
163 return v8::Number::New( | 190 return v8::Number::New( |
164 static_cast<double>(base::TimeTicks::HighResNow().ToInternalValue())); | 191 static_cast<double>(base::TimeTicks::HighResNow().ToInternalValue())); |
165 } | 192 } |
166 }; | 193 }; |
167 | 194 |
168 v8::Extension* BenchmarkingExtension::Get() { | 195 v8::Extension* BenchmarkingExtension::Get() { |
169 return new BenchmarkingWrapper(); | 196 return new BenchmarkingWrapper(); |
170 } | 197 } |
171 | 198 |
172 } // namespace extensions_v8 | 199 } // namespace extensions_v8 |
OLD | NEW |