[llvm-commits] CVS: llvm/lib/Bytecode/Analyzer/Analyzer.cpp AnalyzerWrappers.cpp

LLVM llvm at cs.uiuc.edu
Fri Jun 11 10:16:01 PDT 2004


Changes in directory llvm/lib/Bytecode/Analyzer:

Analyzer.cpp updated: 1.5 -> 1.6
AnalyzerWrappers.cpp updated: 1.6 -> 1.7

---
Log message:

Implement tracking of bytecode instruction size and the number of long 
instructions generated. 


---
Diffs of the changes:  (+16 -0)

Index: llvm/lib/Bytecode/Analyzer/Analyzer.cpp
diff -u llvm/lib/Bytecode/Analyzer/Analyzer.cpp:1.5 llvm/lib/Bytecode/Analyzer/Analyzer.cpp:1.6
--- llvm/lib/Bytecode/Analyzer/Analyzer.cpp:1.5	Thu Jun 10 22:06:43 2004
+++ llvm/lib/Bytecode/Analyzer/Analyzer.cpp	Fri Jun 11 10:10:38 2004
@@ -52,6 +52,8 @@
     bca.fileDensity = 0.0;
     bca.globalsDensity = 0.0;
     bca.functionDensity = 0.0;
+    bca.instructionSize = 0;
+    bca.longInstructions = 0;
     bca.vbrCount32 = 0;
     bca.vbrCount64 = 0;
     bca.vbrCompBytes = 0;
@@ -167,6 +169,8 @@
     currFunc->numPhis = 0;
     currFunc->numOperands = 0;
     currFunc->density = 0.0;
+    currFunc->instructionSize = 0;
+    currFunc->longInstructions = 0;
     currFunc->vbrCount32 = 0;
     currFunc->vbrCount64 = 0;
     currFunc->vbrCompBytes = 0;
@@ -188,9 +192,13 @@
     std::vector<unsigned>& Operands, unsigned Size) {
     bca.numInstructions++;
     bca.numValues++;
+    bca.instructionSize += Size;
+    if (Size > 4 ) bca.longInstructions++;
     bca.numOperands += Operands.size();
     if ( currFunc ) {
       currFunc->numInstructions++;
+      currFunc->instructionSize += Size;
+      if (Size > 4 ) currFunc->longInstructions++;
       if ( Opcode == Instruction::PHI ) currFunc->numPhis++;
     }
     return Instruction::isTerminator(Opcode); 


Index: llvm/lib/Bytecode/Analyzer/AnalyzerWrappers.cpp
diff -u llvm/lib/Bytecode/Analyzer/AnalyzerWrappers.cpp:1.6 llvm/lib/Bytecode/Analyzer/AnalyzerWrappers.cpp:1.7
--- llvm/lib/Bytecode/Analyzer/AnalyzerWrappers.cpp:1.6	Thu Jun 10 17:03:00 2004
+++ llvm/lib/Bytecode/Analyzer/AnalyzerWrappers.cpp	Fri Jun 11 10:10:38 2004
@@ -249,6 +249,10 @@
   print(Out, "Number Of Operands",              bca.numOperands);
   print(Out, "Number Of Compaction Tables",     bca.numCmpctnTables);
   print(Out, "Number Of Symbol Tables",         bca.numSymTab);
+  print(Out, "Long Instructions", bca.longInstructions);
+  print(Out, "Instruction Size", bca.instructionSize);
+  print(Out, "Average Instruction Size", 
+    double(bca.instructionSize)/double(bca.numInstructions));
   print(Out, "Maximum Type Slot Number",        bca.maxTypeSlot);
   print(Out, "Maximum Value Slot Number",       bca.maxValueSlot);
   print(Out, "Bytes Thrown To Alignment",       double(bca.numAlignment), 
@@ -304,6 +308,10 @@
       print(Out, "Type:", I->second.description);
       print(Out, "Byte Size", I->second.byteSize);
       print(Out, "Instructions", I->second.numInstructions);
+      print(Out, "Long Instructions", I->second.longInstructions);
+      print(Out, "Instruction Size", I->second.instructionSize);
+      print(Out, "Average Instruction Size", 
+        double(I->second.instructionSize)/double(I->second.numInstructions));
       print(Out, "Basic Blocks", I->second.numBasicBlocks);
       print(Out, "Operand", I->second.numOperands);
       print(Out, "Function Density", I->second.density);





More information about the llvm-commits mailing list