Home | History | Annotate | Download | only in LoopStrengthReduce
      1 ; RUN: opt < %s -loop-reduce -disable-output
      2 ; LSR should not crash on this.
      3 
      4 define fastcc void @loadloop() {
      5 entry:
      6 	switch i8 0, label %shortcirc_next [
      7 		 i8 32, label %loopexit.2
      8 		 i8 59, label %loopexit.2
      9 	]
     10 shortcirc_next:		; preds = %no_exit.2, %entry
     11 	%indvar37 = phi i32 [ 0, %entry ], [ %indvar.next38, %no_exit.2 ]		; <i32> [#uses=3]
     12 	%gep.upgrd.1 = zext i32 %indvar37 to i64		; <i64> [#uses=1]
     13 	%wp.2.4 = getelementptr i8, i8* null, i64 %gep.upgrd.1		; <i8*> [#uses=1]
     14 	br i1 false, label %loopexit.2, label %no_exit.2
     15 no_exit.2:		; preds = %shortcirc_next
     16 	%wp.2.4.rec = bitcast i32 %indvar37 to i32		; <i32> [#uses=1]
     17 	%inc.1.rec = add i32 %wp.2.4.rec, 1		; <i32> [#uses=1]
     18 	%inc.1 = getelementptr i8, i8* null, i32 %inc.1.rec		; <i8*> [#uses=2]
     19 	%indvar.next38 = add i32 %indvar37, 1		; <i32> [#uses=1]
     20 	switch i8 0, label %shortcirc_next [
     21 		 i8 32, label %loopexit.2
     22 		 i8 59, label %loopexit.2
     23 	]
     24 loopexit.2:		; preds = %no_exit.2, %no_exit.2, %shortcirc_next, %entry, %entry
     25 	%wp.2.7 = phi i8* [ null, %entry ], [ null, %entry ], [ %wp.2.4, %shortcirc_next ], [ %inc.1, %no_exit.2 ], [ %inc.1, %no_exit.2 ]		; <i8*> [#uses=0]
     26 	ret void
     27 }
     28 
     29