diff options
author | Chris Lattner <sabre@nondot.org> | 2006-10-13 17:50:07 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2006-10-13 17:50:07 +0000 |
commit | 4c7b07a66f3d5c14339a6181fa12d060aeb9b18c (patch) | |
tree | 96b7a30dbf78a771a6fb5f333a391d3f0bce08c8 | |
parent | 7445ea6b177abcf7da1daa4abe5cbbb014fbb932 (diff) |
Expose method and ivars for measuring inline asm length properly.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30934 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/Target/TargetAsmInfo.h | 15 | ||||
-rw-r--r-- | lib/Target/TargetAsmInfo.cpp | 20 |
2 files changed, 31 insertions, 4 deletions
diff --git a/include/llvm/Target/TargetAsmInfo.h b/include/llvm/Target/TargetAsmInfo.h index 930ad902c1..d9ddf06a4f 100644 --- a/include/llvm/Target/TargetAsmInfo.h +++ b/include/llvm/Target/TargetAsmInfo.h @@ -27,7 +27,6 @@ namespace llvm { /// TargetAsmInfo - This class is intended to be used as a base class for asm /// properties and features specific to the target. class TargetAsmInfo { - protected: //===------------------------------------------------------------------===// // Properties to be set by the target writer, used to configure asm printer. @@ -48,6 +47,15 @@ namespace llvm { /// NeedsSet - True if target asm can't compute addresses on data /// directives. bool NeedsSet; // Defaults to false. + + /// MaxInstLength - This is the maximum possible length of an instruction, + /// which is needed to compute the size of an inline asm. + unsigned MaxInstLength; // Defaults to 4. + + /// SeparatorChar - This character, if specified, is used to separate + /// instructions from each other when on the same line. This is used to + /// measure inline asm instructions. + char SeparatorChar; // Defaults to ';' /// CommentString - This indicates the comment character used by the /// assembler. @@ -261,6 +269,10 @@ namespace llvm { TargetAsmInfo(); virtual ~TargetAsmInfo(); + /// Measure the specified inline asm to determine an approximation of its + /// length. + unsigned getInlineAsmLength(const char *Str) const; + // // Accessors. // @@ -430,7 +442,6 @@ namespace llvm { return DwarfMacInfoSection; } }; - } #endif diff --git a/lib/Target/TargetAsmInfo.cpp b/lib/Target/TargetAsmInfo.cpp index 79c064c371..7d463ce572 100644 --- a/lib/Target/TargetAsmInfo.cpp +++ b/lib/Target/TargetAsmInfo.cpp @@ -21,6 +21,8 @@ TargetAsmInfo::TargetAsmInfo() : DataSection(".data"), AddressSize(4), NeedsSet(false), + MaxInstLength(4), + SeparatorChar(';'), CommentString("#"), GlobalPrefix(""), PrivateGlobalPrefix("."), @@ -71,8 +73,22 @@ TargetAsmInfo::TargetAsmInfo() : DwarfLocSection(".debug_loc"), DwarfARangesSection(".debug_aranges"), DwarfRangesSection(".debug_ranges"), - DwarfMacInfoSection(".debug_macinfo") -{} + DwarfMacInfoSection(".debug_macinfo") { +} TargetAsmInfo::~TargetAsmInfo() { } + +/// Measure the specified inline asm to determine an approximation of its +/// length. +unsigned TargetAsmInfo::getInlineAsmLength(const char *Str) const { + // Count the number of instructions in the asm. + unsigned NumInsts = 0; + for (; *Str; ++Str) { + if (*Str == '\n' || *Str == SeparatorChar) + ++NumInsts; + } + + // Multiply by the worst-case length for each instruction. + return NumInsts * MaxInstLength; +} |