2011-11-01-lftrptr.ll 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. ; RUN: opt < %s -indvars -S "-default-data-layout=e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64" | FileCheck %s
  2. ; RUN: opt < %s -indvars -S "-default-data-layout=e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128-n8:16:32" | FileCheck %s
  3. ;
  4. ; PR11279: Assertion !IVLimit->getType()->isPointerTy()
  5. ;
  6. ; Test LinearFunctionTestReplace of a pointer-type loop counter. Note
  7. ; that BECount may or may not be a pointer type. A pointer type
  8. ; BECount doesn't really make sense, but that's what falls out of
  9. ; SCEV. Since it's an i8*, it has unit stride so we never adjust the
  10. ; SCEV expression in a way that would convert it to an integer type.
  11. ; CHECK-LABEL: @testnullptrptr(
  12. ; CHECK: loop:
  13. ; CHECK: icmp ne
  14. define i8 @testnullptrptr(i8* %buf, i8* %end) nounwind {
  15. br label %loopguard
  16. loopguard:
  17. %guard = icmp ult i8* null, %end
  18. br i1 %guard, label %preheader, label %exit
  19. preheader:
  20. br label %loop
  21. loop:
  22. %p.01.us.us = phi i8* [ null, %preheader ], [ %gep, %loop ]
  23. %s = phi i8 [0, %preheader], [%snext, %loop]
  24. %gep = getelementptr inbounds i8, i8* %p.01.us.us, i64 1
  25. %snext = load i8, i8* %gep
  26. %cmp = icmp ult i8* %gep, %end
  27. br i1 %cmp, label %loop, label %exit
  28. exit:
  29. %ret = phi i8 [0, %loopguard], [%snext, %loop]
  30. ret i8 %ret
  31. }
  32. ; CHECK-LABEL: @testptrptr(
  33. ; CHECK: loop:
  34. ; CHECK: icmp ne
  35. define i8 @testptrptr(i8* %buf, i8* %end) nounwind {
  36. br label %loopguard
  37. loopguard:
  38. %guard = icmp ult i8* %buf, %end
  39. br i1 %guard, label %preheader, label %exit
  40. preheader:
  41. br label %loop
  42. loop:
  43. %p.01.us.us = phi i8* [ %buf, %preheader ], [ %gep, %loop ]
  44. %s = phi i8 [0, %preheader], [%snext, %loop]
  45. %gep = getelementptr inbounds i8, i8* %p.01.us.us, i64 1
  46. %snext = load i8, i8* %gep
  47. %cmp = icmp ult i8* %gep, %end
  48. br i1 %cmp, label %loop, label %exit
  49. exit:
  50. %ret = phi i8 [0, %loopguard], [%snext, %loop]
  51. ret i8 %ret
  52. }
  53. ; CHECK-LABEL: @testnullptrint(
  54. ; CHECK: loop:
  55. ; CHECK: icmp ne
  56. define i8 @testnullptrint(i8* %buf, i8* %end) nounwind {
  57. br label %loopguard
  58. loopguard:
  59. %bi = ptrtoint i8* %buf to i32
  60. %ei = ptrtoint i8* %end to i32
  61. %cnt = sub i32 %ei, %bi
  62. %guard = icmp ult i32 0, %cnt
  63. br i1 %guard, label %preheader, label %exit
  64. preheader:
  65. br label %loop
  66. loop:
  67. %p.01.us.us = phi i8* [ null, %preheader ], [ %gep, %loop ]
  68. %iv = phi i32 [ 0, %preheader ], [ %ivnext, %loop ]
  69. %s = phi i8 [0, %preheader], [%snext, %loop]
  70. %gep = getelementptr inbounds i8, i8* %p.01.us.us, i64 1
  71. %snext = load i8, i8* %gep
  72. %ivnext = add i32 %iv, 1
  73. %cmp = icmp ult i32 %ivnext, %cnt
  74. br i1 %cmp, label %loop, label %exit
  75. exit:
  76. %ret = phi i8 [0, %loopguard], [%snext, %loop]
  77. ret i8 %ret
  78. }
  79. ; CHECK-LABEL: @testptrint(
  80. ; CHECK: loop:
  81. ; CHECK: icmp ne
  82. define i8 @testptrint(i8* %buf, i8* %end) nounwind {
  83. br label %loopguard
  84. loopguard:
  85. %bi = ptrtoint i8* %buf to i32
  86. %ei = ptrtoint i8* %end to i32
  87. %cnt = sub i32 %ei, %bi
  88. %guard = icmp ult i32 %bi, %cnt
  89. br i1 %guard, label %preheader, label %exit
  90. preheader:
  91. br label %loop
  92. loop:
  93. %p.01.us.us = phi i8* [ %buf, %preheader ], [ %gep, %loop ]
  94. %iv = phi i32 [ %bi, %preheader ], [ %ivnext, %loop ]
  95. %s = phi i8 [0, %preheader], [%snext, %loop]
  96. %gep = getelementptr inbounds i8, i8* %p.01.us.us, i64 1
  97. %snext = load i8, i8* %gep
  98. %ivnext = add i32 %iv, 1
  99. %cmp = icmp ult i32 %ivnext, %cnt
  100. br i1 %cmp, label %loop, label %exit
  101. exit:
  102. %ret = phi i8 [0, %loopguard], [%snext, %loop]
  103. ret i8 %ret
  104. }
  105. ; IV and BECount have two different pointer types here.
  106. define void @testnullptr([512 x i8]* %base) nounwind {
  107. entry:
  108. %add.ptr1603 = getelementptr [512 x i8], [512 x i8]* %base, i64 0, i64 512
  109. br label %preheader
  110. preheader:
  111. %cmp1604192 = icmp ult i8* undef, %add.ptr1603
  112. br i1 %cmp1604192, label %for.body, label %for.end1609
  113. for.body:
  114. %r.17193 = phi i8* [ %incdec.ptr1608, %for.body ], [ null, %preheader ]
  115. %incdec.ptr1608 = getelementptr i8, i8* %r.17193, i64 1
  116. %cmp1604 = icmp ult i8* %incdec.ptr1608, %add.ptr1603
  117. br i1 %cmp1604, label %for.body, label %for.end1609
  118. for.end1609:
  119. unreachable
  120. }