Expose method and ivars for measuring inline asm length properly.

llvm-svn: 30934
This commit is contained in:
Chris Lattner 2006-10-13 17:50:07 +00:00
parent 966645e6b4
commit 95129a7f22
2 changed files with 31 additions and 4 deletions

View File

@ -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

View File

@ -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;
}