From 01533ff6526fd31ed4d5c9768dae65ccb1126d92 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Fri, 20 Feb 2004 23:05:43 +0000 Subject: [PATCH] new testcase git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@11682 91177308-0d34-0410-b5e6-96231b3b80d8 --- test/Analysis/DSGraph/strcpy.ll | 34 +++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 test/Analysis/DSGraph/strcpy.ll diff --git a/test/Analysis/DSGraph/strcpy.ll b/test/Analysis/DSGraph/strcpy.ll new file mode 100644 index 00000000000..5ef59ae8d3e --- /dev/null +++ b/test/Analysis/DSGraph/strcpy.ll @@ -0,0 +1,34 @@ +; We know that strcpy cannot be used to copy pointer values, because +; pointers might contain null bytes and would stop the copy. The code +; has no defined way to check for this, so DSA can know that strcpy doesn't +; require merging the input arguments. + +; RUN: analyze %s -datastructure-gc --dsgc-abort-if-merged=A,B --dsgc-check-flags=A:SM,B:SR --dsgc-dspass=bu + +implementation + +internal void %strcpy(sbyte* %s1, sbyte* %s2) { +entry: + br label %loopentry + +loopentry: ; preds = %entry, %loopentry + %cann-indvar = phi uint [ 0, %entry ], [ %next-indvar, %loopentry ] ; [#uses=2] + %cann-indvar1 = cast uint %cann-indvar to long ; [#uses=2] + %s1_addr.0 = getelementptr sbyte* %s1, long %cann-indvar1 ; [#uses=1] + %s2_addr.0 = getelementptr sbyte* %s2, long %cann-indvar1 ; [#uses=1] + %next-indvar = add uint %cann-indvar, 1 ; [#uses=1] + %tmp.3 = load sbyte* %s2_addr.0 ; [#uses=2] + store sbyte %tmp.3, sbyte* %s1_addr.0 + %tmp.4 = setne sbyte %tmp.3, 0 ; [#uses=1] + br bool %tmp.4, label %loopentry, label %loopexit + +loopexit: ; preds = %loopentry + ret void +} + +int %main() { + %A = alloca sbyte + %B = alloca sbyte + call void %strcpy(sbyte* %A, sbyte* %B) + ret int 0 +}