diff options
author | Chris Lattner <sabre@nondot.org> | 2008-08-23 05:31:10 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-08-23 05:31:10 +0000 |
commit | 259f88e3c9dc2fe0513897d8a4d3b05adf2eea46 (patch) | |
tree | 33d4ec06430a66dcff5a64d452d53a68cf2ff20e | |
parent | dbf7aa5b4bb2b8bbeaf7c53d03d2ab222feba7c3 (diff) | |
download | llvm-259f88e3c9dc2fe0513897d8a4d3b05adf2eea46.tar.gz llvm-259f88e3c9dc2fe0513897d8a4d3b05adf2eea46.tar.bz2 llvm-259f88e3c9dc2fe0513897d8a4d3b05adf2eea46.tar.xz |
Verify that the alignment argument to llvm.memcpy is a constant
integer, PR2318.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55228 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/VMCore/Verifier.cpp | 10 | ||||
-rw-r--r-- | test/Verifier/2008-08-22-MemCpyAlignment.ll | 11 |
2 files changed, 21 insertions, 0 deletions
diff --git a/lib/VMCore/Verifier.cpp b/lib/VMCore/Verifier.cpp index bede405193..e569011b8f 100644 --- a/lib/VMCore/Verifier.cpp +++ b/lib/VMCore/Verifier.cpp @@ -1273,6 +1273,16 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) { switch (ID) { default: break; + case Intrinsic::memcpy_i32: + case Intrinsic::memcpy_i64: + case Intrinsic::memmove_i32: + case Intrinsic::memmove_i64: + case Intrinsic::memset_i32: + case Intrinsic::memset_i64: + Assert1(isa<ConstantInt>(CI.getOperand(4)), + "alignment argument of memory intrinsics must be a constant int", + &CI); + break; case Intrinsic::init_trampoline: Assert1(isa<Function>(CI.getOperand(2)->stripPointerCasts()), "llvm.init_trampoline parameter #2 must resolve to a function.", diff --git a/test/Verifier/2008-08-22-MemCpyAlignment.ll b/test/Verifier/2008-08-22-MemCpyAlignment.ll new file mode 100644 index 0000000000..6bad2d138d --- /dev/null +++ b/test/Verifier/2008-08-22-MemCpyAlignment.ll @@ -0,0 +1,11 @@ +; RUN: not llvm-as -f %s -o /dev/null |& grep {alignment argument of memory intrinsics must be a constant int} +; PR2318 + +define void @x(i8* %a, i8* %src, i64 %len, i32 %align) nounwind { +entry: + tail call void @llvm.memcpy.i64( i8* %a, i8* %src, i64 %len, i32 %align) nounwind + ret void +} + +declare void @llvm.memcpy.i64( i8* %a, i8* %src, i64 %len, i32) + |