diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2014-02-26 17:02:08 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2014-02-26 17:02:08 +0000 |
commit | ae593f1563e615ded29b4f3d7ec0635492bc2db1 (patch) | |
tree | ee7ec61520c910f741741abcf83fd2c2b72ead7c /llvm/lib | |
parent | 667fcb839eefb2f12ea1d7216189759f0bddd33e (diff) | |
download | llvm-ae593f1563e615ded29b4f3d7ec0635492bc2db1.zip llvm-ae593f1563e615ded29b4f3d7ec0635492bc2db1.tar.gz llvm-ae593f1563e615ded29b4f3d7ec0635492bc2db1.tar.bz2 |
Compare DataLayout by Value, not by pointer.
This fixes spurious warnings in llvm-link about the datalayout not matching.
Thanks to Zalman Stern for reporting the bug!
llvm-svn: 202276
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/IR/DataLayout.cpp | 10 | ||||
-rw-r--r-- | llvm/lib/Linker/LinkModules.cpp | 2 |
2 files changed, 11 insertions, 1 deletions
diff --git a/llvm/lib/IR/DataLayout.cpp b/llvm/lib/IR/DataLayout.cpp index 7089b7b..162f3d3 100644 --- a/llvm/lib/IR/DataLayout.cpp +++ b/llvm/lib/IR/DataLayout.cpp @@ -354,6 +354,16 @@ DataLayout::DataLayout(const Module *M) : LayoutMap(0) { reset(""); } +bool DataLayout::operator==(const DataLayout &Other) const { + bool Ret = LittleEndian == Other.LittleEndian && + StackNaturalAlign == Other.StackNaturalAlign && + ManglingMode == Other.ManglingMode && + LegalIntWidths == Other.LegalIntWidths && + Alignments == Other.Alignments && Pointers == Pointers; + assert(Ret == (getStringRepresentation() == Other.getStringRepresentation())); + return Ret; +} + void DataLayout::setAlignment(AlignTypeEnum align_type, unsigned abi_align, unsigned pref_align, uint32_t bit_width) { diff --git a/llvm/lib/Linker/LinkModules.cpp b/llvm/lib/Linker/LinkModules.cpp index f1b8cb7..9160e26 100644 --- a/llvm/lib/Linker/LinkModules.cpp +++ b/llvm/lib/Linker/LinkModules.cpp @@ -1208,7 +1208,7 @@ bool ModuleLinker::run() { DstM->setTargetTriple(SrcM->getTargetTriple()); if (SrcM->getDataLayout() && DstM->getDataLayout() && - SrcM->getDataLayout() != DstM->getDataLayout()) { + *SrcM->getDataLayout() != *DstM->getDataLayout()) { if (!SuppressWarnings) { errs() << "WARNING: Linking two modules of different data layouts!\n"; } |