mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 11:13:28 +01:00
0520741ff9
ScalarEvolution currently lowers a subtraction recurrence to an add recurrence with the same no-wrap flags as the subtraction. This is incorrect because `sub nsw X, Y` is not the same as `add nsw X, -Y` and `sub nuw X, Y` is not the same as `add nuw X, -Y`. This patch fixes the issue, and adds two test cases demonstrating the bug. Differential Revision: http://reviews.llvm.org/D7081 llvm-svn: 226755
42 lines
939 B
LLVM
42 lines
939 B
LLVM
; RUN: opt -S -indvars < %s | FileCheck %s
|
|
|
|
; Check that SCEV does not assume sub nuw X Y == add nuw X, -Y
|
|
define void @f(i32* %loc) {
|
|
; CHECK-LABEL: @f
|
|
entry:
|
|
br label %loop
|
|
|
|
loop:
|
|
%idx = phi i32 [ 6, %entry ], [ %idx.dec, %loop ]
|
|
store i32 %idx, i32* %loc
|
|
%idx.dec = sub nuw i32 %idx, 1
|
|
%cond = icmp uge i32 %idx.dec, 5
|
|
br i1 %cond, label %loop, label %exit
|
|
; CHECK-NOT: br i1 true, label %loop, label %exit
|
|
|
|
exit:
|
|
ret void
|
|
}
|
|
|
|
declare void @use_i1(i1)
|
|
|
|
; Check that SCEV does not assume sub nsw X Y == add nsw X, -Y
|
|
define void @g(i32 %lim) {
|
|
; CHECK-LABEL: @g
|
|
entry:
|
|
br label %loop
|
|
|
|
loop:
|
|
%idx = phi i32 [ -1, %entry ], [ %idx.dec, %loop ]
|
|
%t = icmp sgt i32 %idx, 0
|
|
; CHECK-NOT: call void @use_i1(i1 false)
|
|
; CHECK: call void @use_i1(i1 %t)
|
|
call void @use_i1(i1 %t)
|
|
%idx.dec = sub nsw i32 %idx, -2147483648
|
|
%cond = icmp eq i32 %idx.dec, %lim
|
|
br i1 %cond, label %loop, label %exit
|
|
|
|
exit:
|
|
ret void
|
|
}
|