diff options
| -rw-r--r-- | polly/lib/Support/GICHelper.cpp | 5 | ||||
| -rw-r--r-- | polly/test/ScopInfo/integers.ll | 123 | 
2 files changed, 125 insertions, 3 deletions
diff --git a/polly/lib/Support/GICHelper.cpp b/polly/lib/Support/GICHelper.cpp index 876e132ab72..f1fe15a7928 100644 --- a/polly/lib/Support/GICHelper.cpp +++ b/polly/lib/Support/GICHelper.cpp @@ -33,8 +33,7 @@ void polly::MPZ_from_APInt(mpz_t v, const APInt apint, bool is_signed) {    const uint64_t *rawdata = abs.getRawData();    unsigned numWords = abs.getNumWords(); -  // TODO: Check if this is true for all platforms. -  mpz_import(v, numWords, 1, sizeof(uint64_t), 0, 0, rawdata); +  mpz_import(v, numWords, -1, sizeof(uint64_t), 0, 0, rawdata);    if (is_signed && apint.isNegative())      mpz_neg(v, v); @@ -44,7 +43,7 @@ APInt polly::APInt_from_MPZ(const mpz_t mpz) {    uint64_t *p = NULL;    size_t sz; -  p = (uint64_t *)mpz_export(p, &sz, 1, sizeof(uint64_t), 0, 0, mpz); +  p = (uint64_t *)mpz_export(p, &sz, -1, sizeof(uint64_t), 0, 0, mpz);    if (p) {      APInt A((unsigned) mpz_sizeinbase(mpz, 2), (unsigned) sz, p); diff --git a/polly/test/ScopInfo/integers.ll b/polly/test/ScopInfo/integers.ll new file mode 100644 index 00000000000..f36bf1f479f --- /dev/null +++ b/polly/test/ScopInfo/integers.ll @@ -0,0 +1,123 @@ +; RUN: opt %loadPolly -polly-scops -analyze < %s | FileCheck %s + +; Check that we correctly convert integers to isl values. + +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" +target triple = "x86_64-unknown-linux-gnu" + +; Large positive integer +define void @f(i1024* nocapture %a) nounwind { +entry: +  br label %bb + +bb: +  %indvar = phi i1024 [ 0, %entry ], [ %indvar.next, %bb ] +  %scevgep = getelementptr i1024* %a, i1024 %indvar +  store i1024 %indvar, i1024* %scevgep, align 8 +  %indvar.next = add nsw i1024 %indvar, 1 +  %exitcond = icmp eq i1024 %indvar, 123456000000000000000000000 +; CHECK:  'bb => return' in function 'f' +; CHECK: i0 <= 123456000000000000000000000 +  br i1 %exitcond, label %return, label %bb + +return: +  ret void +} + +; Normal positive integer +define void @f2(i32* nocapture %a) nounwind { +entry: +  br label %bb + +bb: +  %indvar = phi i32 [ 0, %entry ], [ %indvar.next, %bb ] +  %scevgep = getelementptr i32* %a, i32 %indvar +  store i32 %indvar, i32* %scevgep, align 8 +  %indvar.next = add nsw i32 %indvar, 1 +  %exitcond = icmp eq i32 %indvar, 123456 +; CHECK:  'bb => return' in function 'f2' +; CHECK: i0 <= 123456 +  br i1 %exitcond, label %return, label %bb + +return: +  ret void +} + +; Normal negative integer +define void @f3(i32* nocapture %a, i32 %n) nounwind { +entry: +  br label %bb + +bb: +  %indvar = phi i32 [ 0, %entry ], [ %indvar.next, %bb ] +  %scevgep = getelementptr i32* %a, i32 %indvar +  store i32 %indvar, i32* %scevgep, align 8 +  %indvar.next = add nsw i32 %indvar, 1 +  %sub = sub i32 %n, 123456 +  %exitcond = icmp eq i32 %indvar, %sub +; CHECK:  'bb => return' in function 'f3' +; CHECK: -123456 +  br i1 %exitcond, label %return, label %bb + +return: +  ret void +} + +; Large negative integer +define void @f4(i1024* nocapture %a, i1024 %n) nounwind { +entry: +  br label %bb + +bb: +  %indvar = phi i1024 [ 0, %entry ], [ %indvar.next, %bb ] +  %scevgep = getelementptr i1024* %a, i1024 %indvar +  store i1024 %indvar, i1024* %scevgep, align 8 +  %indvar.next = add nsw i1024 %indvar, 1 +  %sub = sub i1024 %n, 123456000000000000000000000000000000 +; CHECK:  'bb => return' in function 'f4' +; CHECK: -123456000000000000000000000000000000 +  %exitcond = icmp eq i1024 %indvar, %sub +  br i1 %exitcond, label %return, label %bb + +return: +  ret void +} + +define void @f5(i1023* nocapture %a, i1023 %n) nounwind { +entry: +  br label %bb + +bb: +  %indvar = phi i1023 [ 0, %entry ], [ %indvar.next, %bb ] +  %scevgep = getelementptr i1023* %a, i1023 %indvar +  store i1023 %indvar, i1023* %scevgep, align 8 +  %indvar.next = add nsw i1023 %indvar, 1 +  %sub = sub i1023 %n, 123456000000000000000000000000000000 +; CHECK:  'bb => return' in function 'f5' +; CHECK: -123456000000000000000000000000000000 +  %exitcond = icmp eq i1023 %indvar, %sub +  br i1 %exitcond, label %return, label %bb + +return: +  ret void +} + +; Tiny negative integer +define void @f6(i3* nocapture %a, i3 %n) nounwind { +entry: +  br label %bb + +bb: +  %indvar = phi i3 [ 0, %entry ], [ %indvar.next, %bb ] +  %scevgep = getelementptr i3* %a, i3 %indvar +  store i3 %indvar, i3* %scevgep, align 8 +  %indvar.next = add nsw i3 %indvar, 1 +  %sub = sub i3 %n, 3 +; CHECK:  'bb => return' in function 'f6' +; CHECK: -3 +  %exitcond = icmp eq i3 %indvar, %sub +  br i1 %exitcond, label %return, label %bb + +return: +  ret void +}  | 

