aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llmemoryview.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llmemoryview.cpp')
-rw-r--r--linden/indra/newview/llmemoryview.cpp53
1 files changed, 51 insertions, 2 deletions
diff --git a/linden/indra/newview/llmemoryview.cpp b/linden/indra/newview/llmemoryview.cpp
index 1d92bff..c29b33f 100644
--- a/linden/indra/newview/llmemoryview.cpp
+++ b/linden/indra/newview/llmemoryview.cpp
@@ -45,10 +45,20 @@
45 45
46#include "llfasttimer.h" 46#include "llfasttimer.h"
47 47
48
49
48LLMemoryView::LLMemoryView(const std::string& name, const LLRect& rect) 50LLMemoryView::LLMemoryView(const std::string& name, const LLRect& rect)
49: LLView(name, rect, TRUE) 51: LLView(name, rect, TRUE),
52mDelay(120)
50{ 53{
51 setVisible(FALSE); 54 setVisible(FALSE);
55 mDumpTimer.reset();
56
57#ifdef MEM_DUMP_DATA
58 // clear out file.
59 FILE *dump = fopen("memusagedump.txt", "w");
60 fclose(dump);
61#endif
52} 62}
53 63
54LLMemoryView::~LLMemoryView() 64LLMemoryView::~LLMemoryView()
@@ -196,7 +206,7 @@ void LLMemoryView::draw()
196 peak += maxbytes; 206 peak += maxbytes;
197 S32 mbytes = bytes >> 20; 207 S32 mbytes = bytes >> 20;
198 208
199 tdesc = llformat("%s [%4d MB]",mtv_display_table[i].desc,mbytes); 209 tdesc = llformat("%s [%4d MB] in %06d NEWS",mtv_display_table[i].desc,mbytes, LLMemType::sNewCount[tidx]);
200 LLFontGL::sMonospace->renderUTF8(tdesc, 0, x, y, LLColor4::white, LLFontGL::LEFT, LLFontGL::TOP); 210 LLFontGL::sMonospace->renderUTF8(tdesc, 0, x, y, LLColor4::white, LLFontGL::LEFT, LLFontGL::TOP);
201 211
202 y -= (texth + 2); 212 y -= (texth + 2);
@@ -239,7 +249,46 @@ void LLMemoryView::draw()
239 y -= (texth + 2); 249 y -= (texth + 2);
240 } 250 }
241 251
252 dumpData();
253
242#endif 254#endif
243 255
244 LLView::draw(); 256 LLView::draw();
245} 257}
258
259void LLMemoryView::setDataDumpInterval(float delay)
260{
261 mDelay = delay;
262}
263
264void LLMemoryView::dumpData()
265{
266#if MEM_TRACK_TYPE && MEM_DUMP_DATA
267 if (mDelay && (mDumpTimer.getElapsedTimeF32() > mDelay ))
268 {
269 // reset timer
270 mDumpTimer.reset();
271 // append dump info to text file
272 FILE *dump = fopen("memusagedump.txt", "a");
273
274 if (dump)
275 {
276 // write out total memory usage
277 fprintf (dump, "Total memory in use = %09d (%03d MB)\n", LLMemType::sTotalMem, LLMemType::sTotalMem>>20);
278 fprintf (dump, "High Water Mark = %09d (%03d MB)\n\n", LLMemType::sMaxTotalMem, LLMemType::sMaxTotalMem>>20);
279 // dump out usage of 'new' for each memory type
280 for (S32 i=0; i<LLMemType::MTYPE_NUM_TYPES; i++)
281 {
282 if (LLMemType::sMemCount[i])
283 {
284 std::string outData = llformat("MEM: % 20s %09d %03d MB (%09d %03d MB) in %06d News", LLMemType::sTypeDesc[i], LLMemType::sMemCount[i], LLMemType::sMemCount[i]>>20, LLMemType::sMaxMemCount[i], LLMemType::sMaxMemCount[i]>>20, LLMemType::sNewCount[i]);
285 fprintf (dump, "%s\n", outData.c_str());
286 }
287 }
288 fprintf (dump, "\n\n");
289
290 fclose(dump);
291 }
292 }
293#endif
294}