a.ll 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. ; RUN: opt < %s -analyze -delinearize | FileCheck %s
  2. ;
  3. ; void foo(long n, long m, long o, int A[n][m][o]) {
  4. ; for (long i = 0; i < n; i++)
  5. ; for (long j = 0; j < m; j++)
  6. ; for (long k = 0; k < o; k++)
  7. ; A[2*i+3][3*j-4][5*k+7] = 1;
  8. ; }
  9. ; AddRec: {{{(28 + (4 * (-4 + (3 * %m)) * %o) + %A),+,(8 * %m * %o)}<%for.i>,+,(12 * %o)}<%for.j>,+,20}<%for.k>
  10. ; CHECK: Base offset: %A
  11. ; CHECK: ArrayDecl[UnknownSize][%m][%o] with elements of 4 bytes.
  12. ; CHECK: ArrayRef[{3,+,2}<%for.i>][{-4,+,3}<%for.j>][{7,+,5}<%for.k>]
  13. define void @foo(i64 %n, i64 %m, i64 %o, i32* nocapture %A) #0 {
  14. entry:
  15. %cmp32 = icmp sgt i64 %n, 0
  16. br i1 %cmp32, label %for.cond1.preheader.lr.ph, label %for.end17
  17. for.cond1.preheader.lr.ph: ; preds = %entry
  18. %cmp230 = icmp sgt i64 %m, 0
  19. %cmp528 = icmp sgt i64 %o, 0
  20. br i1 %cmp230, label %for.i, label %for.end17
  21. for.inc15.us: ; preds = %for.inc12.us.us, %for.i
  22. %inc16.us = add nsw i64 %i.033.us, 1
  23. %exitcond55 = icmp eq i64 %inc16.us, %n
  24. br i1 %exitcond55, label %for.end17, label %for.i
  25. for.i: ; preds = %for.cond1.preheader.lr.ph, %for.inc15.us
  26. %i.033.us = phi i64 [ %inc16.us, %for.inc15.us ], [ 0, %for.cond1.preheader.lr.ph ]
  27. %mul8.us = shl i64 %i.033.us, 1
  28. %add9.us = add nsw i64 %mul8.us, 3
  29. %0 = mul i64 %add9.us, %m
  30. %sub.us = add i64 %0, -4
  31. br i1 %cmp528, label %for.j, label %for.inc15.us
  32. for.inc12.us.us: ; preds = %for.k
  33. %inc13.us.us = add nsw i64 %j.031.us.us, 1
  34. %exitcond54 = icmp eq i64 %inc13.us.us, %m
  35. br i1 %exitcond54, label %for.inc15.us, label %for.j
  36. for.j: ; preds = %for.i, %for.inc12.us.us
  37. %j.031.us.us = phi i64 [ %inc13.us.us, %for.inc12.us.us ], [ 0, %for.i ]
  38. %mul7.us.us = mul nsw i64 %j.031.us.us, 3
  39. %tmp.us.us = add i64 %sub.us, %mul7.us.us
  40. %tmp27.us.us = mul i64 %tmp.us.us, %o
  41. br label %for.k
  42. for.k: ; preds = %for.k, %for.j
  43. %k.029.us.us = phi i64 [ 0, %for.j ], [ %inc.us.us, %for.k ]
  44. %mul.us.us = mul nsw i64 %k.029.us.us, 5
  45. %arrayidx.sum.us.us = add i64 %mul.us.us, 7
  46. %arrayidx10.sum.us.us = add i64 %arrayidx.sum.us.us, %tmp27.us.us
  47. %arrayidx11.us.us = getelementptr inbounds i32, i32* %A, i64 %arrayidx10.sum.us.us
  48. store i32 1, i32* %arrayidx11.us.us, align 4
  49. %inc.us.us = add nsw i64 %k.029.us.us, 1
  50. %exitcond = icmp eq i64 %inc.us.us, %o
  51. br i1 %exitcond, label %for.inc12.us.us, label %for.k
  52. for.end17: ; preds = %for.inc15.us, %for.cond1.preheader.lr.ph, %entry
  53. ret void
  54. }