1; RUN: opt %loadPolly -polly-detect -analyze < %s \ 2; RUN: | FileCheck %s -check-prefix=DETECT 3; RUN: opt %loadPolly -polly-scops -analyze < %s | FileCheck %s 4; 5; DETECT: Valid Region for Scop: bb124 => bb176 6; 7; A valid Scop would print the list of it's statements, we check that we do not 8; see that list. 9; 10; CHECK-NOT: Statements 11 12target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128" 13target triple = "aarch64--linux-android" 14 15%0 = type { i8*, i64, i64, i64, i64, i64, i64 } 16 17define void @_Z1fR1SS0_Ph(%0* nocapture readonly dereferenceable(56) %arg, %0* nocapture readonly dereferenceable(56) %arg1, i8* nocapture readonly %arg2) { 18bb: 19 %tmp = getelementptr inbounds %0, %0* %arg1, i64 0, i32 1 20 %tmp3 = getelementptr inbounds %0, %0* %arg, i64 0, i32 0 21 %tmp4 = load i8*, i8** %tmp3, align 8 22 %tmp5 = getelementptr inbounds %0, %0* %arg, i64 0, i32 4 23 %tmp6 = load i64, i64* %tmp5, align 8 24 %tmp7 = getelementptr inbounds %0, %0* %arg, i64 0, i32 1 25 %tmp8 = load i64, i64* %tmp7, align 8 26 %tmp9 = mul i64 %tmp8, %tmp6 27 %tmp10 = getelementptr inbounds i8, i8* %tmp4, i64 %tmp9 28 %tmp11 = getelementptr inbounds %0, %0* %arg, i64 0, i32 3 29 %tmp12 = load i64, i64* %tmp11, align 8 30 %tmp13 = getelementptr inbounds i8, i8* %tmp10, i64 %tmp12 31 %tmp14 = getelementptr inbounds %0, %0* %arg, i64 0, i32 6 32 %tmp15 = load i64, i64* %tmp14, align 8 33 %tmp16 = add i64 %tmp15, 1 34 %tmp17 = icmp eq i64 %tmp16, %tmp6 35 br i1 %tmp17, label %bb51, label %bb18 36 37bb18: ; preds = %bb 38 %tmp19 = getelementptr inbounds %0, %0* %arg, i64 0, i32 2 39 %tmp20 = load i64, i64* %tmp19, align 8 40 %tmp21 = mul i64 %tmp20, %tmp8 41 %tmp22 = getelementptr inbounds i8, i8* %tmp13, i64 %tmp21 42 %tmp23 = getelementptr inbounds i8, i8* %tmp22, i64 %tmp9 43 %tmp24 = getelementptr inbounds i8, i8* %tmp23, i64 %tmp12 44 %tmp25 = bitcast %0* %arg1 to i16** 45 %tmp26 = load i16*, i16** %tmp25, align 8 46 %tmp27 = load i64, i64* %tmp, align 8 47 %tmp28 = getelementptr inbounds %0, %0* %arg1, i64 0, i32 4 48 %tmp29 = load i64, i64* %tmp28, align 8 49 %tmp30 = mul i64 %tmp27, %tmp29 50 %tmp31 = getelementptr inbounds i16, i16* %tmp26, i64 %tmp30 51 %tmp32 = getelementptr inbounds %0, %0* %arg1, i64 0, i32 3 52 %tmp33 = load i64, i64* %tmp32, align 8 53 %tmp34 = getelementptr inbounds i16, i16* %tmp31, i64 %tmp33 54 %tmp35 = getelementptr inbounds %0, %0* %arg, i64 0, i32 5 55 %tmp36 = load i64, i64* %tmp35, align 8 56 br label %bb37 57 58bb37: ; preds = %bb57, %bb18 59 %tmp38 = phi i64 [ %tmp6, %bb18 ], [ %tmp58, %bb57 ] 60 %tmp39 = phi i64 [ %tmp15, %bb18 ], [ %tmp59, %bb57 ] 61 %tmp40 = phi i64 [ %tmp27, %bb18 ], [ %tmp60, %bb57 ] 62 %tmp41 = phi i64 [ %tmp8, %bb18 ], [ %tmp61, %bb57 ] 63 %tmp42 = phi i64 [ %tmp12, %bb18 ], [ %tmp62, %bb57 ] 64 %tmp43 = phi i64 [ %tmp36, %bb18 ], [ %tmp63, %bb57 ] 65 %tmp44 = phi i16* [ %tmp34, %bb18 ], [ %tmp69, %bb57 ] 66 %tmp45 = phi i8* [ %tmp13, %bb18 ], [ %tmp64, %bb57 ] 67 %tmp46 = phi i8* [ %tmp24, %bb18 ], [ %tmp68, %bb57 ] 68 %tmp47 = phi i64 [ 0, %bb18 ], [ %tmp70, %bb57 ] 69 %tmp48 = add i64 %tmp43, 1 70 %tmp49 = sub i64 %tmp48, %tmp42 71 %tmp50 = icmp eq i64 %tmp49, 0 72 br i1 %tmp50, label %bb57, label %bb74 73 74bb51: ; preds = %bb57, %bb 75 ret void 76 77bb52: ; preds = %bb176 78 %tmp53 = load i64, i64* %tmp7, align 8 79 %tmp54 = load i64, i64* %tmp, align 8 80 %tmp55 = load i64, i64* %tmp14, align 8 81 %tmp56 = load i64, i64* %tmp5, align 8 82 br label %bb57 83 84bb57: ; preds = %bb52, %bb37 85 %tmp58 = phi i64 [ %tmp56, %bb52 ], [ %tmp38, %bb37 ] 86 %tmp59 = phi i64 [ %tmp55, %bb52 ], [ %tmp39, %bb37 ] 87 %tmp60 = phi i64 [ %tmp54, %bb52 ], [ %tmp40, %bb37 ] 88 %tmp61 = phi i64 [ %tmp53, %bb52 ], [ %tmp41, %bb37 ] 89 %tmp62 = phi i64 [ %tmp179, %bb52 ], [ %tmp42, %bb37 ] 90 %tmp63 = phi i64 [ %tmp178, %bb52 ], [ %tmp43, %bb37 ] 91 %tmp64 = getelementptr inbounds i8, i8* %tmp45, i64 %tmp61 92 %tmp65 = and i64 %tmp47, 1 93 %tmp66 = icmp eq i64 %tmp65, 0 94 %tmp67 = getelementptr inbounds i8, i8* %tmp46, i64 %tmp61 95 %tmp68 = select i1 %tmp66, i8* %tmp46, i8* %tmp67 96 %tmp69 = getelementptr inbounds i16, i16* %tmp44, i64 %tmp60 97 %tmp70 = add i64 %tmp47, 1 98 %tmp71 = add i64 %tmp59, 1 99 %tmp72 = sub i64 %tmp71, %tmp58 100 %tmp73 = icmp ult i64 %tmp70, %tmp72 101 br i1 %tmp73, label %bb37, label %bb51 102 103bb74: ; preds = %bb176, %bb37 104 %tmp75 = phi i64 [ %tmp181, %bb176 ], [ %tmp49, %bb37 ] 105 %tmp76 = phi i64 [ %tmp177, %bb176 ], [ 0, %bb37 ] 106 %tmp77 = getelementptr inbounds i8, i8* %tmp45, i64 %tmp76 107 %tmp78 = load i8, i8* %tmp77, align 1 108 %tmp79 = zext i8 %tmp78 to i32 109 %tmp80 = or i64 %tmp76, 1 110 %tmp81 = getelementptr inbounds i8, i8* %tmp45, i64 %tmp80 111 %tmp82 = load i8, i8* %tmp81, align 1 112 %tmp83 = zext i8 %tmp82 to i32 113 %tmp84 = getelementptr inbounds i8, i8* %tmp46, i64 %tmp76 114 %tmp85 = load i8, i8* %tmp84, align 1 115 %tmp86 = zext i8 %tmp85 to i32 116 %tmp87 = getelementptr inbounds i8, i8* %tmp46, i64 %tmp80 117 %tmp88 = load i8, i8* %tmp87, align 1 118 %tmp89 = zext i8 %tmp88 to i32 119 %tmp90 = mul nuw nsw i32 %tmp86, 517 120 %tmp91 = add nsw i32 %tmp90, -66176 121 %tmp92 = sub nsw i32 128, %tmp86 122 %tmp93 = mul nsw i32 %tmp92, 100 123 %tmp94 = sub nsw i32 128, %tmp89 124 %tmp95 = mul nsw i32 %tmp94, 208 125 %tmp96 = mul nuw nsw i32 %tmp89, 409 126 %tmp97 = add nsw i32 %tmp96, -52352 127 %tmp98 = mul nuw nsw i32 %tmp79, 298 128 %tmp99 = add nsw i32 %tmp98, -4768 129 %tmp100 = add nsw i32 %tmp91, %tmp99 130 %tmp101 = sdiv i32 %tmp100, 256 131 %tmp102 = tail call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 %tmp99, i32 %tmp95) 132 %tmp103 = extractvalue { i32, i1 } %tmp102, 1 133 br i1 %tmp103, label %bb104, label %bb105 134 135bb104: ; preds = %bb120, %bb109, %bb105, %bb74 136 tail call void @llvm.trap() 137 unreachable 138 139bb105: ; preds = %bb74 140 %tmp106 = extractvalue { i32, i1 } %tmp102, 0 141 %tmp107 = tail call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 %tmp106, i32 %tmp93) 142 %tmp108 = extractvalue { i32, i1 } %tmp107, 1 143 br i1 %tmp108, label %bb104, label %bb109 144 145bb109: ; preds = %bb105 146 %tmp110 = extractvalue { i32, i1 } %tmp107, 0 147 %tmp111 = sdiv i32 %tmp110, 256 148 %tmp112 = add nsw i32 %tmp97, %tmp99 149 %tmp113 = sdiv i32 %tmp112, 256 150 %tmp114 = mul nuw nsw i32 %tmp83, 298 151 %tmp115 = add nsw i32 %tmp114, -4768 152 %tmp116 = add nsw i32 %tmp91, %tmp115 153 %tmp117 = sdiv i32 %tmp116, 256 154 %tmp118 = tail call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 %tmp115, i32 %tmp95) 155 %tmp119 = extractvalue { i32, i1 } %tmp118, 1 156 br i1 %tmp119, label %bb104, label %bb120 157 158bb120: ; preds = %bb109 159 %tmp121 = extractvalue { i32, i1 } %tmp118, 0 160 %tmp122 = tail call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 %tmp121, i32 %tmp93) 161 %tmp123 = extractvalue { i32, i1 } %tmp122, 1 162 br i1 %tmp123, label %bb104, label %bb124 163 164bb124: ; preds = %bb120 165 %tmp125 = sext i32 %tmp101 to i64 166 %tmp126 = getelementptr inbounds i8, i8* %arg2, i64 %tmp125 167 %tmp127 = load i8, i8* %tmp126, align 1 168 %tmp128 = zext i8 %tmp127 to i32 169 %tmp129 = lshr i32 %tmp128, 3 170 %tmp130 = shl nuw nsw i32 %tmp129, 11 171 %tmp131 = sext i32 %tmp111 to i64 172 %tmp132 = getelementptr inbounds i8, i8* %arg2, i64 %tmp131 173 %tmp133 = load i8, i8* %tmp132, align 1 174 %tmp134 = zext i8 %tmp133 to i32 175 %tmp135 = lshr i32 %tmp134, 2 176 %tmp136 = shl nuw nsw i32 %tmp135, 5 177 %tmp137 = or i32 %tmp136, %tmp130 178 %tmp138 = sext i32 %tmp113 to i64 179 %tmp139 = getelementptr inbounds i8, i8* %arg2, i64 %tmp138 180 %tmp140 = load i8, i8* %tmp139, align 1 181 %tmp141 = zext i8 %tmp140 to i32 182 %tmp142 = lshr i32 %tmp141, 3 183 %tmp143 = or i32 %tmp137, %tmp142 184 %tmp144 = icmp ult i64 %tmp80, %tmp75 185 br i1 %tmp144, label %bb145, label %bb173 186 187bb145: ; preds = %bb124 188 %tmp146 = add nsw i32 %tmp97, %tmp115 189 %tmp147 = sdiv i32 %tmp146, 256 190 %tmp148 = sext i32 %tmp147 to i64 191 %tmp149 = getelementptr inbounds i8, i8* %arg2, i64 %tmp148 192 %tmp150 = load i8, i8* %tmp149, align 1 193 %tmp151 = extractvalue { i32, i1 } %tmp122, 0 194 %tmp152 = sdiv i32 %tmp151, 256 195 %tmp153 = sext i32 %tmp152 to i64 196 %tmp154 = getelementptr inbounds i8, i8* %arg2, i64 %tmp153 197 %tmp155 = load i8, i8* %tmp154, align 1 198 %tmp156 = sext i32 %tmp117 to i64 199 %tmp157 = getelementptr inbounds i8, i8* %arg2, i64 %tmp156 200 %tmp158 = load i8, i8* %tmp157, align 1 201 %tmp159 = zext i8 %tmp158 to i32 202 %tmp160 = lshr i32 %tmp159, 3 203 %tmp161 = shl nuw nsw i32 %tmp160, 11 204 %tmp162 = zext i8 %tmp155 to i32 205 %tmp163 = lshr i32 %tmp162, 2 206 %tmp164 = shl nuw nsw i32 %tmp163, 5 207 %tmp165 = zext i8 %tmp150 to i32 208 %tmp166 = lshr i32 %tmp165, 3 209 %tmp167 = or i32 %tmp164, %tmp166 210 %tmp168 = or i32 %tmp167, %tmp161 211 %tmp169 = shl nuw i32 %tmp168, 16 212 %tmp170 = or i32 %tmp169, %tmp143 213 %tmp171 = getelementptr inbounds i16, i16* %tmp44, i64 %tmp76 214 %tmp172 = bitcast i16* %tmp171 to i32* 215 store i32 %tmp170, i32* %tmp172, align 4 216 br label %bb176 217 218bb173: ; preds = %bb124 219 %tmp174 = trunc i32 %tmp143 to i16 220 %tmp175 = getelementptr inbounds i16, i16* %tmp44, i64 %tmp76 221 store i16 %tmp174, i16* %tmp175, align 2 222 br label %bb176 223 224bb176: ; preds = %bb173, %bb145 225 %tmp177 = add i64 %tmp76, 2 226 %tmp178 = load i64, i64* %tmp35, align 8 227 %tmp179 = load i64, i64* %tmp11, align 8 228 %tmp180 = add i64 %tmp178, 1 229 %tmp181 = sub i64 %tmp180, %tmp179 230 %tmp182 = icmp ult i64 %tmp177, %tmp181 231 br i1 %tmp182, label %bb74, label %bb52 232} 233 234; Function Attrs: noreturn nounwind 235declare void @llvm.trap() #0 236 237; Function Attrs: nounwind readnone 238declare { i32, i1 } @llvm.sadd.with.overflow.i32(i32, i32) #1 239 240attributes #0 = { noreturn nounwind } 241attributes #1 = { nounwind readnone } 242