diff options
author | Chris Lattner <sabre@nondot.org> | 2008-08-17 07:19:36 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-08-17 07:19:36 +0000 |
commit | fad86b003a839cef40ec8ce8408322f4913368ca (patch) | |
tree | 4049a1355d17df35e86a6806d300f0c894bb3fd9 /lib/CodeGen/AsmPrinter.cpp | |
parent | b6c8a4098fd23c21d6cda33b09b99b5a0ac1e13f (diff) |
Rework the routines that convert AP[S]Int into a string. Now, instead of
returning an std::string by value, it fills in a SmallString/SmallVector
passed in. This significantly reduces string thrashing in some cases.
More specifically, this:
- Adds an operator<< and a print method for APInt that allows you to
directly send them to an ostream.
- Reimplements APInt::toString to be much simpler and more efficient
algorithmically in addition to not thrashing strings quite as much.
This speeds up llvm-dis on kc++ by 7%, and may also slightly speed up the
asmprinter. This also fixes a bug I introduced into the asmwriter in a
previous patch w.r.t. alias printing.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@54873 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/AsmPrinter.cpp')
-rw-r--r-- | lib/CodeGen/AsmPrinter.cpp | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/lib/CodeGen/AsmPrinter.cpp b/lib/CodeGen/AsmPrinter.cpp index 16f26c4299..1bc4868a60 100644 --- a/lib/CodeGen/AsmPrinter.cpp +++ b/lib/CodeGen/AsmPrinter.cpp @@ -31,6 +31,7 @@ #include "llvm/Target/TargetOptions.h" #include "llvm/Target/TargetRegisterInfo.h" #include "llvm/ADT/SmallPtrSet.h" +#include "llvm/ADT/SmallString.h" #include <cerrno> using namespace llvm; @@ -800,7 +801,10 @@ void AsmPrinter::EmitConstantValueOnly(const Constant *CV) { O << "(("; EmitConstantValueOnly(Op); APInt ptrMask = APInt::getAllOnesValue(TD->getABITypeSizeInBits(Ty)); - O << ") & " << ptrMask.toStringUnsigned() << ')'; + + SmallString<40> S; + ptrMask.toStringUnsigned(S); + O << ") & " << S.c_str() << ')'; break; } case Instruction::Add: @@ -1058,15 +1062,14 @@ void AsmPrinter::EmitGlobalConstant(const Constant *CV) { printDataDirective(type); EmitConstantValueOnly(CV); if (const ConstantInt *CI = dyn_cast<ConstantInt>(CV)) { - O << "\t\t\t" - << TAI->getCommentString() - << " 0x" << CI->getValue().toStringUnsigned(16); + SmallString<40> S; + CI->getValue().toStringUnsigned(S, 16); + O << "\t\t\t" << TAI->getCommentString() << " 0x" << S.c_str(); } O << '\n'; } -void -AsmPrinter::EmitMachineConstantPoolValue(MachineConstantPoolValue *MCPV) { +void AsmPrinter::EmitMachineConstantPoolValue(MachineConstantPoolValue *MCPV) { // Target doesn't support this yet! abort(); } |