simple.ll 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. ; RUN: opt < %s -bounds-checking -S | FileCheck %s
  2. target datalayout = "e-p:64:64:64-p1:16:16:16-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-S128"
  3. @.str = private constant [8 x i8] c"abcdefg\00" ; <[8 x i8]*>
  4. @.str_as1 = private addrspace(1) constant [8 x i8] c"abcdefg\00" ; <[8 x i8] addrspace(1)*>
  5. declare noalias i8* @malloc(i64) nounwind
  6. declare noalias i8* @calloc(i64, i64) nounwind
  7. declare noalias i8* @realloc(i8* nocapture, i64) nounwind
  8. ; CHECK: @f1
  9. define void @f1() nounwind {
  10. %1 = tail call i8* @malloc(i64 32)
  11. %2 = bitcast i8* %1 to i32*
  12. %idx = getelementptr inbounds i32, i32* %2, i64 2
  13. ; CHECK-NOT: trap
  14. store i32 3, i32* %idx, align 4
  15. ret void
  16. }
  17. ; CHECK: @f2
  18. define void @f2() nounwind {
  19. %1 = tail call i8* @malloc(i64 32)
  20. %2 = bitcast i8* %1 to i32*
  21. %idx = getelementptr inbounds i32, i32* %2, i64 8
  22. ; CHECK: trap
  23. store i32 3, i32* %idx, align 4
  24. ret void
  25. }
  26. ; CHECK: @f3
  27. define void @f3(i64 %x) nounwind {
  28. %1 = tail call i8* @calloc(i64 4, i64 %x)
  29. %2 = bitcast i8* %1 to i32*
  30. %idx = getelementptr inbounds i32, i32* %2, i64 8
  31. ; CHECK: mul i64 4, %
  32. ; CHECK: sub i64 {{.*}}, 32
  33. ; CHECK-NEXT: icmp ult i64 {{.*}}, 32
  34. ; CHECK-NEXT: icmp ult i64 {{.*}}, 4
  35. ; CHECK-NEXT: or i1
  36. ; CHECK: trap
  37. store i32 3, i32* %idx, align 4
  38. ret void
  39. }
  40. ; CHECK: @f4
  41. define void @f4(i64 %x) nounwind {
  42. %1 = tail call i8* @realloc(i8* null, i64 %x) nounwind
  43. %2 = bitcast i8* %1 to i32*
  44. %idx = getelementptr inbounds i32, i32* %2, i64 8
  45. ; CHECK: trap
  46. %3 = load i32, i32* %idx, align 4
  47. ret void
  48. }
  49. ; CHECK: @f5
  50. define void @f5(i64 %x) nounwind {
  51. %idx = getelementptr inbounds [8 x i8], [8 x i8]* @.str, i64 0, i64 %x
  52. ; CHECK: trap
  53. %1 = load i8, i8* %idx, align 4
  54. ret void
  55. }
  56. define void @f5_as1(i64 %x) nounwind {
  57. ; CHECK: @f5_as1
  58. %idx = getelementptr inbounds [8 x i8], [8 x i8] addrspace(1)* @.str_as1, i64 0, i64 %x
  59. ; CHECK: sub i16
  60. ; CHECK: icmp ult i16
  61. ; CHECK: trap
  62. %1 = load i8, i8 addrspace(1)* %idx, align 4
  63. ret void
  64. }
  65. ; CHECK: @f6
  66. define void @f6(i64 %x) nounwind {
  67. %1 = alloca i128
  68. ; CHECK-NOT: trap
  69. %2 = load i128, i128* %1, align 4
  70. ret void
  71. }
  72. ; CHECK: @f7
  73. define void @f7(i64 %x) nounwind {
  74. %1 = alloca i128, i64 %x
  75. ; CHECK: mul i64 16,
  76. ; CHECK: trap
  77. %2 = load i128, i128* %1, align 4
  78. ret void
  79. }
  80. ; CHECK: @f8
  81. define void @f8() nounwind {
  82. %1 = alloca i128
  83. %2 = alloca i128
  84. %3 = select i1 undef, i128* %1, i128* %2
  85. ; CHECK-NOT: trap
  86. %4 = load i128, i128* %3, align 4
  87. ret void
  88. }
  89. ; CHECK: @f9
  90. define void @f9(i128* %arg) nounwind {
  91. %1 = alloca i128
  92. %2 = select i1 undef, i128* %arg, i128* %1
  93. ; CHECK-NOT: trap
  94. %3 = load i128, i128* %2, align 4
  95. ret void
  96. }
  97. ; CHECK: @f10
  98. define void @f10(i64 %x, i64 %y) nounwind {
  99. %1 = alloca i128, i64 %x
  100. %2 = alloca i128, i64 %y
  101. %3 = select i1 undef, i128* %1, i128* %2
  102. ; CHECK: select
  103. ; CHECK: select
  104. ; CHECK: trap
  105. %4 = load i128, i128* %3, align 4
  106. ret void
  107. }
  108. ; CHECK: @f11
  109. define void @f11(i128* byval %x) nounwind {
  110. %1 = bitcast i128* %x to i8*
  111. %2 = getelementptr inbounds i8, i8* %1, i64 16
  112. ; CHECK: br label
  113. %3 = load i8, i8* %2, align 4
  114. ret void
  115. }
  116. ; CHECK: @f11_as1
  117. define void @f11_as1(i128 addrspace(1)* byval %x) nounwind {
  118. %1 = bitcast i128 addrspace(1)* %x to i8 addrspace(1)*
  119. %2 = getelementptr inbounds i8, i8 addrspace(1)* %1, i16 16
  120. ; CHECK: br label
  121. %3 = load i8, i8 addrspace(1)* %2, align 4
  122. ret void
  123. }
  124. ; CHECK: @f12
  125. define i64 @f12(i64 %x, i64 %y) nounwind {
  126. %1 = tail call i8* @calloc(i64 1, i64 %x)
  127. ; CHECK: mul i64 %y, 8
  128. %2 = bitcast i8* %1 to i64*
  129. %3 = getelementptr inbounds i64, i64* %2, i64 %y
  130. %4 = load i64, i64* %3, align 8
  131. ret i64 %4
  132. }
  133. ; PR17402
  134. ; CHECK-LABEL: @f13
  135. define void @f13() nounwind {
  136. entry:
  137. br label %alive
  138. dead:
  139. ; Self-refential GEPs can occur in dead code.
  140. %incdec.ptr = getelementptr inbounds i32, i32* %incdec.ptr, i64 1
  141. ; CHECK: %incdec.ptr = getelementptr inbounds i32, i32* %incdec.ptr
  142. %l = load i32, i32* %incdec.ptr
  143. br label %alive
  144. alive:
  145. ret void
  146. }