diff options
author | Anton Korobeynikov <asl@math.spbu.ru> | 2008-07-09 13:26:05 +0000 |
---|---|---|
committer | Anton Korobeynikov <asl@math.spbu.ru> | 2008-07-09 13:26:05 +0000 |
commit | 9da4fd0f2e6b72e52a65a00a82ac0edd3261437b (patch) | |
tree | 50f4baa47193789853c17219b7d8882a57d02853 | |
parent | 13b9a22fb087c5176168dab92f4a36b6122b8320 (diff) | |
download | bcm5719-llvm-9da4fd0f2e6b72e52a65a00a82ac0edd3261437b.tar.gz bcm5719-llvm-9da4fd0f2e6b72e52a65a00a82ac0edd3261437b.zip |
Drop mergeable flag, if size is no suitable
llvm-svn: 53313
-rw-r--r-- | llvm/lib/Target/X86/X86TargetAsmInfo.cpp | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/llvm/lib/Target/X86/X86TargetAsmInfo.cpp b/llvm/lib/Target/X86/X86TargetAsmInfo.cpp index 7a56ed55e06..304e5a5303e 100644 --- a/llvm/lib/Target/X86/X86TargetAsmInfo.cpp +++ b/llvm/lib/Target/X86/X86TargetAsmInfo.cpp @@ -323,8 +323,11 @@ X86DarwinTargetAsmInfo::SectionFlagsForGlobal(const GlobalValue *GV, Type = C->getType(); unsigned Size = TD->getABITypeSize(Type); - if (Size > 16) + if (Size > 16) { + // Too big for mergeable Size = 0; + Flags &= ~SectionFlags::Mergeable; + } Flags = SectionFlags::setEntitySize(Flags, Size); } @@ -513,8 +516,11 @@ X86ELFTargetAsmInfo::SectionFlagsForGlobal(const GlobalValue *GV, Type = C->getType(); unsigned Size = TD->getABITypeSize(Type); - if (Size > 16) + if (Size > 16) { + // Too big for mergeable Size = 0; + Flags &= ~SectionFlags::Mergeable; + } Flags = SectionFlags::setEntitySize(Flags, Size); } |