This reverts commit e987ab11a6f3d3965ef26fc42c82db3e8b1d56f5. This broke premerge: 1. https://lab.llvm.org/staging/#/builders/192/builds/9521 2. https://github.com/llvm/llvm-project/actions/runs/19054182009 Notably this did not break inside the PR. Not exactly sure why. I realize that there is a lot of test churn here, but they're largely in polly where commit frequency is much lower, so a reapply of the patch should be clean.
45 lines
1.2 KiB
LLVM
45 lines
1.2 KiB
LLVM
; RUN: opt %loadNPMPolly '-passes=polly-import-jscop,polly-codegen' -polly-import-jscop-postfix=transformed -S < %s | FileCheck %s
|
|
;
|
|
; Partial write of an array access.
|
|
;
|
|
; for (int j = 0; j < n; j += 1)
|
|
; A[0] = 42.0
|
|
;
|
|
|
|
define void @partial_write_array(i32 %n, ptr noalias nonnull %A) {
|
|
entry:
|
|
br label %for
|
|
|
|
for:
|
|
%j = phi i32 [0, %entry], [%j.inc, %inc]
|
|
%j.cmp = icmp slt i32 %j, %n
|
|
br i1 %j.cmp, label %body, label %exit
|
|
|
|
body:
|
|
store double 42.0, ptr %A
|
|
br label %inc
|
|
|
|
inc:
|
|
%j.inc = add nuw nsw i32 %j, 1
|
|
br label %for
|
|
|
|
exit:
|
|
br label %return
|
|
|
|
return:
|
|
ret void
|
|
}
|
|
|
|
|
|
; CHECK: polly.stmt.body:
|
|
; CHECK-NEXT: %1 = icmp sge i64 %polly.indvar, 5
|
|
; CHECK-NEXT: %polly.Stmt_body_Write0.cond = icmp ne i1 %1, false
|
|
; CHECK-NEXT: br i1 %polly.Stmt_body_Write0.cond, label %polly.stmt.body.Stmt_body_Write0.partial, label %polly.stmt.body.cont
|
|
|
|
; CHECK: polly.stmt.body.Stmt_body_Write0.partial:
|
|
; CHECK-NEXT: %polly.access.A = getelementptr double, ptr %A, i64 0
|
|
; CHECK-NEXT: store double 4.200000e+01, ptr %polly.access.A, align 8, !alias.scope !2, !noalias !5
|
|
; CHECK-NEXT: br label %polly.stmt.body.cont
|
|
|
|
; CHECK: polly.stmt.body.cont:
|