[llvm-branch-commits] [llvm-branch] r245478 - Merging r245395:
Hans Wennborg via llvm-branch-commits
llvm-branch-commits at lists.llvm.org
Wed Aug 19 11:40:30 PDT 2015
Author: hans
Date: Wed Aug 19 13:40:30 2015
New Revision: 245478
URL: http://llvm.org/viewvc/llvm-project?rev=245478&view=rev
Log:
Merging r245395:
------------------------------------------------------------------------
r245395 | qcolombet | 2015-08-18 17:08:26 -0700 (Tue, 18 Aug 2015) | 3 lines
[BasicAA] Add a test for PR24468 to be sure we won't regress
when we finally get the GEP aliasing right.
------------------------------------------------------------------------
Modified:
llvm/branches/release_37/ (props changed)
llvm/branches/release_37/test/Analysis/BasicAA/gep-alias.ll
Propchange: llvm/branches/release_37/
------------------------------------------------------------------------------
--- svn:mergeinfo (original)
+++ svn:mergeinfo Wed Aug 19 13:40:30 2015
@@ -1,3 +1,3 @@
/llvm/branches/Apple/Pertwee:110850,110961
/llvm/branches/type-system-rewrite:133420-134817
-/llvm/trunk:155241,242236,242239,242281,242288,242296,242331,242341,242410,242412,242433-242434,242442,242543,242673,242680,242706,242721-242722,242733-242735,242742,242869,242919,242993,243001,243057,243116,243263,243294,243361,243469,243485,243500,243519,243531,243589,243609,243636,243638-243640,243745,243891,243898,243927,243932,243934,243984,243986,243999,244058,244123,244232,244332,244418,244448,244554,244644,244659,244676,244789,244889,245064,245105,245119,245256,245355,245394
+/llvm/trunk:155241,242236,242239,242281,242288,242296,242331,242341,242410,242412,242433-242434,242442,242543,242673,242680,242706,242721-242722,242733-242735,242742,242869,242919,242993,243001,243057,243116,243263,243294,243361,243469,243485,243500,243519,243531,243589,243609,243636,243638-243640,243745,243891,243898,243927,243932,243934,243984,243986,243999,244058,244123,244232,244332,244418,244448,244554,244644,244659,244676,244789,244889,245064,245105,245119,245256,245355,245394-245395
Modified: llvm/branches/release_37/test/Analysis/BasicAA/gep-alias.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/branches/release_37/test/Analysis/BasicAA/gep-alias.ll?rev=245478&r1=245477&r2=245478&view=diff
==============================================================================
--- llvm/branches/release_37/test/Analysis/BasicAA/gep-alias.ll (original)
+++ llvm/branches/release_37/test/Analysis/BasicAA/gep-alias.ll Wed Aug 19 13:40:30 2015
@@ -228,3 +228,51 @@ define i32 @test12(i32 %x, i32 %y, i8* %
; CHECK-LABEL: @test12(
; CHECK: ret i32 %r
}
+
+ at P = internal global i32 715827882, align 4
+ at Q = internal global i32 715827883, align 4
+ at .str = private unnamed_addr constant [7 x i8] c"%u %u\0A\00", align 1
+
+; Make sure we recognize that u[0] and u[Global + Cst] may alias
+; when the addition has wrapping semantic.
+; PR24468.
+; CHECK-LABEL: @test13(
+; Make sure the stores appear before the related loads.
+; CHECK: store i8 42,
+; CHECK: store i8 99,
+; Find the loads and make sure they are used in the arguments to the printf.
+; CHECK: [[T0ADDR:%[a-zA-Z0-9_]+]] = getelementptr inbounds [3 x i8], [3 x i8]* %t, i32 0, i32 0
+; CHECK: [[T0:%[a-zA-Z0-9_]+]] = load i8, i8* [[T0ADDR]], align 1
+; CHECK: [[T0ARG:%[a-zA-Z0-9_]+]] = zext i8 [[T0]] to i32
+; CHECK: [[U0ADDR:%[a-zA-Z0-9_]+]] = getelementptr inbounds [3 x i8], [3 x i8]* %u, i32 0, i32 0
+; CHECK: [[U0:%[a-zA-Z0-9_]+]] = load i8, i8* [[U0ADDR]], align 1
+; CHECK: [[U0ARG:%[a-zA-Z0-9_]+]] = zext i8 [[U0]] to i32
+; CHECK: call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([7 x i8], [7 x i8]* @.str, i32 0, i32 0), i32 [[T0ARG]], i32 [[U0ARG]])
+; CHECK: ret
+define void @test13() {
+entry:
+ %t = alloca [3 x i8], align 1
+ %u = alloca [3 x i8], align 1
+ %tmp = load i32, i32* @P, align 4
+ %tmp1 = mul i32 %tmp, 3
+ %mul = add i32 %tmp1, -2147483646
+ %idxprom = zext i32 %mul to i64
+ %arrayidx = getelementptr inbounds [3 x i8], [3 x i8]* %t, i64 0, i64 %idxprom
+ store i8 42, i8* %arrayidx, align 1
+ %tmp2 = load i32, i32* @Q, align 4
+ %tmp3 = mul i32 %tmp2, 3
+ %mul2 = add i32 %tmp3, 2147483647
+ %idxprom3 = zext i32 %mul2 to i64
+ %arrayidx4 = getelementptr inbounds [3 x i8], [3 x i8]* %u, i64 0, i64 %idxprom3
+ store i8 99, i8* %arrayidx4, align 1
+ %arrayidx5 = getelementptr inbounds [3 x i8], [3 x i8]* %t, i64 0, i64 0
+ %tmp4 = load i8, i8* %arrayidx5, align 1
+ %conv = zext i8 %tmp4 to i32
+ %arrayidx6 = getelementptr inbounds [3 x i8], [3 x i8]* %u, i64 0, i64 0
+ %tmp5 = load i8, i8* %arrayidx6, align 1
+ %conv7 = zext i8 %tmp5 to i32
+ %call = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([7 x i8], [7 x i8]* @.str, i64 0, i64 0), i32 %conv, i32 %conv7)
+ ret void
+}
+
+declare i32 @printf(i8*, ...)
More information about the llvm-branch-commits
mailing list