Sink dag combine's post index load / store code that swap base ptr and index into...
[oota-llvm.git] / test / CodeGen / Generic / 2003-05-30-BadPreselectPhi.ll
index 7e6be13fdf2e05d84fc206aad03e04ffd696ff7e..f7c3e42dc4879305279cc541e48c9211f6754371 100644 (file)
@@ -1,4 +1,4 @@
-; RUN: llvm-as -f %s -o - | llc
+; RUN: llc < %s
 
 ;; Date:     May 28, 2003.
 ;; From:     test/Programs/SingleSource/richards_benchmark.c
@@ -8,53 +8,26 @@
 ;;           the Phi instead of in predecessor blocks.  This later
 ;;           causes llc to produces an invalid register <NULL VALUE>
 ;;           for the phi arguments.
-;;
-;; PreSelection Output:
-;; *** LLVM code after pre-selection for function handlerfn:
-;; 
-;; 
-;; %struct..task* %handlerfn(%struct..packet*) {
-;; ; <label>:0             ; No predecessors!
-;;         setne %struct..packet* %0, null         ; <bool>:0 [#uses=1]
-;;         br bool %0, label %1, label %2
-;; 
-;; ; <label>:1             ; preds = %0
-;;         br label %2
-;; 
-;; ; <label>:2             ; preds = %0, %1
-;;         %addrOfGlobal = getelementptr int* %v2, long 0          ; <int*> [#uses=1]
-;;         %addrOfGlobal1 = getelementptr int* %v1, long 0         ; <int*> [#uses=1]
-;;         phi int* [ %addrOfGlobal, %1 ], [ %addrOfGlobal1, %0 ]          ; <int*>:0 [#uses=1]
-;;         cast int* %0 to %struct..packet*                ; <%struct..packet*>:1 [#uses=1]
-;;         call void %append( %struct..packet* %0, %struct..packet* %1 )
-;;         ret %struct..task* null
-;; }
-;; llc: ../../../include/llvm/CodeGen/MachineInstr.h:294: int MachineOperand::getAllocatedRegNum() const: Assertion `hasAllocatedReg()' failed.
-;; 
-
 
-target endian = little
-target pointersize = 32
-       %struct..packet = type { %struct..packet*, int, int, int, [4 x sbyte] }
-       %struct..task = type { %struct..task*, int, int, %struct..packet*, int, %struct..task* (%struct..packet*)*, int, int }
-%v1 = external global int
-%v2 = external global int
+        %struct..packet = type { %struct..packet*, i32, i32, i32, [4 x i8] }
+        %struct..task = type { %struct..task*, i32, i32, %struct..packet*, i32, %struct..task* (%struct..packet*)*, i32, i32 }
+@v1 = external global i32               ; <i32*> [#uses=1]
+@v2 = external global i32               ; <i32*> [#uses=1]
 
-implementation   ; Functions:
+define %struct..task* @handlerfn(%struct..packet* %pkt.2) {
+entry:
+        %tmp.1 = icmp ne %struct..packet* %pkt.2, null          ; <i1> [#uses=1]
+        br i1 %tmp.1, label %cond_false, label %cond_continue
 
-%struct..task* %handlerfn(%struct..packet* %pkt.2) {
-entry:         ; No predecessors!
-       %tmp.1 = setne %struct..packet* %pkt.2, null
-       br bool %tmp.1, label %cond_false, label %cond_continue
+cond_false:             ; preds = %entry
+        br label %cond_continue
 
-cond_false:            ; preds = %entry
-       br label %cond_continue
-
-cond_continue:         ; preds = %entry, %cond_false
-       %mem_tmp.0 = phi int* [ %v2, %cond_false ], [ %v1, %entry ]
-       %tmp.12 = cast int* %mem_tmp.0 to %struct..packet*
-       call void %append( %struct..packet* %pkt.2, %struct..packet* %tmp.12 )
-       ret %struct..task* null
+cond_continue:          ; preds = %cond_false, %entry
+        %mem_tmp.0 = phi i32* [ @v2, %cond_false ], [ @v1, %entry ]             ; <i32*> [#uses=1]
+        %tmp.12 = bitcast i32* %mem_tmp.0 to %struct..packet*           ; <%struct..packet*> [#uses=1]
+        call void @append( %struct..packet* %pkt.2, %struct..packet* %tmp.12 )
+        ret %struct..task* null
 }
 
-declare void %append(%struct..packet*, %struct..packet*)
+declare void @append(%struct..packet*, %struct..packet*)
+