zext-signed-addrec.ll 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. ; RUN: opt -loop-reduce -S < %s | FileCheck %s
  2. ; PR18000
  3. target datalayout = "e-i64:64-f80:128-s:64-n8:16:32:64-S128"
  4. target triple = "x86_64-unknown-linux-gnu"
  5. @a = global i32 0, align 4
  6. @b = common global i32 0, align 4
  7. @e = common global i8 0, align 1
  8. @d = common global i32 0, align 4
  9. @c = common global i32 0, align 4
  10. @.str = private unnamed_addr constant [4 x i8] c"%d\0A\00", align 1
  11. ; Function Attrs: nounwind optsize uwtable
  12. ; CHECK-LABEL: foo
  13. define i32 @foo() {
  14. entry:
  15. %.pr = load i32, i32* @b, align 4
  16. %cmp10 = icmp slt i32 %.pr, 1
  17. br i1 %cmp10, label %for.cond1.preheader.lr.ph, label %entry.for.end9_crit_edge
  18. entry.for.end9_crit_edge: ; preds = %entry
  19. %.pre = load i32, i32* @c, align 4
  20. br label %for.end9
  21. for.cond1.preheader.lr.ph: ; preds = %entry
  22. %0 = load i32, i32* @a, align 4
  23. %tobool = icmp eq i32 %0, 0
  24. br i1 %tobool, label %for.cond1.preheader.for.cond1.preheader.split_crit_edge, label %return.loopexit.split
  25. for.cond1.preheader.for.cond1.preheader.split_crit_edge: ; preds = %for.cond1.preheader.lr.ph, %for.inc8
  26. %1 = phi i32 [ %inc, %for.inc8 ], [ %.pr, %for.cond1.preheader.lr.ph ]
  27. br label %if.end
  28. ; CHECK-LABEL: if.end
  29. if.end: ; preds = %if.end, %for.cond1.preheader.for.cond1.preheader.split_crit_edge
  30. ; CHECK: %lsr.iv = phi i32 [ %lsr.iv.next, %if.end ], [ 258, %for.cond1.preheader.for.cond1.preheader.split_crit_edge ]
  31. %indvars.iv = phi i32 [ 1, %for.cond1.preheader.for.cond1.preheader.split_crit_edge ], [ %indvars.iv.next, %if.end ]
  32. %2 = phi i8 [ 1, %for.cond1.preheader.for.cond1.preheader.split_crit_edge ], [ %dec, %if.end ]
  33. %conv7 = mul i32 %indvars.iv, 258
  34. %shl = and i32 %conv7, 510
  35. store i32 %shl, i32* @c, align 4
  36. ; CHECK: %lsr.iv.next = add nsw i32 %lsr.iv, -258
  37. %dec = add i8 %2, -1
  38. %cmp2 = icmp sgt i8 %dec, -1
  39. %indvars.iv.next = add i32 %indvars.iv, -1
  40. br i1 %cmp2, label %if.end, label %for.inc8
  41. for.inc8: ; preds = %if.end
  42. store i32 0, i32* @d, align 4
  43. %inc = add nsw i32 %1, 1
  44. store i32 %inc, i32* @b, align 4
  45. %cmp = icmp slt i32 %1, 0
  46. br i1 %cmp, label %for.cond1.preheader.for.cond1.preheader.split_crit_edge, label %for.cond.for.end9_crit_edge
  47. for.cond.for.end9_crit_edge: ; preds = %for.inc8
  48. store i8 %dec, i8* @e, align 1
  49. br label %for.end9
  50. for.end9: ; preds = %entry.for.end9_crit_edge, %for.cond.for.end9_crit_edge
  51. %3 = phi i32 [ %.pre, %entry.for.end9_crit_edge ], [ %shl, %for.cond.for.end9_crit_edge ]
  52. %call = tail call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i64 0, i64 0), i32 %3) #2
  53. br label %return
  54. return.loopexit.split: ; preds = %for.cond1.preheader.lr.ph
  55. store i8 1, i8* @e, align 1
  56. store i32 0, i32* @d, align 4
  57. br label %return
  58. return: ; preds = %return.loopexit.split, %for.end9
  59. %retval.0 = phi i32 [ 0, %for.end9 ], [ 1, %return.loopexit.split ]
  60. ret i32 %retval.0
  61. }
  62. ; Function Attrs: nounwind optsize
  63. declare i32 @printf(i8* nocapture readonly, ...)