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

Side by Side Diff: src/IceTargetLoweringX86BaseImpl.h

Issue 1377323002: Subzero: Change -asm-verbose output to print more useful info. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: Also add predecessors and loop depth Created 5 years, 2 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/IceOperand.h ('k') | no next file » | 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/IceTargetLoweringX86BaseImpl.h - x86 lowering -*- C++ -*-==// 1 //===- subzero/src/IceTargetLoweringX86BaseImpl.h - x86 lowering -*- 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 728 matching lines...) Expand 10 before | Expand all | Expand 10 after
739 if (!BuildDefs::dump()) 739 if (!BuildDefs::dump())
740 return; 740 return;
741 Ostream &Str = Ctx->getStrEmit(); 741 Ostream &Str = Ctx->getStrEmit();
742 if (Var->hasReg()) { 742 if (Var->hasReg()) {
743 Str << "%" << getRegName(Var->getRegNum(), Var->getType()); 743 Str << "%" << getRegName(Var->getRegNum(), Var->getType());
744 return; 744 return;
745 } 745 }
746 if (Var->mustHaveReg()) { 746 if (Var->mustHaveReg()) {
747 llvm_unreachable("Infinite-weight Variable has no register assigned"); 747 llvm_unreachable("Infinite-weight Variable has no register assigned");
748 } 748 }
749 int32_t Offset = Var->getStackOffset(); 749 const int32_t Offset = Var->getStackOffset();
750 int32_t OffsetAdj = 0;
750 int32_t BaseRegNum = Var->getBaseRegNum(); 751 int32_t BaseRegNum = Var->getBaseRegNum();
751 if (BaseRegNum == Variable::NoRegister) { 752 if (BaseRegNum == Variable::NoRegister) {
752 BaseRegNum = getFrameOrStackReg(); 753 BaseRegNum = getFrameOrStackReg();
753 if (!hasFramePointer()) 754 if (!hasFramePointer())
754 Offset += getStackAdjustment(); 755 OffsetAdj = getStackAdjustment();
755 } 756 }
756 if (Offset) 757 // Print in the form "OffsetAdj+Offset(%reg)", taking care that:
757 Str << Offset; 758 // - OffsetAdj may be 0
759 // - Offset is never printed when it is 0
760 // - Offset may be positive or symbolic, so a "+" might be needed
761
762 // Only print nonzero OffsetAdj.
763 if (OffsetAdj) {
764 Str << OffsetAdj;
765 }
766 const bool DecorateAsm = Func->getContext()->getFlags().getDecorateAsm();
767 // Only print Offset when it is nonzero, regardless of DecorateAsm.
768 if (Offset) {
769 if (OffsetAdj && (DecorateAsm || Offset > 0)) {
770 Str << "+";
771 }
772 if (DecorateAsm) {
773 Str << Var->getSymbolicStackOffset(Func);
774 } else {
775 Str << Offset;
776 }
777 }
758 const Type FrameSPTy = Traits::WordType; 778 const Type FrameSPTy = Traits::WordType;
759 Str << "(%" << getRegName(BaseRegNum, FrameSPTy) << ")"; 779 Str << "(%" << getRegName(BaseRegNum, FrameSPTy) << ")";
760 } 780 }
761 781
762 template <class Machine> 782 template <class Machine>
763 typename TargetX86Base<Machine>::Traits::Address 783 typename TargetX86Base<Machine>::Traits::Address
764 TargetX86Base<Machine>::stackVarToAsmOperand(const Variable *Var) const { 784 TargetX86Base<Machine>::stackVarToAsmOperand(const Variable *Var) const {
765 if (Var->hasReg()) 785 if (Var->hasReg())
766 llvm_unreachable("Stack Variable has a register assigned"); 786 llvm_unreachable("Stack Variable has a register assigned");
767 if (Var->mustHaveReg()) { 787 if (Var->mustHaveReg()) {
(...skipping 4688 matching lines...) Expand 10 before | Expand all | Expand 10 after
5456 } 5476 }
5457 // the offset is not eligible for blinding or pooling, return the original 5477 // the offset is not eligible for blinding or pooling, return the original
5458 // mem operand 5478 // mem operand
5459 return MemOperand; 5479 return MemOperand;
5460 } 5480 }
5461 5481
5462 } // end of namespace X86Internal 5482 } // end of namespace X86Internal
5463 } // end of namespace Ice 5483 } // end of namespace Ice
5464 5484
5465 #endif // SUBZERO_SRC_ICETARGETLOWERINGX86BASEIMPL_H 5485 #endif // SUBZERO_SRC_ICETARGETLOWERINGX86BASEIMPL_H
OLDNEW
« no previous file with comments | « src/IceOperand.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698