mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 02:33:33 +00:00
Move getPreferredAlignmentLog from AsmPrinter to TargetData
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31171 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
0e5e3aacbe
commit
f9c197e022
@ -95,11 +95,6 @@ namespace llvm {
|
||||
///
|
||||
void SwitchToDataSection(const char *NewSection, const GlobalValue *GV);
|
||||
|
||||
/// getPreferredAlignmentLog - Return the preferred alignment of the
|
||||
/// specified global, returned in log form. This includes an explicitly
|
||||
/// requested alignment (if the global has one).
|
||||
unsigned getPreferredAlignmentLog(const GlobalVariable *GV) const;
|
||||
|
||||
/// getGlobalLinkName - Returns the asm/link name of of the specified
|
||||
/// global variable. Should be overridden by each target asm printer to
|
||||
/// generate the appropriate value.
|
||||
|
@ -31,6 +31,7 @@ class Value;
|
||||
class Type;
|
||||
class StructType;
|
||||
class StructLayout;
|
||||
class GlobalVariable;
|
||||
|
||||
class TargetData : public ImmutablePass {
|
||||
bool LittleEndian; // Defaults to false
|
||||
@ -142,6 +143,11 @@ public:
|
||||
/// removed, this method must be called whenever a StructType is removed to
|
||||
/// avoid a dangling pointer in this cache.
|
||||
void InvalidateStructLayoutInfo(const StructType *Ty) const;
|
||||
|
||||
/// getPreferredAlignmentLog - Return the preferred alignment of the
|
||||
/// specified global, returned in log form. This includes an explicitly
|
||||
/// requested alignment (if the global has one).
|
||||
virtual unsigned getPreferredAlignmentLog(const GlobalVariable *GV) const;
|
||||
};
|
||||
|
||||
/// StructLayout - used to lazily calculate structure layout information for a
|
||||
|
@ -326,29 +326,6 @@ void AsmPrinter::EmitXXStructorList(Constant *List) {
|
||||
}
|
||||
}
|
||||
|
||||
/// getPreferredAlignmentLog - Return the preferred alignment of the
|
||||
/// specified global, returned in log form. This includes an explicitly
|
||||
/// requested alignment (if the global has one).
|
||||
unsigned AsmPrinter::getPreferredAlignmentLog(const GlobalVariable *GV) const {
|
||||
const Type *ElemType = GV->getType()->getElementType();
|
||||
unsigned Alignment = TM.getTargetData()->getTypeAlignmentShift(ElemType);
|
||||
if (GV->getAlignment() > (1U << Alignment))
|
||||
Alignment = Log2_32(GV->getAlignment());
|
||||
|
||||
if (GV->hasInitializer()) {
|
||||
// Always round up alignment of global doubles to 8 bytes.
|
||||
if (GV->getType()->getElementType() == Type::DoubleTy && Alignment < 3)
|
||||
Alignment = 3;
|
||||
if (Alignment < 4) {
|
||||
// If the global is not external, see if it is large. If so, give it a
|
||||
// larger alignment.
|
||||
if (TM.getTargetData()->getTypeSize(ElemType) > 128)
|
||||
Alignment = 4; // 16-byte alignment.
|
||||
}
|
||||
}
|
||||
return Alignment;
|
||||
}
|
||||
|
||||
/// getGlobalLinkName - Returns the asm/link name of of the specified
|
||||
/// global variable. Should be overridden by each target asm printer to
|
||||
/// generate the appropriate value.
|
||||
|
@ -232,7 +232,7 @@ bool AlphaAsmPrinter::doFinalization(Module &M) {
|
||||
Constant *C = I->getInitializer();
|
||||
unsigned Size = TD->getTypeSize(C->getType());
|
||||
// unsigned Align = TD->getTypeAlignmentShift(C->getType());
|
||||
unsigned Align = getPreferredAlignmentLog(I);
|
||||
unsigned Align = TD->getPreferredAlignmentLog(I);
|
||||
|
||||
if (C->isNullValue() &&
|
||||
(I->hasLinkOnceLinkage() || I->hasInternalLinkage() ||
|
||||
|
@ -513,7 +513,7 @@ bool DarwinAsmPrinter::doFinalization(Module &M) {
|
||||
std::string name = Mang->getValueName(I);
|
||||
Constant *C = I->getInitializer();
|
||||
unsigned Size = TD->getTypeSize(C->getType());
|
||||
unsigned Align = getPreferredAlignmentLog(I);
|
||||
unsigned Align = TD->getPreferredAlignmentLog(I);
|
||||
|
||||
if (C->isNullValue() && /* FIXME: Verify correct */
|
||||
(I->hasInternalLinkage() || I->hasWeakLinkage() ||
|
||||
|
@ -354,3 +354,26 @@ uint64_t TargetData::getIndexedOffset(const Type *ptrTy,
|
||||
return Result;
|
||||
}
|
||||
|
||||
/// getPreferredAlignmentLog - Return the preferred alignment of the
|
||||
/// specified global, returned in log form. This includes an explicitly
|
||||
/// requested alignment (if the global has one).
|
||||
unsigned TargetData::getPreferredAlignmentLog(const GlobalVariable *GV) const {
|
||||
const Type *ElemType = GV->getType()->getElementType();
|
||||
unsigned Alignment = getTypeAlignmentShift(ElemType);
|
||||
if (GV->getAlignment() > (1U << Alignment))
|
||||
Alignment = Log2_32(GV->getAlignment());
|
||||
|
||||
if (GV->hasInitializer()) {
|
||||
// Always round up alignment of global doubles to 8 bytes.
|
||||
if (GV->getType()->getElementType() == Type::DoubleTy && Alignment < 3)
|
||||
Alignment = 3;
|
||||
if (Alignment < 4) {
|
||||
// If the global is not external, see if it is large. If so, give it a
|
||||
// larger alignment.
|
||||
if (getTypeSize(ElemType) > 128)
|
||||
Alignment = 4; // 16-byte alignment.
|
||||
}
|
||||
}
|
||||
return Alignment;
|
||||
}
|
||||
|
||||
|
@ -139,7 +139,7 @@ bool X86SharedAsmPrinter::doFinalization(Module &M) {
|
||||
std::string name = Mang->getValueName(I);
|
||||
Constant *C = I->getInitializer();
|
||||
unsigned Size = TD->getTypeSize(C->getType());
|
||||
unsigned Align = getPreferredAlignmentLog(I);
|
||||
unsigned Align = TD->getPreferredAlignmentLog(I);
|
||||
|
||||
if (C->isNullValue() && /* FIXME: Verify correct */
|
||||
(I->hasInternalLinkage() || I->hasWeakLinkage() ||
|
||||
|
@ -387,7 +387,7 @@ bool X86IntelAsmPrinter::doFinalization(Module &M) {
|
||||
std::string name = Mang->getValueName(I);
|
||||
Constant *C = I->getInitializer();
|
||||
unsigned Size = TD->getTypeSize(C->getType());
|
||||
unsigned Align = getPreferredAlignmentLog(I);
|
||||
unsigned Align = TD->getPreferredAlignmentLog(I);
|
||||
bool bCustomSegment = false;
|
||||
|
||||
switch (I->getLinkage()) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user