[PATCH] D58071: Fix auto-upgrade for the new parameter to llvm.objectsize
Erik Pilkington via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Feb 11 16:39:42 PST 2019
erik.pilkington updated this revision to Diff 186365.
erik.pilkington added a comment.
Use a `.bc` file in the test. @steven_wu, LG?
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D58071/new/
https://reviews.llvm.org/D58071
Files:
llvm/lib/IR/AutoUpgrade.cpp
llvm/test/Bitcode/objectsize-upgrade-7.0.ll
llvm/test/Bitcode/objectsize-upgrade-7.0.ll.bc
Index: llvm/test/Bitcode/objectsize-upgrade-7.0.ll
===================================================================
--- /dev/null
+++ llvm/test/Bitcode/objectsize-upgrade-7.0.ll
@@ -0,0 +1,12 @@
+; RUN: llvm-dis < %s.bc | FileCheck %s
+
+; Bitcode compatibility test for 'dynamic' parameter to llvm.objectsize.
+
+define void @callit(i8* %ptr) {
+ %sz = call i64 @llvm.objectsize.i64.p0i8(i8* %ptr, i1 false, i1 true)
+ ; CHECK: %sz = call i64 @llvm.objectsize.i64.p0i8(i8* %ptr, i1 false, i1 true, i1 false)
+ ret void
+}
+
+declare i64 @llvm.objectsize.i64.p0i8(i8*, i1, i1)
+; CHECK: declare i64 @llvm.objectsize.i64.p0i8(i8*, i1, i1, i1)
Index: llvm/lib/IR/AutoUpgrade.cpp
===================================================================
--- llvm/lib/IR/AutoUpgrade.cpp
+++ llvm/lib/IR/AutoUpgrade.cpp
@@ -743,7 +743,7 @@
// address space.
if (Name.startswith("objectsize.")) {
Type *Tys[2] = { F->getReturnType(), F->arg_begin()->getType() };
- if (F->arg_size() == 2 ||
+ if (F->arg_size() == 2 || F->arg_size() == 3 ||
F->getName() != Intrinsic::getName(Intrinsic::objectsize, Tys)) {
rename(F);
NewFn = Intrinsic::getDeclaration(F->getParent(), Intrinsic::objectsize,
@@ -3461,7 +3461,7 @@
? Builder.getFalse()
: CI->getArgOperand(2);
Value *Dynamic =
- CI->getNumArgOperands() < 3 ? Builder.getFalse() : CI->getArgOperand(3);
+ CI->getNumArgOperands() < 4 ? Builder.getFalse() : CI->getArgOperand(3);
NewCall = Builder.CreateCall(
NewFn, {CI->getArgOperand(0), CI->getArgOperand(1), NullIsUnknownSize, Dynamic});
break;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D58071.186365.patch
Type: text/x-patch
Size: 1704 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190212/676a0b76/attachment.bin>
More information about the llvm-commits
mailing list