| ; RUN: llc < %s | |
| ;; Date: May 28, 2003. | |
| ;; From: test/Programs/External/SPEC/CINT2000/254.gap.llvm.bc | |
| ;; Function: int %OpenOutput(sbyte* %filename.1) | |
| ;; | |
| ;; Error: A sequence of GEPs is folded incorrectly by llc during selection | |
| ;; causing an assertion about a dynamic casting error. | |
| ;; This code sequence was produced (correctly) by preselection | |
| ;; from a nested pair of ConstantExpr getelementptrs. | |
| ;; The code below is the output of preselection. | |
| ;; The original ConstantExprs are included in a comment. | |
| ;; | |
| ;; Cause: FoldGetElemChain() was inserting an extra leading 0 even though | |
| ;; the first instruction in the sequence contributes no indices. | |
| ;; The next instruction contributes a leading non-zero so another | |
| ;; zero should not be added before it! | |
| ;; | |
| %FileType = type { i32, [256 x i8], i32, i32, i32, i32 } | |
| @OutputFiles = external global [16 x %FileType] ; <[16 x %FileType]*> [#uses=1] | |
| @Output = internal global %FileType* null ; <%FileType**> [#uses=1] | |
| define internal i32 @OpenOutput(i8* %filename.1) { | |
| entry: | |
| %tmp.0 = load %FileType** @Output ; <%FileType*> [#uses=1] | |
| %tmp.4 = getelementptr %FileType* %tmp.0, i64 1 ; <%FileType*> [#uses=1] | |
| %addrOfGlobal = getelementptr [16 x %FileType]* @OutputFiles, i64 0 ; <[16 x %FileType]*> [#uses=1] | |
| %constantGEP = getelementptr [16 x %FileType]* %addrOfGlobal, i64 1 ; <[16 x %FileType]*> [#uses=1] | |
| %constantGEP.upgrd.1 = getelementptr [16 x %FileType]* %constantGEP, i64 0, i64 0 ; <%FileType*> [#uses=1] | |
| %tmp.10 = icmp eq %FileType* %tmp.4, %constantGEP.upgrd.1 ; <i1> [#uses=1] | |
| br i1 %tmp.10, label %return, label %endif.0 | |
| endif.0: ; preds = %entry | |
| ret i32 0 | |
| return: ; preds = %entry | |
| ret i32 1 | |
| } | |