Mercurial > hg > CbC > CbC_llvm
diff llvm/test/Transforms/LoopDistribute/crash-in-memcheck-generation.ll @ 252:1f2b6ac9f198 llvm-original
LLVM16-1
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Fri, 18 Aug 2023 09:04:13 +0900 |
parents | c4bab56944e8 |
children |
line wrap: on
line diff
--- a/llvm/test/Transforms/LoopDistribute/crash-in-memcheck-generation.ll Wed Nov 09 17:47:54 2022 +0900 +++ b/llvm/test/Transforms/LoopDistribute/crash-in-memcheck-generation.ll Fri Aug 18 09:04:13 2023 +0900 @@ -1,4 +1,4 @@ -; RUN: opt -loop-distribute -enable-loop-distribute -loop-vectorize -force-vector-width=4 \ +; RUN: opt -passes=loop-distribute,loop-vectorize -enable-loop-distribute -force-vector-width=4 \ ; RUN: -verify-loop-info -verify-dom-info -S < %s | FileCheck %s ; If only A and B can alias here, we don't need memchecks to distribute since @@ -14,11 +14,11 @@ target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128" target triple = "x86_64-apple-macosx10.10.0" -define void @f(i32* %a, - i32* %b, - i32* noalias %c, - i32* noalias %d, - i32* noalias %e) { +define void @f(ptr %a, + ptr %b, + ptr noalias %c, + ptr noalias %d, + ptr noalias %e) { entry: br label %for.body @@ -28,28 +28,28 @@ for.body: ; preds = %for.body, %entry %ind = phi i64 [ 0, %entry ], [ %add, %for.body ] - %arrayidxA = getelementptr inbounds i32, i32* %a, i64 %ind - %loadA = load i32, i32* %arrayidxA, align 4 + %arrayidxA = getelementptr inbounds i32, ptr %a, i64 %ind + %loadA = load i32, ptr %arrayidxA, align 4 - %arrayidxB = getelementptr inbounds i32, i32* %b, i64 %ind - %loadB = load i32, i32* %arrayidxB, align 4 + %arrayidxB = getelementptr inbounds i32, ptr %b, i64 %ind + %loadB = load i32, ptr %arrayidxB, align 4 %mulA = mul i32 %loadB, %loadA %add = add nuw nsw i64 %ind, 1 - %arrayidxA_plus_4 = getelementptr inbounds i32, i32* %a, i64 %add - store i32 %mulA, i32* %arrayidxA_plus_4, align 4 + %arrayidxA_plus_4 = getelementptr inbounds i32, ptr %a, i64 %add + store i32 %mulA, ptr %arrayidxA_plus_4, align 4 - %arrayidxD = getelementptr inbounds i32, i32* %d, i64 %ind - %loadD = load i32, i32* %arrayidxD, align 4 + %arrayidxD = getelementptr inbounds i32, ptr %d, i64 %ind + %loadD = load i32, ptr %arrayidxD, align 4 - %arrayidxE = getelementptr inbounds i32, i32* %e, i64 %ind - %loadE = load i32, i32* %arrayidxE, align 4 + %arrayidxE = getelementptr inbounds i32, ptr %e, i64 %ind + %loadE = load i32, ptr %arrayidxE, align 4 %mulC = mul i32 %loadD, %loadE - %arrayidxC = getelementptr inbounds i32, i32* %c, i64 %ind - store i32 %mulC, i32* %arrayidxC, align 4 + %arrayidxC = getelementptr inbounds i32, ptr %c, i64 %ind + store i32 %mulC, ptr %arrayidxC, align 4 %exitcond = icmp eq i64 %add, 20 br i1 %exitcond, label %for.end, label %for.body