Mercurial > hg > CbC > CbC_llvm
diff llvm/test/Transforms/LoopDistribute/basic.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/basic.ll Wed Nov 09 17:47:54 2022 +0900 +++ b/llvm/test/Transforms/LoopDistribute/basic.ll Fri Aug 18 09:04:13 2023 +0900 @@ -19,11 +19,11 @@ target triple = "x86_64-apple-macosx10.10.0" ; CHECK-LABEL: @f( -define void @f(i32* noalias %a, - i32* noalias %b, - i32* noalias %c, - i32* noalias %d, - i32* noalias %e) { +define void @f(ptr noalias %a, + ptr noalias %b, + ptr noalias %c, + ptr noalias %d, + ptr noalias %e) { entry: br label %for.body @@ -53,28 +53,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 @@ -88,11 +88,11 @@ ; It is OK to distribute with a convergent operation, since in each ; new loop the convergent operation has the ssame control dependency. ; CHECK-LABEL: @f_with_convergent( -define void @f_with_convergent(i32* noalias %a, - i32* noalias %b, - i32* noalias %c, - i32* noalias %d, - i32* noalias %e) { +define void @f_with_convergent(ptr noalias %a, + ptr noalias %b, + ptr noalias %c, + ptr noalias %d, + ptr noalias %e) { entry: br label %for.body @@ -125,29 +125,29 @@ 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 %convergentD = call i32 @llvm.convergent(i32 %loadD) %mulC = mul i32 %convergentD, %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