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

Unified Diff: src/ic/ic-stats.h

Issue 2503183002: [Tracing] Implement IC statistics in tracing. (Closed)
Patch Set: add cache for function name Created 4 years 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 side-by-side diff with in-line comments
Download patch
Index: src/ic/ic-stats.h
diff --git a/src/ic/ic-stats.h b/src/ic/ic-stats.h
new file mode 100644
index 0000000000000000000000000000000000000000..8e3e8ab09b94456e9444578be46805adeefc42c6
--- /dev/null
+++ b/src/ic/ic-stats.h
@@ -0,0 +1,76 @@
+// Copyright 2016 the V8 project authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef V8_IC_IC_STATS_H_
+#define V8_IC_IC_STATS_H_
+
+#include <memory>
+#include <string>
+#include <unordered_map>
+#include <vector>
+
+#include "src/base/atomicops.h"
+#include "src/base/lazy-instance.h"
+
+namespace v8 {
+
+namespace tracing {
+class TracedValue;
+}
+
+namespace internal {
+
+class JSFunction;
+class Object;
+
+struct ICInfo {
+ ICInfo();
+ void Reset();
+ void AppendToTracedValue(v8::tracing::TracedValue* value) const;
+ std::string type;
+ std::string function_name;
+ int offset;
Camillo Bruni 2016/12/02 12:12:55 rename to script_offset
lpy 2016/12/05 17:49:11 Done.
+ const char* script_name;
+ int line_num;
+ unsigned constructor;
Camillo Bruni 2016/12/02 12:12:55 bool is_constructor
lpy 2016/12/05 17:49:11 Done.
+ std::string state;
+ // Address of the map.
+ void* map;
+ // Indicate whether map is a dictionary map.
+ unsigned dict;
Camillo Bruni 2016/12/02 12:12:55 this should be bool I guess (also maybe rename it
lpy 2016/12/05 17:49:11 Done.
+ // Number of own descriptors.
+ unsigned own;
Camillo Bruni 2016/12/02 12:12:55 please rename to: number_of_own_descriptors (or a
lpy 2016/12/05 17:49:11 Done.
+ std::string instance_type;
+};
+
+class ICStats {
+ public:
+ const int MAX_IC_INFO = 4096;
+
+ ICStats();
+ void Dump();
+ void Begin();
+ void End();
+ void Reset();
+ V8_INLINE ICInfo& Current() {
+ DCHECK(pos_ >= 0 && pos_ < MAX_IC_INFO);
+ return ic_infos_[pos_];
+ }
+ const char* GetOrCacheScriptName(Object* obj);
+ std::string& GetOrCacheFunctionName(JSFunction* function);
+ V8_INLINE static ICStats* instance() { return instance_.Pointer(); }
+
+ private:
+ static base::LazyInstance<ICStats>::type instance_;
+ base::Atomic32 being_used_;
Camillo Bruni 2016/12/02 12:12:55 How about "enabled"?
lpy 2016/12/05 17:49:11 Done.
+ std::vector<ICInfo> ic_infos_;
+ std::unordered_map<Object*, std::unique_ptr<char[]>> script_name_map_;
+ std::unordered_map<JSFunction*, std::string> function_name_map_;
Camillo Bruni 2016/12/02 12:12:55 Did you try running this on a big website and see
lpy 2016/12/05 17:49:11 Thanks for the advice, will try it with Chrome TOT
+ int pos_;
+};
+
+} // namespace internal
+} // namespace v8
+
+#endif // V8_IC_IC_STATS_H_

Powered by Google App Engine
This is Rietveld 408576698