mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-05 12:31:33 +00:00
Implement the AsmPrinter::getPreferredAlignmentLog method.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25978 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
28adf292d9
commit
4d57e0cd69
@ -171,6 +171,22 @@ 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 {
|
||||||
|
unsigned Alignment = TM.getTargetData().getTypeAlignmentShift(GV->getType());
|
||||||
|
if (GV->getAlignment() > (1U << Alignment))
|
||||||
|
Alignment = Log2_32(GV->getAlignment());
|
||||||
|
|
||||||
|
if (GV->hasInitializer() && Alignment < 4) {
|
||||||
|
// If the global is not external, see if it is large. If so, give it a
|
||||||
|
// larger alignment.
|
||||||
|
if (TM.getTargetData().getTypeSize(GV->getType()->getElementType()) > 128)
|
||||||
|
Alignment = 4; // 16-byte alignment.
|
||||||
|
}
|
||||||
|
return Alignment;
|
||||||
|
}
|
||||||
|
|
||||||
// EmitAlignment - Emit an alignment directive to the specified power of two.
|
// EmitAlignment - Emit an alignment directive to the specified power of two.
|
||||||
void AsmPrinter::EmitAlignment(unsigned NumBits, const GlobalValue *GV) const {
|
void AsmPrinter::EmitAlignment(unsigned NumBits, const GlobalValue *GV) const {
|
||||||
|
Loading…
Reference in New Issue
Block a user