mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-25 21:16:19 +00:00
Alignment of globals has not been quite right. Needed to drop the pointer type
to get the alignment of the element type. llvm-svn: 28799
This commit is contained in:
parent
cc433bd065
commit
61655f779a
@ -244,18 +244,16 @@ void AsmPrinter::EmitXXStructorList(Constant *List) {
|
||||
/// 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());
|
||||
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(GV->getType()->getElementType()) > 128)
|
||||
if (TM.getTargetData()->getTypeSize(ElemType) > 128)
|
||||
Alignment = 4; // 16-byte alignment.
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user