forked from OSchip/llvm-project
Clean up some ARM GV asm printing out; minor fixes to match what gcc does.
llvm-svn: 60621
This commit is contained in:
parent
5a3422f602
commit
ab85feb91c
|
@ -56,6 +56,7 @@ ARMDarwinTargetAsmInfo::ARMDarwinTargetAsmInfo(const ARMTargetMachine &TM):
|
||||||
ZeroFillDirective = "\t.zerofill\t"; // Uses .zerofill
|
ZeroFillDirective = "\t.zerofill\t"; // Uses .zerofill
|
||||||
SetDirective = "\t.set\t";
|
SetDirective = "\t.set\t";
|
||||||
WeakRefDirective = "\t.weak_reference\t";
|
WeakRefDirective = "\t.weak_reference\t";
|
||||||
|
WeakDefDirective = "\t.weak_definition ";
|
||||||
HiddenDirective = "\t.private_extern\t";
|
HiddenDirective = "\t.private_extern\t";
|
||||||
ProtectedDirective = NULL;
|
ProtectedDirective = NULL;
|
||||||
JumpTableDataSection = ".const";
|
JumpTableDataSection = ".const";
|
||||||
|
|
|
@ -29,7 +29,6 @@
|
||||||
#include "llvm/Target/TargetData.h"
|
#include "llvm/Target/TargetData.h"
|
||||||
#include "llvm/Target/TargetMachine.h"
|
#include "llvm/Target/TargetMachine.h"
|
||||||
#include "llvm/Target/TargetOptions.h"
|
#include "llvm/Target/TargetOptions.h"
|
||||||
#include "llvm/ADT/SmallPtrSet.h"
|
|
||||||
#include "llvm/ADT/Statistic.h"
|
#include "llvm/ADT/Statistic.h"
|
||||||
#include "llvm/ADT/StringExtras.h"
|
#include "llvm/ADT/StringExtras.h"
|
||||||
#include "llvm/ADT/StringSet.h"
|
#include "llvm/ADT/StringSet.h"
|
||||||
|
@ -84,10 +83,6 @@ namespace {
|
||||||
/// asm printer should generate stubs for.
|
/// asm printer should generate stubs for.
|
||||||
StringSet<> FnStubs;
|
StringSet<> FnStubs;
|
||||||
|
|
||||||
/// PCRelGVs - Keeps the set of GlobalValues used in pc relative
|
|
||||||
/// constantpool.
|
|
||||||
SmallPtrSet<const GlobalValue*, 8> PCRelGVs;
|
|
||||||
|
|
||||||
/// True if asm printer is printing a series of CONSTPOOL_ENTRY.
|
/// True if asm printer is printing a series of CONSTPOOL_ENTRY.
|
||||||
bool InCPMode;
|
bool InCPMode;
|
||||||
|
|
||||||
|
@ -677,12 +672,6 @@ void ARMAsmPrinter::printCPInstOperand(const MachineInstr *MI, int OpNo,
|
||||||
|
|
||||||
if (MCPE.isMachineConstantPoolEntry()) {
|
if (MCPE.isMachineConstantPoolEntry()) {
|
||||||
EmitMachineConstantPoolValue(MCPE.Val.MachineCPVal);
|
EmitMachineConstantPoolValue(MCPE.Val.MachineCPVal);
|
||||||
ARMConstantPoolValue *ACPV =
|
|
||||||
static_cast<ARMConstantPoolValue*>(MCPE.Val.MachineCPVal);
|
|
||||||
if (ACPV->getPCAdjustment() != 0) {
|
|
||||||
const GlobalValue *GV = ACPV->getGV();
|
|
||||||
PCRelGVs.insert(GV);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
EmitGlobalConstant(MCPE.Val.ConstVal);
|
EmitGlobalConstant(MCPE.Val.ConstVal);
|
||||||
// remember to emit the weak reference
|
// remember to emit the weak reference
|
||||||
|
@ -841,18 +830,18 @@ void ARMAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
|
||||||
const Type *Type = C->getType();
|
const Type *Type = C->getType();
|
||||||
unsigned Size = TD->getABITypeSize(Type);
|
unsigned Size = TD->getABITypeSize(Type);
|
||||||
unsigned Align = TD->getPreferredAlignmentLog(GVar);
|
unsigned Align = TD->getPreferredAlignmentLog(GVar);
|
||||||
|
bool isDarwin = Subtarget->isTargetDarwin();
|
||||||
|
|
||||||
printVisibility(name, GVar->getVisibility());
|
printVisibility(name, GVar->getVisibility());
|
||||||
|
|
||||||
if (Subtarget->isTargetELF())
|
if (Subtarget->isTargetELF())
|
||||||
O << "\t.type " << name << ",%object\n";
|
O << "\t.type " << name << ",%object\n";
|
||||||
|
|
||||||
SwitchToSection(TAI->SectionForGlobal(GVar));
|
|
||||||
|
|
||||||
if (C->isNullValue() && !GVar->hasSection() && !GVar->isThreadLocal()) {
|
if (C->isNullValue() && !GVar->hasSection() && !GVar->isThreadLocal()) {
|
||||||
// FIXME: This seems to be pretty darwin-specific
|
// FIXME: This seems to be pretty darwin-specific
|
||||||
|
|
||||||
if (GVar->hasExternalLinkage()) {
|
if (GVar->hasExternalLinkage()) {
|
||||||
|
SwitchToSection(TAI->SectionForGlobal(GVar));
|
||||||
if (const char *Directive = TAI->getZeroFillDirective()) {
|
if (const char *Directive = TAI->getZeroFillDirective()) {
|
||||||
O << "\t.globl\t" << name << "\n";
|
O << "\t.globl\t" << name << "\n";
|
||||||
O << Directive << "__DATA, __common, " << name << ", "
|
O << Directive << "__DATA, __common, " << name << ", "
|
||||||
|
@ -864,14 +853,34 @@ void ARMAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
|
||||||
if (GVar->hasInternalLinkage() || GVar->mayBeOverridden()) {
|
if (GVar->hasInternalLinkage() || GVar->mayBeOverridden()) {
|
||||||
if (Size == 0) Size = 1; // .comm Foo, 0 is undefined, avoid it.
|
if (Size == 0) Size = 1; // .comm Foo, 0 is undefined, avoid it.
|
||||||
|
|
||||||
if (TAI->getLCOMMDirective() != NULL) {
|
if (isDarwin) {
|
||||||
if (PCRelGVs.count(GVar) || GVar->hasInternalLinkage()) {
|
if (GVar->hasInternalLinkage()) {
|
||||||
O << TAI->getLCOMMDirective() << name << "," << Size;
|
O << TAI->getLCOMMDirective() << name << "," << Size
|
||||||
if (Subtarget->isTargetDarwin())
|
<< ',' << Align;
|
||||||
O << "," << Align;
|
} else if (GVar->hasCommonLinkage()) {
|
||||||
} else
|
O << TAI->getCOMMDirective() << name << "," << Size
|
||||||
O << TAI->getCOMMDirective() << name << "," << Size;
|
<< ',' << Align;
|
||||||
} else {
|
} else {
|
||||||
|
SwitchToSection(TAI->SectionForGlobal(GVar));
|
||||||
|
O << "\t.globl " << name << '\n'
|
||||||
|
<< TAI->getWeakDefDirective() << name << '\n';
|
||||||
|
EmitAlignment(Align, GVar);
|
||||||
|
O << name << ":\t\t\t\t" << TAI->getCommentString() << ' ';
|
||||||
|
PrintUnmangledNameSafely(GVar, O);
|
||||||
|
O << '\n';
|
||||||
|
EmitGlobalConstant(C);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else if (TAI->getLCOMMDirective() != NULL) {
|
||||||
|
if (GVar->hasInternalLinkage()) {
|
||||||
|
O << TAI->getLCOMMDirective() << name << "," << Size;
|
||||||
|
} else {
|
||||||
|
O << TAI->getCOMMDirective() << name << "," << Size;
|
||||||
|
if (TAI->getCOMMDirectiveTakesAlignment())
|
||||||
|
O << ',' << (TAI->getAlignmentIsInBytes() ? (1 << Align) : Align);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
SwitchToSection(TAI->SectionForGlobal(GVar));
|
||||||
if (GVar->hasInternalLinkage())
|
if (GVar->hasInternalLinkage())
|
||||||
O << "\t.local\t" << name << "\n";
|
O << "\t.local\t" << name << "\n";
|
||||||
O << TAI->getCOMMDirective() << name << "," << Size;
|
O << TAI->getCOMMDirective() << name << "," << Size;
|
||||||
|
@ -885,10 +894,12 @@ void ARMAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SwitchToSection(TAI->SectionForGlobal(GVar));
|
||||||
switch (GVar->getLinkage()) {
|
switch (GVar->getLinkage()) {
|
||||||
|
case GlobalValue::CommonLinkage:
|
||||||
case GlobalValue::LinkOnceLinkage:
|
case GlobalValue::LinkOnceLinkage:
|
||||||
case GlobalValue::WeakLinkage:
|
case GlobalValue::WeakLinkage:
|
||||||
if (Subtarget->isTargetDarwin()) {
|
if (isDarwin) {
|
||||||
O << "\t.globl " << name << "\n"
|
O << "\t.globl " << name << "\n"
|
||||||
<< "\t.weak_definition " << name << "\n";
|
<< "\t.weak_definition " << name << "\n";
|
||||||
} else {
|
} else {
|
||||||
|
@ -980,7 +991,7 @@ bool ARMAsmPrinter::doFinalization(Module &M) {
|
||||||
|
|
||||||
// Output non-lazy-pointers for external and common global variables.
|
// Output non-lazy-pointers for external and common global variables.
|
||||||
if (!GVNonLazyPtrs.empty()) {
|
if (!GVNonLazyPtrs.empty()) {
|
||||||
SwitchToDataSection(".non_lazy_symbol_pointer", 0);
|
SwitchToDataSection("\t.non_lazy_symbol_pointer", 0);
|
||||||
for (StringSet<>::iterator i = GVNonLazyPtrs.begin(),
|
for (StringSet<>::iterator i = GVNonLazyPtrs.begin(),
|
||||||
e = GVNonLazyPtrs.end(); i != e; ++i) {
|
e = GVNonLazyPtrs.end(); i != e; ++i) {
|
||||||
const char *p = i->getKeyData();
|
const char *p = i->getKeyData();
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
; RUN: llvm-as < %s | llc -mtriple=arm-apple-darwin -mattr=+v6 -relocation-model=pic | grep lcomm
|
; RUN: llvm-as < %s | llc -mtriple=arm-apple-darwin -mattr=+v6 -relocation-model=pic | grep comm
|
||||||
|
|
||||||
%struct.FILE = type { i8*, i32, i32, i16, i16, %struct.__sbuf, i32, i8*, i32 (i8*)*, i32 (i8*, i8*, i32)*, i64 (i8*, i64, i32)*, i32 (i8*, i8*, i32)*, %struct.__sbuf, %struct.__sFILEX*, i32, [3 x i8], [1 x i8], %struct.__sbuf, i32, i64 }
|
%struct.FILE = type { i8*, i32, i32, i16, i16, %struct.__sbuf, i32, i8*, i32 (i8*)*, i32 (i8*, i8*, i32)*, i64 (i8*, i64, i32)*, i32 (i8*, i8*, i32)*, %struct.__sbuf, %struct.__sFILEX*, i32, [3 x i8], [1 x i8], %struct.__sbuf, i32, i64 }
|
||||||
%struct.__gcov_var = type { %struct.FILE*, i32, i32, i32, i32, i32, i32, [1025 x i32] }
|
%struct.__gcov_var = type { %struct.FILE*, i32, i32, i32, i32, i32, i32, [1025 x i32] }
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
; RUN: llvm-as < %s | llc -mtriple=arm-apple-darwin | grep ldr | count 2
|
||||||
|
|
||||||
|
@x = weak hidden global i32 0 ; <i32*> [#uses=1]
|
||||||
|
|
||||||
|
define i32 @t() nounwind readonly {
|
||||||
|
entry:
|
||||||
|
%0 = load i32* @x, align 4 ; <i32> [#uses=1]
|
||||||
|
ret i32 %0
|
||||||
|
}
|
|
@ -0,0 +1,14 @@
|
||||||
|
; RUN: llvm-as < %s | llc -mtriple=arm-apple-darwin | grep ldr | count 6
|
||||||
|
; RUN: llvm-as < %s | llc -mtriple=arm-apple-darwin | grep non_lazy_ptr
|
||||||
|
; RUN: llvm-as < %s | llc -mtriple=arm-apple-darwin | grep long | count 4
|
||||||
|
|
||||||
|
@x = external hidden global i32 ; <i32*> [#uses=1]
|
||||||
|
@y = extern_weak hidden global i32 ; <i32*> [#uses=1]
|
||||||
|
|
||||||
|
define i32 @t() nounwind readonly {
|
||||||
|
entry:
|
||||||
|
%0 = load i32* @x, align 4 ; <i32> [#uses=1]
|
||||||
|
%1 = load i32* @y, align 4 ; <i32> [#uses=1]
|
||||||
|
%2 = add i32 %1, %0 ; <i32> [#uses=1]
|
||||||
|
ret i32 %2
|
||||||
|
}
|
|
@ -0,0 +1,18 @@
|
||||||
|
; RUN: llvm-as < %s | llc -mtriple=arm-apple-darwin | \
|
||||||
|
; RUN: grep .private_extern | count 2
|
||||||
|
|
||||||
|
%struct.Person = type { i32 }
|
||||||
|
@a = hidden global i32 0
|
||||||
|
@b = external global i32
|
||||||
|
|
||||||
|
|
||||||
|
define weak hidden void @_ZN6Person13privateMethodEv(%struct.Person* %this) {
|
||||||
|
ret void
|
||||||
|
}
|
||||||
|
|
||||||
|
declare void @function(i32)
|
||||||
|
|
||||||
|
define weak void @_ZN6PersonC1Ei(%struct.Person* %this, i32 %_c) {
|
||||||
|
ret void
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue