https://llvm.org/bugs/show_bug.cgi?id=27395

            Bug ID: 27395
           Summary: Missing loop canonicalization when iterating using a
                    pointer or an integer index
           Product: new-bugs
           Version: trunk
          Hardware: PC
                OS: All
            Status: NEW
          Severity: normal
          Priority: P
         Component: new bugs
          Assignee: unassignedb...@nondot.org
          Reporter: mehdi.am...@apple.com
                CC: llvm-bugs@lists.llvm.org
    Classification: Unclassified

Considering this simple example:

int data[8000];
int init_value;
void foo() {
    auto *start = data;
    while (start++ != data+8000)
        *start = init_value;
}
void bar() {
    for (int i = 0; i < 8000; i++)
        data[i] = init_value;
}



foo() and bar() are performing the same initialization of array `data`, however
foo() is iterating using a sliding pointer while bar() is using an integer
index.
I would expect us to canonicalize the iterator one way or the other.

Right now, we can only vectorize the second form. It seems to be because the
first form iterates using a pointer, it compares to the end of the array using:

  %4 = icmp ne i32* %2, getelementptr inbounds (i32* getelementptr inbounds
([8000 x i32]* @data, i32 0, i32 0), i64 8000)

This GEP prevents global alias analysis from doing anything interesting with
data (i. (Here it seems that "data" is not detected to not alias with
`init_value`...), see GlobalsAAResult::AnalyzeUsesOfPointer().

-- 
You are receiving this mail because:
You are on the CC list for the bug.
_______________________________________________
llvm-bugs mailing list
llvm-bugs@lists.llvm.org
http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-bugs

Reply via email to