mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-24 22:24:54 +00:00
indvars: Linear function test replace should avoid reusing undef.
Fixes PR13371: indvars pass incorrectly substitutes 'undef' values. I do not like this fix. It's needed until/unless the meaning of undef changes. It attempts to be complete according to the IR spec, but I don't have much confidence in the implementation given the difficulty testing undefined behavior. Worse, this invalidates some of my hard-fought work on indvars and LSR to optimize pointer induction variables. It results benchmark regressions, which I'll track internally. On x86_64 no LTO I see: -3% huffbench -3% 400.perlbench -8% fhourstones My only suggestion for recovering is to change the meaning of undef. If we could trust an arbitrary instruction to produce a some real value that can be manipulated (e.g. incremented) according to non-undef rules, then this case could be easily handled with SCEV. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@160421 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -153,6 +153,9 @@ return:
|
||||
; Remove %i which is only used by the exit test.
|
||||
; Verify that SCEV can still compute a backedge count from the sign
|
||||
; extended %n, used for pointer comparison by LFTR.
|
||||
;
|
||||
; TODO: Fix for PR13371 currently makes this impossible. See
|
||||
; IndVarSimplify.cpp hasConcreteDef(). We may want to change to undef rules.
|
||||
define void @geplftr(i8* %base, i32 %x, i32 %y, i32 %n) nounwind {
|
||||
entry:
|
||||
%x.ext = sext i32 %x to i64
|
||||
@@ -162,13 +165,13 @@ entry:
|
||||
%lim = add i32 %x, %n
|
||||
%cmp.ph = icmp ult i32 %x, %lim
|
||||
br i1 %cmp.ph, label %loop, label %exit
|
||||
|
||||
; CHECK: @geplftr
|
||||
; CHECK: loop:
|
||||
; CHECK: phi i8*
|
||||
; CHECK-NOT: phi
|
||||
; DISABLE-NOT: phi // This check is currently disabled
|
||||
; CHECK: getelementptr
|
||||
; CHECK: store
|
||||
; CHECK: icmp ne i8*
|
||||
; DISABLE: icmp ne i8* // This check is currently disabled
|
||||
; CHECK: br i1
|
||||
loop:
|
||||
%i = phi i32 [ %x, %entry ], [ %inc, %loop ]
|
||||
@@ -187,7 +190,7 @@ exit:
|
||||
define void @nevertaken() nounwind uwtable ssp {
|
||||
entry:
|
||||
br label %loop
|
||||
|
||||
; CHECK: @nevertaken
|
||||
; CHECK: loop:
|
||||
; CHECK-NOT: phi
|
||||
; CHECK-NOT: add
|
||||
|
Reference in New Issue
Block a user