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

Side by Side Diff: src/IceGlobalContext.h

Issue 1848733002: Subzero: Refine the memory usage report with -szstats . (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: Bug fix Created 4 years, 8 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
« no previous file with comments | « src/IceCompiler.cpp ('k') | src/IceGlobalContext.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 //===- subzero/src/IceGlobalContext.h - Global context defs -----*- C++ -*-===// 1 //===- subzero/src/IceGlobalContext.h - Global context defs -----*- C++ -*-===//
2 // 2 //
3 // The Subzero Code Generator 3 // The Subzero Code Generator
4 // 4 //
5 // This file is distributed under the University of Illinois Open Source 5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details. 6 // License. See LICENSE.TXT for details.
7 // 7 //
8 //===----------------------------------------------------------------------===// 8 //===----------------------------------------------------------------------===//
9 /// 9 ///
10 /// \file 10 /// \file
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after
99 CodeStats() { reset(); } 99 CodeStats() { reset(); }
100 void reset() { Stats.fill(0); } 100 void reset() { Stats.fill(0); }
101 void update(CSTag Tag, uint32_t Count = 1) { 101 void update(CSTag Tag, uint32_t Count = 1) {
102 assert(Tag < Stats.size()); 102 assert(Tag < Stats.size());
103 Stats[Tag] += Count; 103 Stats[Tag] += Count;
104 } 104 }
105 void add(const CodeStats &Other) { 105 void add(const CodeStats &Other) {
106 for (uint32_t i = 0; i < Stats.size(); ++i) 106 for (uint32_t i = 0; i < Stats.size(); ++i)
107 Stats[i] += Other.Stats[i]; 107 Stats[i] += Other.Stats[i];
108 } 108 }
109 void dump(const std::string &Name, GlobalContext *Ctx); 109 /// Dumps the stats for the given Cfg. If Func==nullptr, it identifies it
110 /// as the "final" cumulative stats instead as a specific function's name.
111 void dump(const Cfg *Func, GlobalContext *Ctx);
110 112
111 private: 113 private:
112 std::array<uint32_t, CS_NUM> Stats; 114 std::array<uint32_t, CS_NUM> Stats;
113 }; 115 };
114 116
115 /// TimerList is a vector of TimerStack objects, with extra methods 117 /// TimerList is a vector of TimerStack objects, with extra methods
116 /// to initialize and merge these vectors. 118 /// to initialize and merge these vectors.
117 class TimerList : public std::vector<TimerStack> { 119 class TimerList : public std::vector<TimerStack> {
118 TimerList(const TimerList &) = delete; 120 TimerList(const TimerList &) = delete;
119 TimerList &operator=(const TimerList &) = delete; 121 TimerList &operator=(const TimerList &) = delete;
(...skipping 174 matching lines...) Expand 10 before | Expand all | Expand 10 after
294 296
295 const Intrinsics &getIntrinsicsInfo() const { return IntrinsicsInfo; } 297 const Intrinsics &getIntrinsicsInfo() const { return IntrinsicsInfo; }
296 298
297 ELFObjectWriter *getObjectWriter() const { return ObjectWriter.get(); } 299 ELFObjectWriter *getObjectWriter() const { return ObjectWriter.get(); }
298 300
299 /// Reset stats at the beginning of a function. 301 /// Reset stats at the beginning of a function.
300 void resetStats() { 302 void resetStats() {
301 if (BuildDefs::dump()) 303 if (BuildDefs::dump())
302 ICE_TLS_GET_FIELD(TLS)->StatsFunction.reset(); 304 ICE_TLS_GET_FIELD(TLS)->StatsFunction.reset();
303 } 305 }
304 void dumpStats(const std::string &Name, bool Final = false); 306 void dumpStats(const Cfg *Func = nullptr);
305 void statsUpdateEmitted(uint32_t InstCount) { 307 void statsUpdateEmitted(uint32_t InstCount) {
306 if (!getFlags().getDumpStats()) 308 if (!getFlags().getDumpStats())
307 return; 309 return;
308 ThreadContext *Tls = ICE_TLS_GET_FIELD(TLS); 310 ThreadContext *Tls = ICE_TLS_GET_FIELD(TLS);
309 Tls->StatsFunction.update(CodeStats::CS_InstCount, InstCount); 311 Tls->StatsFunction.update(CodeStats::CS_InstCount, InstCount);
310 Tls->StatsCumulative.update(CodeStats::CS_InstCount, InstCount); 312 Tls->StatsCumulative.update(CodeStats::CS_InstCount, InstCount);
311 } 313 }
312 void statsUpdateRegistersSaved(uint32_t Num) { 314 void statsUpdateRegistersSaved(uint32_t Num) {
313 if (!getFlags().getDumpStats()) 315 if (!getFlags().getDumpStats())
314 return; 316 return;
(...skipping 362 matching lines...) Expand 10 before | Expand all | Expand 10 after
677 explicit OstreamLocker(GlobalContext *Ctx) : Ctx(Ctx) { Ctx->lockStr(); } 679 explicit OstreamLocker(GlobalContext *Ctx) : Ctx(Ctx) { Ctx->lockStr(); }
678 ~OstreamLocker() { Ctx->unlockStr(); } 680 ~OstreamLocker() { Ctx->unlockStr(); }
679 681
680 private: 682 private:
681 GlobalContext *const Ctx; 683 GlobalContext *const Ctx;
682 }; 684 };
683 685
684 } // end of namespace Ice 686 } // end of namespace Ice
685 687
686 #endif // SUBZERO_SRC_ICEGLOBALCONTEXT_H 688 #endif // SUBZERO_SRC_ICEGLOBALCONTEXT_H
OLDNEW
« no previous file with comments | « src/IceCompiler.cpp ('k') | src/IceGlobalContext.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698