Add some statistics for PEI register scavenging
authorJim Grosbach <grosbach@apple.com>
Wed, 25 Aug 2010 20:34:28 +0000 (20:34 +0000)
committerJim Grosbach <grosbach@apple.com>
Wed, 25 Aug 2010 20:34:28 +0000 (20:34 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@112084 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/PrologEpilogInserter.cpp

index 4c3e796f5e3ad31131adc1f0d3295790a7ef8e87..734bf6325265a644ed11a851b8b5a896cb85625f 100644 (file)
@@ -36,6 +36,7 @@
 #include "llvm/Support/Debug.h"
 #include "llvm/ADT/IndexedMap.h"
 #include "llvm/ADT/SmallSet.h"
+#include "llvm/ADT/Statistic.h"
 #include "llvm/ADT/STLExtras.h"
 #include <climits>
 
@@ -46,6 +47,9 @@ char PEI::ID = 0;
 INITIALIZE_PASS(PEI, "prologepilog",
                 "Prologue/Epilogue Insertion", false, false);
 
+STATISTIC(NumVirtualFrameRegs, "Number of virtual frame regs encountered");
+STATISTIC(NumScavengedRegs, "Number of frame index regs scavenged");
+
 /// createPrologEpilogCodeInserter - This function returns a pass that inserts
 /// prolog and epilog code, and eliminates abstract frame references.
 ///
@@ -873,6 +877,8 @@ void PEI::scavengeFrameVirtualRegs(MachineFunction &Fn) {
             }
             continue;
           }
+          ++NumVirtualFrameRegs;
+
           // If this is a def, remember that this insn defines the value.
           // This lets us properly consider insns which re-use the scratch
           // register, such as r2 = sub r2, #imm, in the middle of the
@@ -945,6 +951,7 @@ void PEI::scavengeFrameVirtualRegs(MachineFunction &Fn) {
             const TargetRegisterClass *RC = Fn.getRegInfo().getRegClass(Reg);
             CurrentScratchReg = RS->scavengeRegister(RC, I, SPAdj);
             PrevValue = Value;
+            ++NumScavengedRegs;
           }
           // replace this reference to the virtual register with the
           // scratch register.