summaryrefslogtreecommitdiff
path: root/src/compiler/codegen/arm/ArchUtility.cc
diff options
context:
space:
mode:
author buzbee <buzbee@google.com> 2011-10-02 13:08:29 -0700
committer buzbee <buzbee@google.com> 2011-10-02 13:21:01 -0700
commitbbaf894dded77603bd457758ba2b4636122fb8b7 (patch)
treeac8d0450f23dd6cde9647febef8de514c5a4b8ae /src/compiler/codegen/arm/ArchUtility.cc
parentfc22c89072e310767f8e39776195a219df851ea0 (diff)
Optimization fixes
Two primary fixes. First, the save/restore mechanism for FP callee saves was broken if there were any holes in the save mask (the Arm ld/store multiple instructions for floating point use a start + count mechanism, rather than the bit-mask mechanism used for core registers). The second fix corrects a problem introduced by the recent enhancements to loading floating point literals. The load->copy optimization mechanism for literal loads used the value of the loaded literal to identify redundant loads. However, it used only the first 32 bits of the literal - which worked fine previously because 64-bit literal loads were treated as a pair of 32-bit loads. The fix was to use the label of the literal rather than the value in the aliasInfo - which works for all sizes. Change-Id: Ic4779adf73b2c7d80059a988b0ecdef39921a81f
Diffstat (limited to 'src/compiler/codegen/arm/ArchUtility.cc')
-rw-r--r--src/compiler/codegen/arm/ArchUtility.cc3
1 files changed, 2 insertions, 1 deletions
diff --git a/src/compiler/codegen/arm/ArchUtility.cc b/src/compiler/codegen/arm/ArchUtility.cc
index 3ceffae849..edce1148ce 100644
--- a/src/compiler/codegen/arm/ArchUtility.cc
+++ b/src/compiler/codegen/arm/ArchUtility.cc
@@ -404,7 +404,8 @@ void oatCodegenDump(CompilationUnit* cUnit)
LOG(INFO) << "Regs (excluding ins) : " << cUnit->numRegs;
LOG(INFO) << "Ins : " << cUnit->numIns;
LOG(INFO) << "Outs : " << cUnit->numOuts;
- LOG(INFO) << "Spills : " << cUnit->numSpills;
+ LOG(INFO) << "CoreSpills : " << cUnit->numCoreSpills;
+ LOG(INFO) << "FPSpills : " << cUnit->numFPSpills;
LOG(INFO) << "Padding : " << cUnit->numPadding;
LOG(INFO) << "Frame size : " << cUnit->frameSize;
LOG(INFO) << "Start of ins : " << cUnit->insOffset;