summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms/IPO/CrossDSOCFI.cpp
diff options
context:
space:
mode:
authorEvgeniy Stepanov <eugeni.stepanov@gmail.com>2017-08-29 22:29:15 +0000
committerEvgeniy Stepanov <eugeni.stepanov@gmail.com>2017-08-29 22:29:15 +0000
commit4731ad81c77dc202309010a607d7728d0b47efa4 (patch)
tree057156bf14c38972b5374ca31e101befbbd6412b /llvm/lib/Transforms/IPO/CrossDSOCFI.cpp
parent2297fc89b4c0403350fcdf06c22f752e7958217f (diff)
downloadbcm5719-llvm-4731ad81c77dc202309010a607d7728d0b47efa4.tar.gz
bcm5719-llvm-4731ad81c77dc202309010a607d7728d0b47efa4.zip
[cfi] Build __cfi_check as Thumb when applicable.
Summary: Cross-DSO CFI needs all __cfi_check exports to use the same encoding (ARM vs Thumb). Reviewers: pcc Subscribers: aemerson, srhines, kristof.beyls, hiraditya, llvm-commits Differential Revision: https://reviews.llvm.org/D37243 llvm-svn: 312052
Diffstat (limited to 'llvm/lib/Transforms/IPO/CrossDSOCFI.cpp')
-rw-r--r--llvm/lib/Transforms/IPO/CrossDSOCFI.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/IPO/CrossDSOCFI.cpp b/llvm/lib/Transforms/IPO/CrossDSOCFI.cpp
index d94aa5da856..0098b60cb6a 100644
--- a/llvm/lib/Transforms/IPO/CrossDSOCFI.cpp
+++ b/llvm/lib/Transforms/IPO/CrossDSOCFI.cpp
@@ -16,6 +16,7 @@
#include "llvm/ADT/DenseSet.h"
#include "llvm/ADT/EquivalenceClasses.h"
#include "llvm/ADT/Statistic.h"
+#include "llvm/ADT/Triple.h"
#include "llvm/IR/Constant.h"
#include "llvm/IR/Constants.h"
#include "llvm/IR/Function.h"
@@ -115,6 +116,11 @@ void CrossDSOCFI::buildCFICheck(Module &M) {
// linker knows about the symbol; this pass replaces the function body.
F->deleteBody();
F->setAlignment(4096);
+
+ Triple T(M.getTargetTriple());
+ if (T.isARM() || T.isThumb())
+ F->addFnAttr("target-features", "+thumb-mode");
+
auto args = F->arg_begin();
Value &CallSiteTypeId = *(args++);
CallSiteTypeId.setName("CallSiteTypeId");
OpenPOWER on IntegriCloud