diff options
| author | Tobias Grosser <tobias@grosser.es> | 2015-08-17 10:58:03 +0000 |
|---|---|---|
| committer | Tobias Grosser <tobias@grosser.es> | 2015-08-17 10:58:03 +0000 |
| commit | 58fdd88751776912e2a2e64901717c482b8a2209 (patch) | |
| tree | 9d81f2e45f978a8d15640198e514817853e915ba | |
| parent | c5bcf246d134c4af9bd738c3629ce12504bd6db8 (diff) | |
| download | bcm5719-llvm-58fdd88751776912e2a2e64901717c482b8a2209.tar.gz bcm5719-llvm-58fdd88751776912e2a2e64901717c482b8a2209.zip | |
Revert "Disable targetdatalayoutcheck"
I committed by accident a local hack that should not have made it upstream.
Sorry for the noise.
llvm-svn: 245212
| -rw-r--r-- | llvm/include/llvm/Target/TargetMachine.h | 9 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/MachineFunction.cpp | 5 |
2 files changed, 14 insertions, 0 deletions
diff --git a/llvm/include/llvm/Target/TargetMachine.h b/llvm/include/llvm/Target/TargetMachine.h index bc8537c0daa..d707e7c0293 100644 --- a/llvm/include/llvm/Target/TargetMachine.h +++ b/llvm/include/llvm/Target/TargetMachine.h @@ -133,6 +133,15 @@ public: /// Create a DataLayout. const DataLayout createDataLayout() const { return DL; } + /// Test if a DataLayout if compatible with the CodeGen for this target. + /// + /// The LLVM Module owns a DataLayout that is used for the target independent + /// optimizations and code generation. This hook provides a target specific + /// check on the validity of this DataLayout. + bool isCompatibleDataLayout(const DataLayout &Candidate) const { + return DL == Candidate; + } + /// Get the pointer size for this target. /// /// This is the only time the DataLayout in the TargetMachine is used. diff --git a/llvm/lib/CodeGen/MachineFunction.cpp b/llvm/lib/CodeGen/MachineFunction.cpp index 5a797f84843..cf9213b84c4 100644 --- a/llvm/lib/CodeGen/MachineFunction.cpp +++ b/llvm/lib/CodeGen/MachineFunction.cpp @@ -87,6 +87,11 @@ MachineFunction::MachineFunction(const Function *F, const TargetMachine &TM, FunctionNumber = FunctionNum; JumpTableInfo = nullptr; + + assert(TM.isCompatibleDataLayout(getDataLayout()) && + "Can't create a MachineFunction using a Module with a " + "Target-incompatible DataLayout attached\n"); + PSVManager = llvm::make_unique<PseudoSourceValueManager>(); } |

