ia64 asmprinter fixes:

- turn off assembler's autoalignment
  - set FunctionAddrPrefix/Suffix so that .data8 entries pointing to
    functions have their value wrapped in @fptr(), so that a function
    descriptor will be materialized for that function.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@21025 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Duraid Madina 2005-04-02 12:30:47 +00:00
parent 855a519741
commit 32c46f33b7

View File

@ -142,9 +142,8 @@ bool IA64SharedAsmPrinter::doFinalization(Module &M) {
// FALL THROUGH // FALL THROUGH
case GlobalValue::InternalLinkage: case GlobalValue::InternalLinkage:
if (C->isNullValue()) if (C->isNullValue())
SwitchSection(O, CurSection, ".data"); // FIXME: this was SwitchSection(O, CurSection, ".bss");
// '.bss', but in ia64-land .bss means "nobits" (i.e. uninitialized) // FIXME? in ia64-land .bss means "nobits" (i.e. uninitialized)
// hmm.
else else
SwitchSection(O, CurSection, ".data"); SwitchSection(O, CurSection, ".data");
break; break;
@ -191,13 +190,18 @@ namespace {
: IA64SharedAsmPrinter(O, TM) { : IA64SharedAsmPrinter(O, TM) {
CommentString = "//"; CommentString = "//";
Data8bitsDirective = "\tdata1\t"; Data8bitsDirective = "\tdata1\t"; // FIXME: check that we are
Data16bitsDirective = "\tdata2\t"; Data16bitsDirective = "\tdata2.ua\t"; // disabling auto-alignment
Data32bitsDirective = "\tdata4\t"; Data32bitsDirective = "\tdata4.ua\t"; // properly
Data64bitsDirective = "\tdata8\t"; Data64bitsDirective = "\tdata8.ua\t";
ZeroDirective = "\t.skip\t"; ZeroDirective = "\t.skip\t";
AsciiDirective = "\tstring\t"; AsciiDirective = "\tstring\t";
GlobalVarAddrPrefix="";
GlobalVarAddrSuffix="";
FunctionAddrPrefix="@fptr(";
FunctionAddrSuffix=")";
} }
virtual const char *getPassName() const { virtual const char *getPassName() const {