2017-03-08 04:28:43 +08:00
|
|
|
; RUN: opt %loadPolly -polly-scops -analyze -polly-allow-nonaffine -polly-invariant-load-hoisting=true < %s \
|
2017-02-12 16:11:12 +08:00
|
|
|
; RUN: -debug 2>&1 | FileCheck %s
|
|
|
|
|
|
|
|
; REQUIRES: asserts
|
|
|
|
|
|
|
|
; CHECK: Region: %bb1---%bb16
|
2018-02-20 15:26:42 +08:00
|
|
|
; CHECK: [n] -> { : false }
|
2017-02-12 16:11:12 +08:00
|
|
|
|
|
|
|
; This test case at some point caused an assertion when modeling a scop, due
|
|
|
|
; to use constructing an invalid lower and upper bound for the range of
|
|
|
|
; non-affine accesses.
|
|
|
|
|
|
|
|
target datalayout = "e-p:64:64:64-S128-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f16:16:16-f32:32:32-f64:64:64-f128:128:128-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
|
|
|
|
|
|
|
|
define void @zot(double* noalias %arg, double** %D, i32 %n) {
|
|
|
|
bb:
|
|
|
|
br label %bb1
|
|
|
|
|
|
|
|
bb1:
|
|
|
|
%tmp4 = load double*, double** %D
|
|
|
|
%tmp5 = add i64 undef, 3
|
|
|
|
%tmp6 = add i64 %tmp5, undef
|
|
|
|
%tmp7 = add i64 %tmp6, undef
|
|
|
|
%tmp8 = getelementptr double, double* %tmp4, i64 %tmp7
|
|
|
|
%tmp9 = bitcast double* %tmp8 to i64*
|
|
|
|
store i64 42, i64* %tmp9
|
|
|
|
br label %bb11
|
|
|
|
|
|
|
|
bb11:
|
|
|
|
%tmp12 = getelementptr double, double* %arg, i64 0
|
|
|
|
%tmp13 = bitcast double* %tmp12 to i64*
|
|
|
|
store i64 43, i64* %tmp13
|
|
|
|
br label %bb14
|
|
|
|
|
|
|
|
bb14:
|
|
|
|
%tmp15 = icmp eq i32 0, %n
|
|
|
|
br i1 %tmp15, label %bb16, label %bb1
|
|
|
|
|
|
|
|
bb16:
|
|
|
|
ret void
|
|
|
|
}
|