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

Side by Side Diff: chrome/renderer/benchmarking_extension.cc

Issue 12211008: Add a benchmarking_extension API to call TCMalloc's HeapProfilerDump(). (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 10 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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
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
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
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698