Skip to content

Commit 351a064

Browse files
committed
[DA] Adding a test case failure due to overflow in strong SIV test
1 parent 10afda0 commit 351a064

File tree

1 file changed

+68
-14
lines changed

1 file changed

+68
-14
lines changed

llvm/test/Analysis/DependenceAnalysis/StrongSIV.ll

Lines changed: 68 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,8 @@
11
; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 5
22
; RUN: opt < %s -disable-output "-passes=print<da>" -aa-pipeline=basic-aa 2>&1 \
3-
; RUN: | FileCheck %s
3+
; RUN: | FileCheck %s --check-prefixes=CHECK,CHECK-ALL
4+
; RUN: opt < %s -disable-output "-passes=print<da>" -aa-pipeline=basic-aa -da-enable-dependence-test=strong-siv 2>&1 \
5+
; RUN: | FileCheck %s --check-prefixes=CHECK,CHECK-STRONG-SIV
46

57
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
68
target triple = "x86_64-apple-macosx10.6.0"
@@ -423,19 +425,33 @@ for.end: ; preds = %for.body
423425
;; *B++ = A[i + 2*n];
424426

425427
define void @strong9(ptr %A, ptr %B, i64 %n) nounwind uwtable ssp {
426-
; CHECK-LABEL: 'strong9'
427-
; CHECK-NEXT: Src: store i32 %conv, ptr %arrayidx, align 4 --> Dst: store i32 %conv, ptr %arrayidx, align 4
428-
; CHECK-NEXT: da analyze - none!
429-
; CHECK-NEXT: Src: store i32 %conv, ptr %arrayidx, align 4 --> Dst: %0 = load i32, ptr %arrayidx2, align 4
430-
; CHECK-NEXT: da analyze - none!
431-
; CHECK-NEXT: Src: store i32 %conv, ptr %arrayidx, align 4 --> Dst: store i32 %0, ptr %B.addr.02, align 4
432-
; CHECK-NEXT: da analyze - confused!
433-
; CHECK-NEXT: Src: %0 = load i32, ptr %arrayidx2, align 4 --> Dst: %0 = load i32, ptr %arrayidx2, align 4
434-
; CHECK-NEXT: da analyze - none!
435-
; CHECK-NEXT: Src: %0 = load i32, ptr %arrayidx2, align 4 --> Dst: store i32 %0, ptr %B.addr.02, align 4
436-
; CHECK-NEXT: da analyze - confused!
437-
; CHECK-NEXT: Src: store i32 %0, ptr %B.addr.02, align 4 --> Dst: store i32 %0, ptr %B.addr.02, align 4
438-
; CHECK-NEXT: da analyze - none!
428+
; CHECK-ALL-LABEL: 'strong9'
429+
; CHECK-ALL-NEXT: Src: store i32 %conv, ptr %arrayidx, align 4 --> Dst: store i32 %conv, ptr %arrayidx, align 4
430+
; CHECK-ALL-NEXT: da analyze - none!
431+
; CHECK-ALL-NEXT: Src: store i32 %conv, ptr %arrayidx, align 4 --> Dst: %0 = load i32, ptr %arrayidx2, align 4
432+
; CHECK-ALL-NEXT: da analyze - none!
433+
; CHECK-ALL-NEXT: Src: store i32 %conv, ptr %arrayidx, align 4 --> Dst: store i32 %0, ptr %B.addr.02, align 4
434+
; CHECK-ALL-NEXT: da analyze - confused!
435+
; CHECK-ALL-NEXT: Src: %0 = load i32, ptr %arrayidx2, align 4 --> Dst: %0 = load i32, ptr %arrayidx2, align 4
436+
; CHECK-ALL-NEXT: da analyze - none!
437+
; CHECK-ALL-NEXT: Src: %0 = load i32, ptr %arrayidx2, align 4 --> Dst: store i32 %0, ptr %B.addr.02, align 4
438+
; CHECK-ALL-NEXT: da analyze - confused!
439+
; CHECK-ALL-NEXT: Src: store i32 %0, ptr %B.addr.02, align 4 --> Dst: store i32 %0, ptr %B.addr.02, align 4
440+
; CHECK-ALL-NEXT: da analyze - none!
441+
;
442+
; CHECK-STRONG-SIV-LABEL: 'strong9'
443+
; CHECK-STRONG-SIV-NEXT: Src: store i32 %conv, ptr %arrayidx, align 4 --> Dst: store i32 %conv, ptr %arrayidx, align 4
444+
; CHECK-STRONG-SIV-NEXT: da analyze - none!
445+
; CHECK-STRONG-SIV-NEXT: Src: store i32 %conv, ptr %arrayidx, align 4 --> Dst: %0 = load i32, ptr %arrayidx2, align 4
446+
; CHECK-STRONG-SIV-NEXT: da analyze - flow [*|<]!
447+
; CHECK-STRONG-SIV-NEXT: Src: store i32 %conv, ptr %arrayidx, align 4 --> Dst: store i32 %0, ptr %B.addr.02, align 4
448+
; CHECK-STRONG-SIV-NEXT: da analyze - confused!
449+
; CHECK-STRONG-SIV-NEXT: Src: %0 = load i32, ptr %arrayidx2, align 4 --> Dst: %0 = load i32, ptr %arrayidx2, align 4
450+
; CHECK-STRONG-SIV-NEXT: da analyze - none!
451+
; CHECK-STRONG-SIV-NEXT: Src: %0 = load i32, ptr %arrayidx2, align 4 --> Dst: store i32 %0, ptr %B.addr.02, align 4
452+
; CHECK-STRONG-SIV-NEXT: da analyze - confused!
453+
; CHECK-STRONG-SIV-NEXT: Src: store i32 %0, ptr %B.addr.02, align 4 --> Dst: store i32 %0, ptr %B.addr.02, align 4
454+
; CHECK-STRONG-SIV-NEXT: da analyze - none!
439455
;
440456
entry:
441457
%cmp1 = icmp eq i64 %n, 0
@@ -512,3 +528,41 @@ for.body: ; preds = %entry, %for.body
512528
for.end: ; preds = %for.body
513529
ret void
514530
}
531+
532+
533+
;; for (long unsigned i = 0; i < 9223372036854775806; i++)
534+
;; for (long unsigned j = 0; j < 2147483640; j++)
535+
;; if (i < 3000000000)
536+
;; A[i] = 0;
537+
;
538+
; FIXME: DependenceAnalysis currently detects no dependency between A[i] and
539+
; itself, but it does exist.
540+
define void @strong11(ptr %A) nounwind uwtable ssp {
541+
; CHECK-LABEL: 'strong11'
542+
; CHECK-NEXT: Src: store i32 0, ptr %arrayidx, align 4 --> Dst: store i32 0, ptr %arrayidx, align 4
543+
; CHECK-NEXT: da analyze - none!
544+
;
545+
entry:
546+
br label %for.cond1.preheader
547+
548+
for.cond1.preheader: ; preds = %entry, %for.cond.cleanup3
549+
%i.017 = phi i64 [ 0, %entry ], [ %inc8, %for.cond.cleanup3 ]
550+
%cmp5 = icmp samesign ult i64 %i.017, 3000000000
551+
%arrayidx = getelementptr inbounds nuw i32, ptr %A, i64 %i.017
552+
br i1 %cmp5, label %for.body4.us, label %for.cond.cleanup3
553+
554+
for.body4.us: ; preds = %for.cond1.preheader, %for.body4.us
555+
%j.016.us = phi i64 [ %inc.us, %for.body4.us ], [ 0, %for.cond1.preheader ]
556+
store i32 0, ptr %arrayidx, align 4
557+
%inc.us = add nuw nsw i64 %j.016.us, 1
558+
%exitcond.not = icmp eq i64 %inc.us, 2147483640
559+
br i1 %exitcond.not, label %for.cond.cleanup3, label %for.body4.us
560+
561+
for.cond.cleanup: ; preds = %for.cond.cleanup3
562+
ret void
563+
564+
for.cond.cleanup3: ; preds = %for.body4.us, %for.cond1.preheader
565+
%inc8 = add nuw nsw i64 %i.017, 1
566+
%exitcond19.not = icmp eq i64 %inc8, 9223372036854775806
567+
br i1 %exitcond19.not, label %for.cond.cleanup, label %for.cond1.preheader
568+
}

0 commit comments

Comments
 (0)