Evan Cheng | 87faa1f | 2009-07-20 21:46:42 +0000 | [diff] [blame^] | 1 | ; RUN: llvm-as < %s | llc -mtriple=armv6-apple-darwin10 -mattr=+vfp2 | grep fcmpezd | count 13 |
| 2 | |
| 3 | %struct.EDGE_PAIR = type { %struct.edge_rec*, %struct.edge_rec* } |
| 4 | %struct.VEC2 = type { double, double, double } |
| 5 | %struct.VERTEX = type { %struct.VEC2, %struct.VERTEX*, %struct.VERTEX* } |
| 6 | %struct.edge_rec = type { %struct.VERTEX*, %struct.edge_rec*, i32, i8* } |
| 7 | @avail_edge = internal global %struct.edge_rec* null ; <%struct.edge_rec**> [#uses=6] |
| 8 | @_2E_str7 = internal constant [21 x i8] c"ERROR: Only 1 point!\00", section "__TEXT,__cstring,cstring_literals", align 1 ; <[21 x i8]*> [#uses=1] |
| 9 | @llvm.used = appending global [1 x i8*] [i8* bitcast (void (%struct.EDGE_PAIR*, %struct.VERTEX*, %struct.VERTEX*)* @build_delaunay to i8*)], section "llvm.metadata" ; <[1 x i8*]*> [#uses=0] |
| 10 | |
| 11 | define arm_apcscc void @build_delaunay(%struct.EDGE_PAIR* noalias nocapture sret %agg.result, %struct.VERTEX* %tree, %struct.VERTEX* %extra) nounwind { |
| 12 | entry: |
| 13 | %delright = alloca %struct.EDGE_PAIR, align 8 ; <%struct.EDGE_PAIR*> [#uses=3] |
| 14 | %delleft = alloca %struct.EDGE_PAIR, align 8 ; <%struct.EDGE_PAIR*> [#uses=3] |
| 15 | %0 = icmp eq %struct.VERTEX* %tree, null ; <i1> [#uses=1] |
| 16 | br i1 %0, label %bb8, label %bb |
| 17 | |
| 18 | bb: ; preds = %entry |
| 19 | %1 = getelementptr %struct.VERTEX* %tree, i32 0, i32 2 ; <%struct.VERTEX**> [#uses=1] |
| 20 | %2 = load %struct.VERTEX** %1, align 4 ; <%struct.VERTEX*> [#uses=2] |
| 21 | %3 = icmp eq %struct.VERTEX* %2, null ; <i1> [#uses=1] |
| 22 | br i1 %3, label %bb7, label %bb1.i |
| 23 | |
| 24 | bb1.i: ; preds = %bb1.i, %bb |
| 25 | %tree_addr.0.i = phi %struct.VERTEX* [ %5, %bb1.i ], [ %tree, %bb ] ; <%struct.VERTEX*> [#uses=3] |
| 26 | %4 = getelementptr %struct.VERTEX* %tree_addr.0.i, i32 0, i32 1 ; <%struct.VERTEX**> [#uses=1] |
| 27 | %5 = load %struct.VERTEX** %4, align 4 ; <%struct.VERTEX*> [#uses=2] |
| 28 | %6 = icmp eq %struct.VERTEX* %5, null ; <i1> [#uses=1] |
| 29 | br i1 %6, label %get_low.exit, label %bb1.i |
| 30 | |
| 31 | get_low.exit: ; preds = %bb1.i |
| 32 | call arm_apcscc void @build_delaunay(%struct.EDGE_PAIR* noalias sret %delright, %struct.VERTEX* %2, %struct.VERTEX* %extra) nounwind |
| 33 | %7 = getelementptr %struct.VERTEX* %tree, i32 0, i32 1 ; <%struct.VERTEX**> [#uses=1] |
| 34 | %8 = load %struct.VERTEX** %7, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 35 | call arm_apcscc void @build_delaunay(%struct.EDGE_PAIR* noalias sret %delleft, %struct.VERTEX* %8, %struct.VERTEX* %tree) nounwind |
| 36 | %9 = getelementptr %struct.EDGE_PAIR* %delleft, i32 0, i32 0 ; <%struct.edge_rec**> [#uses=1] |
| 37 | %10 = load %struct.edge_rec** %9, align 8 ; <%struct.edge_rec*> [#uses=2] |
| 38 | %11 = getelementptr %struct.EDGE_PAIR* %delleft, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 39 | %12 = load %struct.edge_rec** %11, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 40 | %13 = getelementptr %struct.EDGE_PAIR* %delright, i32 0, i32 0 ; <%struct.edge_rec**> [#uses=1] |
| 41 | %14 = load %struct.edge_rec** %13, align 8 ; <%struct.edge_rec*> [#uses=1] |
| 42 | %15 = getelementptr %struct.EDGE_PAIR* %delright, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 43 | %16 = load %struct.edge_rec** %15, align 4 ; <%struct.edge_rec*> [#uses=2] |
| 44 | br label %bb.i |
| 45 | |
| 46 | bb.i: ; preds = %bb4.i, %get_low.exit |
| 47 | %rdi_addr.0.i = phi %struct.edge_rec* [ %14, %get_low.exit ], [ %72, %bb4.i ] ; <%struct.edge_rec*> [#uses=2] |
| 48 | %ldi_addr.1.i = phi %struct.edge_rec* [ %12, %get_low.exit ], [ %ldi_addr.0.i, %bb4.i ] ; <%struct.edge_rec*> [#uses=3] |
| 49 | %17 = getelementptr %struct.edge_rec* %rdi_addr.0.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 50 | %18 = load %struct.VERTEX** %17, align 4 ; <%struct.VERTEX*> [#uses=3] |
| 51 | %19 = ptrtoint %struct.edge_rec* %ldi_addr.1.i to i32 ; <i32> [#uses=1] |
| 52 | %20 = getelementptr %struct.VERTEX* %18, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 53 | %21 = load double* %20, align 4 ; <double> [#uses=3] |
| 54 | %22 = getelementptr %struct.VERTEX* %18, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 55 | %23 = load double* %22, align 4 ; <double> [#uses=3] |
| 56 | br label %bb2.i |
| 57 | |
| 58 | bb1.i1: ; preds = %bb2.i |
| 59 | %24 = ptrtoint %struct.edge_rec* %ldi_addr.0.i to i32 ; <i32> [#uses=2] |
| 60 | %25 = add i32 %24, 48 ; <i32> [#uses=1] |
| 61 | %26 = and i32 %25, 63 ; <i32> [#uses=1] |
| 62 | %27 = and i32 %24, -64 ; <i32> [#uses=1] |
| 63 | %28 = or i32 %26, %27 ; <i32> [#uses=1] |
| 64 | %29 = inttoptr i32 %28 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 65 | %30 = getelementptr %struct.edge_rec* %29, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 66 | %31 = load %struct.edge_rec** %30, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 67 | %32 = ptrtoint %struct.edge_rec* %31 to i32 ; <i32> [#uses=2] |
| 68 | %33 = add i32 %32, 16 ; <i32> [#uses=1] |
| 69 | %34 = and i32 %33, 63 ; <i32> [#uses=1] |
| 70 | %35 = and i32 %32, -64 ; <i32> [#uses=1] |
| 71 | %36 = or i32 %34, %35 ; <i32> [#uses=2] |
| 72 | %37 = inttoptr i32 %36 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 73 | br label %bb2.i |
| 74 | |
| 75 | bb2.i: ; preds = %bb1.i1, %bb.i |
| 76 | %ldi_addr.1.pn.i = phi %struct.edge_rec* [ %ldi_addr.1.i, %bb.i ], [ %37, %bb1.i1 ] ; <%struct.edge_rec*> [#uses=1] |
| 77 | %.pn6.in.in.i = phi i32 [ %19, %bb.i ], [ %36, %bb1.i1 ] ; <i32> [#uses=1] |
| 78 | %ldi_addr.0.i = phi %struct.edge_rec* [ %ldi_addr.1.i, %bb.i ], [ %37, %bb1.i1 ] ; <%struct.edge_rec*> [#uses=4] |
| 79 | %.pn6.in.i = xor i32 %.pn6.in.in.i, 32 ; <i32> [#uses=1] |
| 80 | %.pn6.i = inttoptr i32 %.pn6.in.i to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 81 | %t1.0.in.i = getelementptr %struct.edge_rec* %ldi_addr.1.pn.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 82 | %t2.0.in.i = getelementptr %struct.edge_rec* %.pn6.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 83 | %t1.0.i = load %struct.VERTEX** %t1.0.in.i ; <%struct.VERTEX*> [#uses=2] |
| 84 | %t2.0.i = load %struct.VERTEX** %t2.0.in.i ; <%struct.VERTEX*> [#uses=2] |
| 85 | %38 = getelementptr %struct.VERTEX* %t1.0.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 86 | %39 = load double* %38, align 4 ; <double> [#uses=3] |
| 87 | %40 = getelementptr %struct.VERTEX* %t1.0.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 88 | %41 = load double* %40, align 4 ; <double> [#uses=3] |
| 89 | %42 = getelementptr %struct.VERTEX* %t2.0.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 90 | %43 = load double* %42, align 4 ; <double> [#uses=1] |
| 91 | %44 = getelementptr %struct.VERTEX* %t2.0.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 92 | %45 = load double* %44, align 4 ; <double> [#uses=1] |
| 93 | %46 = fsub double %39, %21 ; <double> [#uses=1] |
| 94 | %47 = fsub double %45, %23 ; <double> [#uses=1] |
| 95 | %48 = fmul double %46, %47 ; <double> [#uses=1] |
| 96 | %49 = fsub double %43, %21 ; <double> [#uses=1] |
| 97 | %50 = fsub double %41, %23 ; <double> [#uses=1] |
| 98 | %51 = fmul double %49, %50 ; <double> [#uses=1] |
| 99 | %52 = fsub double %48, %51 ; <double> [#uses=1] |
| 100 | %53 = fcmp ogt double %52, 0.000000e+00 ; <i1> [#uses=1] |
| 101 | br i1 %53, label %bb1.i1, label %bb3.i |
| 102 | |
| 103 | bb3.i: ; preds = %bb2.i |
| 104 | %54 = ptrtoint %struct.edge_rec* %rdi_addr.0.i to i32 ; <i32> [#uses=1] |
| 105 | %55 = xor i32 %54, 32 ; <i32> [#uses=3] |
| 106 | %56 = inttoptr i32 %55 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 107 | %57 = getelementptr %struct.edge_rec* %56, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 108 | %58 = load %struct.VERTEX** %57, align 4 ; <%struct.VERTEX*> [#uses=2] |
| 109 | %59 = getelementptr %struct.VERTEX* %58, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 110 | %60 = load double* %59, align 4 ; <double> [#uses=1] |
| 111 | %61 = getelementptr %struct.VERTEX* %58, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 112 | %62 = load double* %61, align 4 ; <double> [#uses=1] |
| 113 | %63 = fsub double %60, %39 ; <double> [#uses=1] |
| 114 | %64 = fsub double %23, %41 ; <double> [#uses=1] |
| 115 | %65 = fmul double %63, %64 ; <double> [#uses=1] |
| 116 | %66 = fsub double %21, %39 ; <double> [#uses=1] |
| 117 | %67 = fsub double %62, %41 ; <double> [#uses=1] |
| 118 | %68 = fmul double %66, %67 ; <double> [#uses=1] |
| 119 | %69 = fsub double %65, %68 ; <double> [#uses=1] |
| 120 | %70 = fcmp ogt double %69, 0.000000e+00 ; <i1> [#uses=1] |
| 121 | br i1 %70, label %bb4.i, label %bb5.i |
| 122 | |
| 123 | bb4.i: ; preds = %bb3.i |
| 124 | %71 = getelementptr %struct.edge_rec* %56, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 125 | %72 = load %struct.edge_rec** %71, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 126 | br label %bb.i |
| 127 | |
| 128 | bb5.i: ; preds = %bb3.i |
| 129 | %73 = add i32 %55, 48 ; <i32> [#uses=1] |
| 130 | %74 = and i32 %73, 63 ; <i32> [#uses=1] |
| 131 | %75 = and i32 %55, -64 ; <i32> [#uses=1] |
| 132 | %76 = or i32 %74, %75 ; <i32> [#uses=1] |
| 133 | %77 = inttoptr i32 %76 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 134 | %78 = getelementptr %struct.edge_rec* %77, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 135 | %79 = load %struct.edge_rec** %78, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 136 | %80 = ptrtoint %struct.edge_rec* %79 to i32 ; <i32> [#uses=2] |
| 137 | %81 = add i32 %80, 16 ; <i32> [#uses=1] |
| 138 | %82 = and i32 %81, 63 ; <i32> [#uses=1] |
| 139 | %83 = and i32 %80, -64 ; <i32> [#uses=1] |
| 140 | %84 = or i32 %82, %83 ; <i32> [#uses=1] |
| 141 | %85 = inttoptr i32 %84 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 142 | %86 = getelementptr %struct.edge_rec* %ldi_addr.0.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 143 | %87 = load %struct.VERTEX** %86, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 144 | %88 = call arm_apcscc %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=6] |
| 145 | %89 = getelementptr %struct.edge_rec* %88, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=4] |
| 146 | store %struct.edge_rec* %88, %struct.edge_rec** %89, align 4 |
| 147 | %90 = getelementptr %struct.edge_rec* %88, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=2] |
| 148 | store %struct.VERTEX* %18, %struct.VERTEX** %90, align 4 |
| 149 | %91 = ptrtoint %struct.edge_rec* %88 to i32 ; <i32> [#uses=5] |
| 150 | %92 = add i32 %91, 16 ; <i32> [#uses=2] |
| 151 | %93 = inttoptr i32 %92 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 152 | %94 = add i32 %91, 48 ; <i32> [#uses=1] |
| 153 | %95 = inttoptr i32 %94 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 154 | %96 = getelementptr %struct.edge_rec* %93, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 155 | store %struct.edge_rec* %95, %struct.edge_rec** %96, align 4 |
| 156 | %97 = add i32 %91, 32 ; <i32> [#uses=1] |
| 157 | %98 = inttoptr i32 %97 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=3] |
| 158 | %99 = getelementptr %struct.edge_rec* %98, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 159 | store %struct.edge_rec* %98, %struct.edge_rec** %99, align 4 |
| 160 | %100 = getelementptr %struct.edge_rec* %98, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 161 | store %struct.VERTEX* %87, %struct.VERTEX** %100, align 4 |
| 162 | %101 = getelementptr %struct.edge_rec* %95, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 163 | store %struct.edge_rec* %93, %struct.edge_rec** %101, align 4 |
| 164 | %102 = load %struct.edge_rec** %89, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 165 | %103 = ptrtoint %struct.edge_rec* %102 to i32 ; <i32> [#uses=2] |
| 166 | %104 = add i32 %103, 16 ; <i32> [#uses=1] |
| 167 | %105 = and i32 %104, 63 ; <i32> [#uses=1] |
| 168 | %106 = and i32 %103, -64 ; <i32> [#uses=1] |
| 169 | %107 = or i32 %105, %106 ; <i32> [#uses=1] |
| 170 | %108 = inttoptr i32 %107 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 171 | %109 = getelementptr %struct.edge_rec* %85, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 172 | %110 = load %struct.edge_rec** %109, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 173 | %111 = ptrtoint %struct.edge_rec* %110 to i32 ; <i32> [#uses=2] |
| 174 | %112 = add i32 %111, 16 ; <i32> [#uses=1] |
| 175 | %113 = and i32 %112, 63 ; <i32> [#uses=1] |
| 176 | %114 = and i32 %111, -64 ; <i32> [#uses=1] |
| 177 | %115 = or i32 %113, %114 ; <i32> [#uses=1] |
| 178 | %116 = inttoptr i32 %115 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 179 | %117 = getelementptr %struct.edge_rec* %116, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 180 | %118 = load %struct.edge_rec** %117, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 181 | %119 = getelementptr %struct.edge_rec* %108, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 182 | %120 = load %struct.edge_rec** %119, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 183 | store %struct.edge_rec* %118, %struct.edge_rec** %119, align 4 |
| 184 | store %struct.edge_rec* %120, %struct.edge_rec** %117, align 4 |
| 185 | %121 = load %struct.edge_rec** %89, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 186 | %122 = load %struct.edge_rec** %109, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 187 | store %struct.edge_rec* %121, %struct.edge_rec** %109, align 4 |
| 188 | store %struct.edge_rec* %122, %struct.edge_rec** %89, align 4 |
| 189 | %123 = xor i32 %91, 32 ; <i32> [#uses=1] |
| 190 | %124 = inttoptr i32 %123 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=3] |
| 191 | %125 = getelementptr %struct.edge_rec* %124, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 192 | %126 = load %struct.edge_rec** %125, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 193 | %127 = ptrtoint %struct.edge_rec* %126 to i32 ; <i32> [#uses=2] |
| 194 | %128 = add i32 %127, 16 ; <i32> [#uses=1] |
| 195 | %129 = and i32 %128, 63 ; <i32> [#uses=1] |
| 196 | %130 = and i32 %127, -64 ; <i32> [#uses=1] |
| 197 | %131 = or i32 %129, %130 ; <i32> [#uses=1] |
| 198 | %132 = inttoptr i32 %131 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 199 | %133 = getelementptr %struct.edge_rec* %ldi_addr.0.i, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 200 | %134 = load %struct.edge_rec** %133, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 201 | %135 = ptrtoint %struct.edge_rec* %134 to i32 ; <i32> [#uses=2] |
| 202 | %136 = add i32 %135, 16 ; <i32> [#uses=1] |
| 203 | %137 = and i32 %136, 63 ; <i32> [#uses=1] |
| 204 | %138 = and i32 %135, -64 ; <i32> [#uses=1] |
| 205 | %139 = or i32 %137, %138 ; <i32> [#uses=1] |
| 206 | %140 = inttoptr i32 %139 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 207 | %141 = getelementptr %struct.edge_rec* %140, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 208 | %142 = load %struct.edge_rec** %141, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 209 | %143 = getelementptr %struct.edge_rec* %132, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 210 | %144 = load %struct.edge_rec** %143, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 211 | store %struct.edge_rec* %142, %struct.edge_rec** %143, align 4 |
| 212 | store %struct.edge_rec* %144, %struct.edge_rec** %141, align 4 |
| 213 | %145 = load %struct.edge_rec** %125, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 214 | %146 = load %struct.edge_rec** %133, align 4 ; <%struct.edge_rec*> [#uses=2] |
| 215 | store %struct.edge_rec* %145, %struct.edge_rec** %133, align 4 |
| 216 | store %struct.edge_rec* %146, %struct.edge_rec** %125, align 4 |
| 217 | %147 = and i32 %92, 63 ; <i32> [#uses=1] |
| 218 | %148 = and i32 %91, -64 ; <i32> [#uses=1] |
| 219 | %149 = or i32 %147, %148 ; <i32> [#uses=1] |
| 220 | %150 = inttoptr i32 %149 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 221 | %151 = getelementptr %struct.edge_rec* %150, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 222 | %152 = load %struct.edge_rec** %151, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 223 | %153 = ptrtoint %struct.edge_rec* %152 to i32 ; <i32> [#uses=2] |
| 224 | %154 = add i32 %153, 16 ; <i32> [#uses=1] |
| 225 | %155 = and i32 %154, 63 ; <i32> [#uses=1] |
| 226 | %156 = and i32 %153, -64 ; <i32> [#uses=1] |
| 227 | %157 = or i32 %155, %156 ; <i32> [#uses=1] |
| 228 | %158 = inttoptr i32 %157 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 229 | %159 = load %struct.VERTEX** %90, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 230 | %160 = getelementptr %struct.edge_rec* %124, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 231 | %161 = load %struct.VERTEX** %160, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 232 | %162 = getelementptr %struct.edge_rec* %16, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 233 | %163 = load %struct.VERTEX** %162, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 234 | %164 = icmp eq %struct.VERTEX* %163, %159 ; <i1> [#uses=1] |
| 235 | %rdo_addr.0.i = select i1 %164, %struct.edge_rec* %88, %struct.edge_rec* %16 ; <%struct.edge_rec*> [#uses=3] |
| 236 | %165 = getelementptr %struct.edge_rec* %10, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 237 | %166 = load %struct.VERTEX** %165, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 238 | %167 = icmp eq %struct.VERTEX* %166, %161 ; <i1> [#uses=1] |
| 239 | %ldo_addr.0.ph.i = select i1 %167, %struct.edge_rec* %124, %struct.edge_rec* %10 ; <%struct.edge_rec*> [#uses=3] |
| 240 | br label %bb9.i |
| 241 | |
| 242 | bb9.i: ; preds = %bb25.i, %bb24.i, %bb5.i |
| 243 | %lcand.2.i = phi %struct.edge_rec* [ %146, %bb5.i ], [ %lcand.1.i, %bb24.i ], [ %739, %bb25.i ] ; <%struct.edge_rec*> [#uses=5] |
| 244 | %rcand.2.i = phi %struct.edge_rec* [ %158, %bb5.i ], [ %666, %bb24.i ], [ %rcand.1.i, %bb25.i ] ; <%struct.edge_rec*> [#uses=5] |
| 245 | %basel.0.i = phi %struct.edge_rec* [ %88, %bb5.i ], [ %595, %bb24.i ], [ %716, %bb25.i ] ; <%struct.edge_rec*> [#uses=2] |
| 246 | %168 = getelementptr %struct.edge_rec* %lcand.2.i, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 247 | %169 = load %struct.edge_rec** %168, align 4 ; <%struct.edge_rec*> [#uses=3] |
| 248 | %170 = getelementptr %struct.edge_rec* %basel.0.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=3] |
| 249 | %171 = load %struct.VERTEX** %170, align 4 ; <%struct.VERTEX*> [#uses=4] |
| 250 | %172 = ptrtoint %struct.edge_rec* %basel.0.i to i32 ; <i32> [#uses=3] |
| 251 | %173 = xor i32 %172, 32 ; <i32> [#uses=1] |
| 252 | %174 = inttoptr i32 %173 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 253 | %175 = getelementptr %struct.edge_rec* %174, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=3] |
| 254 | %176 = load %struct.VERTEX** %175, align 4 ; <%struct.VERTEX*> [#uses=3] |
| 255 | %177 = ptrtoint %struct.edge_rec* %169 to i32 ; <i32> [#uses=1] |
| 256 | %178 = xor i32 %177, 32 ; <i32> [#uses=1] |
| 257 | %179 = inttoptr i32 %178 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 258 | %180 = getelementptr %struct.edge_rec* %179, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 259 | %181 = load %struct.VERTEX** %180, align 4 ; <%struct.VERTEX*> [#uses=2] |
| 260 | %182 = getelementptr %struct.VERTEX* %171, i32 0, i32 0, i32 0 ; <double*> [#uses=2] |
| 261 | %183 = load double* %182, align 4 ; <double> [#uses=2] |
| 262 | %184 = getelementptr %struct.VERTEX* %171, i32 0, i32 0, i32 1 ; <double*> [#uses=2] |
| 263 | %185 = load double* %184, align 4 ; <double> [#uses=2] |
| 264 | %186 = getelementptr %struct.VERTEX* %181, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 265 | %187 = load double* %186, align 4 ; <double> [#uses=1] |
| 266 | %188 = getelementptr %struct.VERTEX* %181, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 267 | %189 = load double* %188, align 4 ; <double> [#uses=1] |
| 268 | %190 = getelementptr %struct.VERTEX* %176, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 269 | %191 = load double* %190, align 4 ; <double> [#uses=2] |
| 270 | %192 = getelementptr %struct.VERTEX* %176, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 271 | %193 = load double* %192, align 4 ; <double> [#uses=2] |
| 272 | %194 = fsub double %183, %191 ; <double> [#uses=1] |
| 273 | %195 = fsub double %189, %193 ; <double> [#uses=1] |
| 274 | %196 = fmul double %194, %195 ; <double> [#uses=1] |
| 275 | %197 = fsub double %187, %191 ; <double> [#uses=1] |
| 276 | %198 = fsub double %185, %193 ; <double> [#uses=1] |
| 277 | %199 = fmul double %197, %198 ; <double> [#uses=1] |
| 278 | %200 = fsub double %196, %199 ; <double> [#uses=1] |
| 279 | %201 = fcmp ogt double %200, 0.000000e+00 ; <i1> [#uses=1] |
| 280 | br i1 %201, label %bb10.i, label %bb13.i |
| 281 | |
| 282 | bb10.i: ; preds = %bb9.i |
| 283 | %202 = getelementptr %struct.VERTEX* %171, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 284 | %avail_edge.promoted25 = load %struct.edge_rec** @avail_edge ; <%struct.edge_rec*> [#uses=1] |
| 285 | br label %bb12.i |
| 286 | |
| 287 | bb11.i: ; preds = %bb12.i |
| 288 | %203 = ptrtoint %struct.edge_rec* %lcand.0.i to i32 ; <i32> [#uses=3] |
| 289 | %204 = add i32 %203, 16 ; <i32> [#uses=1] |
| 290 | %205 = and i32 %204, 63 ; <i32> [#uses=1] |
| 291 | %206 = and i32 %203, -64 ; <i32> [#uses=3] |
| 292 | %207 = or i32 %205, %206 ; <i32> [#uses=1] |
| 293 | %208 = inttoptr i32 %207 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 294 | %209 = getelementptr %struct.edge_rec* %208, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 295 | %210 = load %struct.edge_rec** %209, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 296 | %211 = ptrtoint %struct.edge_rec* %210 to i32 ; <i32> [#uses=2] |
| 297 | %212 = add i32 %211, 16 ; <i32> [#uses=1] |
| 298 | %213 = and i32 %212, 63 ; <i32> [#uses=1] |
| 299 | %214 = and i32 %211, -64 ; <i32> [#uses=1] |
| 300 | %215 = or i32 %213, %214 ; <i32> [#uses=1] |
| 301 | %216 = inttoptr i32 %215 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 302 | %217 = getelementptr %struct.edge_rec* %lcand.0.i, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 303 | %218 = load %struct.edge_rec** %217, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 304 | %219 = ptrtoint %struct.edge_rec* %218 to i32 ; <i32> [#uses=2] |
| 305 | %220 = add i32 %219, 16 ; <i32> [#uses=1] |
| 306 | %221 = and i32 %220, 63 ; <i32> [#uses=1] |
| 307 | %222 = and i32 %219, -64 ; <i32> [#uses=1] |
| 308 | %223 = or i32 %221, %222 ; <i32> [#uses=1] |
| 309 | %224 = inttoptr i32 %223 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 310 | %225 = getelementptr %struct.edge_rec* %216, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 311 | %226 = load %struct.edge_rec** %225, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 312 | %227 = ptrtoint %struct.edge_rec* %226 to i32 ; <i32> [#uses=2] |
| 313 | %228 = add i32 %227, 16 ; <i32> [#uses=1] |
| 314 | %229 = and i32 %228, 63 ; <i32> [#uses=1] |
| 315 | %230 = and i32 %227, -64 ; <i32> [#uses=1] |
| 316 | %231 = or i32 %229, %230 ; <i32> [#uses=1] |
| 317 | %232 = inttoptr i32 %231 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 318 | %233 = getelementptr %struct.edge_rec* %232, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 319 | %234 = load %struct.edge_rec** %233, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 320 | %235 = getelementptr %struct.edge_rec* %224, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 321 | %236 = load %struct.edge_rec** %235, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 322 | store %struct.edge_rec* %234, %struct.edge_rec** %235, align 4 |
| 323 | store %struct.edge_rec* %236, %struct.edge_rec** %233, align 4 |
| 324 | %237 = load %struct.edge_rec** %217, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 325 | %238 = load %struct.edge_rec** %225, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 326 | store %struct.edge_rec* %237, %struct.edge_rec** %225, align 4 |
| 327 | store %struct.edge_rec* %238, %struct.edge_rec** %217, align 4 |
| 328 | %239 = xor i32 %203, 32 ; <i32> [#uses=2] |
| 329 | %240 = add i32 %239, 16 ; <i32> [#uses=1] |
| 330 | %241 = and i32 %240, 63 ; <i32> [#uses=1] |
| 331 | %242 = or i32 %241, %206 ; <i32> [#uses=1] |
| 332 | %243 = inttoptr i32 %242 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 333 | %244 = getelementptr %struct.edge_rec* %243, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 334 | %245 = load %struct.edge_rec** %244, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 335 | %246 = ptrtoint %struct.edge_rec* %245 to i32 ; <i32> [#uses=2] |
| 336 | %247 = add i32 %246, 16 ; <i32> [#uses=1] |
| 337 | %248 = and i32 %247, 63 ; <i32> [#uses=1] |
| 338 | %249 = and i32 %246, -64 ; <i32> [#uses=1] |
| 339 | %250 = or i32 %248, %249 ; <i32> [#uses=1] |
| 340 | %251 = inttoptr i32 %250 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 341 | %252 = inttoptr i32 %239 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 342 | %253 = getelementptr %struct.edge_rec* %252, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 343 | %254 = load %struct.edge_rec** %253, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 344 | %255 = ptrtoint %struct.edge_rec* %254 to i32 ; <i32> [#uses=2] |
| 345 | %256 = add i32 %255, 16 ; <i32> [#uses=1] |
| 346 | %257 = and i32 %256, 63 ; <i32> [#uses=1] |
| 347 | %258 = and i32 %255, -64 ; <i32> [#uses=1] |
| 348 | %259 = or i32 %257, %258 ; <i32> [#uses=1] |
| 349 | %260 = inttoptr i32 %259 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 350 | %261 = getelementptr %struct.edge_rec* %251, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 351 | %262 = load %struct.edge_rec** %261, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 352 | %263 = ptrtoint %struct.edge_rec* %262 to i32 ; <i32> [#uses=2] |
| 353 | %264 = add i32 %263, 16 ; <i32> [#uses=1] |
| 354 | %265 = and i32 %264, 63 ; <i32> [#uses=1] |
| 355 | %266 = and i32 %263, -64 ; <i32> [#uses=1] |
| 356 | %267 = or i32 %265, %266 ; <i32> [#uses=1] |
| 357 | %268 = inttoptr i32 %267 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 358 | %269 = getelementptr %struct.edge_rec* %268, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 359 | %270 = load %struct.edge_rec** %269, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 360 | %271 = getelementptr %struct.edge_rec* %260, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 361 | %272 = load %struct.edge_rec** %271, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 362 | store %struct.edge_rec* %270, %struct.edge_rec** %271, align 4 |
| 363 | store %struct.edge_rec* %272, %struct.edge_rec** %269, align 4 |
| 364 | %273 = load %struct.edge_rec** %253, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 365 | %274 = load %struct.edge_rec** %261, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 366 | store %struct.edge_rec* %273, %struct.edge_rec** %261, align 4 |
| 367 | store %struct.edge_rec* %274, %struct.edge_rec** %253, align 4 |
| 368 | %275 = inttoptr i32 %206 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 369 | %276 = getelementptr %struct.edge_rec* %275, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 370 | store %struct.edge_rec* %avail_edge.tmp.026, %struct.edge_rec** %276, align 4 |
| 371 | %277 = getelementptr %struct.edge_rec* %t.0.i, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 372 | %278 = load %struct.edge_rec** %277, align 4 ; <%struct.edge_rec*> [#uses=2] |
| 373 | %.pre.i = load double* %182, align 4 ; <double> [#uses=1] |
| 374 | %.pre22.i = load double* %184, align 4 ; <double> [#uses=1] |
| 375 | br label %bb12.i |
| 376 | |
| 377 | bb12.i: ; preds = %bb11.i, %bb10.i |
| 378 | %avail_edge.tmp.026 = phi %struct.edge_rec* [ %avail_edge.promoted25, %bb10.i ], [ %275, %bb11.i ] ; <%struct.edge_rec*> [#uses=2] |
| 379 | %279 = phi double [ %.pre22.i, %bb11.i ], [ %185, %bb10.i ] ; <double> [#uses=3] |
| 380 | %280 = phi double [ %.pre.i, %bb11.i ], [ %183, %bb10.i ] ; <double> [#uses=3] |
| 381 | %lcand.0.i = phi %struct.edge_rec* [ %lcand.2.i, %bb10.i ], [ %t.0.i, %bb11.i ] ; <%struct.edge_rec*> [#uses=3] |
| 382 | %t.0.i = phi %struct.edge_rec* [ %169, %bb10.i ], [ %278, %bb11.i ] ; <%struct.edge_rec*> [#uses=4] |
| 383 | %.pn5.in.in.in.i = phi %struct.edge_rec* [ %lcand.2.i, %bb10.i ], [ %t.0.i, %bb11.i ] ; <%struct.edge_rec*> [#uses=1] |
| 384 | %.pn4.in.in.in.i = phi %struct.edge_rec* [ %169, %bb10.i ], [ %278, %bb11.i ] ; <%struct.edge_rec*> [#uses=1] |
| 385 | %lcand.2.pn.i = phi %struct.edge_rec* [ %lcand.2.i, %bb10.i ], [ %t.0.i, %bb11.i ] ; <%struct.edge_rec*> [#uses=1] |
| 386 | %.pn5.in.in.i = ptrtoint %struct.edge_rec* %.pn5.in.in.in.i to i32 ; <i32> [#uses=1] |
| 387 | %.pn4.in.in.i = ptrtoint %struct.edge_rec* %.pn4.in.in.in.i to i32 ; <i32> [#uses=1] |
| 388 | %.pn5.in.i = xor i32 %.pn5.in.in.i, 32 ; <i32> [#uses=1] |
| 389 | %.pn4.in.i = xor i32 %.pn4.in.in.i, 32 ; <i32> [#uses=1] |
| 390 | %.pn5.i = inttoptr i32 %.pn5.in.i to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 391 | %.pn4.i = inttoptr i32 %.pn4.in.i to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 392 | %v1.0.in.i = getelementptr %struct.edge_rec* %.pn5.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 393 | %v2.0.in.i = getelementptr %struct.edge_rec* %.pn4.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 394 | %v3.0.in.i = getelementptr %struct.edge_rec* %lcand.2.pn.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 395 | %v1.0.i = load %struct.VERTEX** %v1.0.in.i ; <%struct.VERTEX*> [#uses=3] |
| 396 | %v2.0.i = load %struct.VERTEX** %v2.0.in.i ; <%struct.VERTEX*> [#uses=3] |
| 397 | %v3.0.i = load %struct.VERTEX** %v3.0.in.i ; <%struct.VERTEX*> [#uses=3] |
| 398 | %281 = load double* %202, align 4 ; <double> [#uses=3] |
| 399 | %282 = getelementptr %struct.VERTEX* %v1.0.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 400 | %283 = load double* %282, align 4 ; <double> [#uses=1] |
| 401 | %284 = fsub double %283, %280 ; <double> [#uses=2] |
| 402 | %285 = getelementptr %struct.VERTEX* %v1.0.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 403 | %286 = load double* %285, align 4 ; <double> [#uses=1] |
| 404 | %287 = fsub double %286, %279 ; <double> [#uses=2] |
| 405 | %288 = getelementptr %struct.VERTEX* %v1.0.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 406 | %289 = load double* %288, align 4 ; <double> [#uses=1] |
| 407 | %290 = getelementptr %struct.VERTEX* %v2.0.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 408 | %291 = load double* %290, align 4 ; <double> [#uses=1] |
| 409 | %292 = fsub double %291, %280 ; <double> [#uses=2] |
| 410 | %293 = getelementptr %struct.VERTEX* %v2.0.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 411 | %294 = load double* %293, align 4 ; <double> [#uses=1] |
| 412 | %295 = fsub double %294, %279 ; <double> [#uses=2] |
| 413 | %296 = getelementptr %struct.VERTEX* %v2.0.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 414 | %297 = load double* %296, align 4 ; <double> [#uses=1] |
| 415 | %298 = getelementptr %struct.VERTEX* %v3.0.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 416 | %299 = load double* %298, align 4 ; <double> [#uses=1] |
| 417 | %300 = fsub double %299, %280 ; <double> [#uses=2] |
| 418 | %301 = getelementptr %struct.VERTEX* %v3.0.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 419 | %302 = load double* %301, align 4 ; <double> [#uses=1] |
| 420 | %303 = fsub double %302, %279 ; <double> [#uses=2] |
| 421 | %304 = getelementptr %struct.VERTEX* %v3.0.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 422 | %305 = load double* %304, align 4 ; <double> [#uses=1] |
| 423 | %306 = fsub double %289, %281 ; <double> [#uses=1] |
| 424 | %307 = fmul double %292, %303 ; <double> [#uses=1] |
| 425 | %308 = fmul double %295, %300 ; <double> [#uses=1] |
| 426 | %309 = fsub double %307, %308 ; <double> [#uses=1] |
| 427 | %310 = fmul double %306, %309 ; <double> [#uses=1] |
| 428 | %311 = fsub double %297, %281 ; <double> [#uses=1] |
| 429 | %312 = fmul double %300, %287 ; <double> [#uses=1] |
| 430 | %313 = fmul double %303, %284 ; <double> [#uses=1] |
| 431 | %314 = fsub double %312, %313 ; <double> [#uses=1] |
| 432 | %315 = fmul double %311, %314 ; <double> [#uses=1] |
| 433 | %316 = fadd double %315, %310 ; <double> [#uses=1] |
| 434 | %317 = fsub double %305, %281 ; <double> [#uses=1] |
| 435 | %318 = fmul double %284, %295 ; <double> [#uses=1] |
| 436 | %319 = fmul double %287, %292 ; <double> [#uses=1] |
| 437 | %320 = fsub double %318, %319 ; <double> [#uses=1] |
| 438 | %321 = fmul double %317, %320 ; <double> [#uses=1] |
| 439 | %322 = fadd double %321, %316 ; <double> [#uses=1] |
| 440 | %323 = fcmp ogt double %322, 0.000000e+00 ; <i1> [#uses=1] |
| 441 | br i1 %323, label %bb11.i, label %bb13.loopexit.i |
| 442 | |
| 443 | bb13.loopexit.i: ; preds = %bb12.i |
| 444 | store %struct.edge_rec* %avail_edge.tmp.026, %struct.edge_rec** @avail_edge |
| 445 | %.pre23.i = load %struct.VERTEX** %170, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 446 | %.pre24.i = load %struct.VERTEX** %175, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 447 | br label %bb13.i |
| 448 | |
| 449 | bb13.i: ; preds = %bb13.loopexit.i, %bb9.i |
| 450 | %324 = phi %struct.VERTEX* [ %.pre24.i, %bb13.loopexit.i ], [ %176, %bb9.i ] ; <%struct.VERTEX*> [#uses=4] |
| 451 | %325 = phi %struct.VERTEX* [ %.pre23.i, %bb13.loopexit.i ], [ %171, %bb9.i ] ; <%struct.VERTEX*> [#uses=3] |
| 452 | %lcand.1.i = phi %struct.edge_rec* [ %lcand.0.i, %bb13.loopexit.i ], [ %lcand.2.i, %bb9.i ] ; <%struct.edge_rec*> [#uses=3] |
| 453 | %326 = ptrtoint %struct.edge_rec* %rcand.2.i to i32 ; <i32> [#uses=2] |
| 454 | %327 = add i32 %326, 16 ; <i32> [#uses=1] |
| 455 | %328 = and i32 %327, 63 ; <i32> [#uses=1] |
| 456 | %329 = and i32 %326, -64 ; <i32> [#uses=1] |
| 457 | %330 = or i32 %328, %329 ; <i32> [#uses=1] |
| 458 | %331 = inttoptr i32 %330 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 459 | %332 = getelementptr %struct.edge_rec* %331, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 460 | %333 = load %struct.edge_rec** %332, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 461 | %334 = ptrtoint %struct.edge_rec* %333 to i32 ; <i32> [#uses=2] |
| 462 | %335 = add i32 %334, 16 ; <i32> [#uses=1] |
| 463 | %336 = and i32 %335, 63 ; <i32> [#uses=1] |
| 464 | %337 = and i32 %334, -64 ; <i32> [#uses=1] |
| 465 | %338 = or i32 %336, %337 ; <i32> [#uses=3] |
| 466 | %339 = xor i32 %338, 32 ; <i32> [#uses=1] |
| 467 | %340 = inttoptr i32 %339 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 468 | %341 = getelementptr %struct.edge_rec* %340, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 469 | %342 = load %struct.VERTEX** %341, align 4 ; <%struct.VERTEX*> [#uses=2] |
| 470 | %343 = getelementptr %struct.VERTEX* %325, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 471 | %344 = load double* %343, align 4 ; <double> [#uses=1] |
| 472 | %345 = getelementptr %struct.VERTEX* %325, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 473 | %346 = load double* %345, align 4 ; <double> [#uses=1] |
| 474 | %347 = getelementptr %struct.VERTEX* %342, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 475 | %348 = load double* %347, align 4 ; <double> [#uses=1] |
| 476 | %349 = getelementptr %struct.VERTEX* %342, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 477 | %350 = load double* %349, align 4 ; <double> [#uses=1] |
| 478 | %351 = getelementptr %struct.VERTEX* %324, i32 0, i32 0, i32 0 ; <double*> [#uses=2] |
| 479 | %352 = load double* %351, align 4 ; <double> [#uses=3] |
| 480 | %353 = getelementptr %struct.VERTEX* %324, i32 0, i32 0, i32 1 ; <double*> [#uses=2] |
| 481 | %354 = load double* %353, align 4 ; <double> [#uses=3] |
| 482 | %355 = fsub double %344, %352 ; <double> [#uses=1] |
| 483 | %356 = fsub double %350, %354 ; <double> [#uses=1] |
| 484 | %357 = fmul double %355, %356 ; <double> [#uses=1] |
| 485 | %358 = fsub double %348, %352 ; <double> [#uses=1] |
| 486 | %359 = fsub double %346, %354 ; <double> [#uses=1] |
| 487 | %360 = fmul double %358, %359 ; <double> [#uses=1] |
| 488 | %361 = fsub double %357, %360 ; <double> [#uses=1] |
| 489 | %362 = fcmp ogt double %361, 0.000000e+00 ; <i1> [#uses=1] |
| 490 | br i1 %362, label %bb14.i, label %bb17.i |
| 491 | |
| 492 | bb14.i: ; preds = %bb13.i |
| 493 | %363 = getelementptr %struct.VERTEX* %324, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 494 | %avail_edge.promoted = load %struct.edge_rec** @avail_edge ; <%struct.edge_rec*> [#uses=1] |
| 495 | br label %bb16.i |
| 496 | |
| 497 | bb15.i: ; preds = %bb16.i |
| 498 | %364 = ptrtoint %struct.edge_rec* %rcand.0.i to i32 ; <i32> [#uses=3] |
| 499 | %365 = add i32 %364, 16 ; <i32> [#uses=1] |
| 500 | %366 = and i32 %365, 63 ; <i32> [#uses=1] |
| 501 | %367 = and i32 %364, -64 ; <i32> [#uses=3] |
| 502 | %368 = or i32 %366, %367 ; <i32> [#uses=1] |
| 503 | %369 = inttoptr i32 %368 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 504 | %370 = getelementptr %struct.edge_rec* %369, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 505 | %371 = load %struct.edge_rec** %370, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 506 | %372 = ptrtoint %struct.edge_rec* %371 to i32 ; <i32> [#uses=2] |
| 507 | %373 = add i32 %372, 16 ; <i32> [#uses=1] |
| 508 | %374 = and i32 %373, 63 ; <i32> [#uses=1] |
| 509 | %375 = and i32 %372, -64 ; <i32> [#uses=1] |
| 510 | %376 = or i32 %374, %375 ; <i32> [#uses=1] |
| 511 | %377 = inttoptr i32 %376 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 512 | %378 = getelementptr %struct.edge_rec* %rcand.0.i, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 513 | %379 = load %struct.edge_rec** %378, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 514 | %380 = ptrtoint %struct.edge_rec* %379 to i32 ; <i32> [#uses=2] |
| 515 | %381 = add i32 %380, 16 ; <i32> [#uses=1] |
| 516 | %382 = and i32 %381, 63 ; <i32> [#uses=1] |
| 517 | %383 = and i32 %380, -64 ; <i32> [#uses=1] |
| 518 | %384 = or i32 %382, %383 ; <i32> [#uses=1] |
| 519 | %385 = inttoptr i32 %384 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 520 | %386 = getelementptr %struct.edge_rec* %377, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 521 | %387 = load %struct.edge_rec** %386, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 522 | %388 = ptrtoint %struct.edge_rec* %387 to i32 ; <i32> [#uses=2] |
| 523 | %389 = add i32 %388, 16 ; <i32> [#uses=1] |
| 524 | %390 = and i32 %389, 63 ; <i32> [#uses=1] |
| 525 | %391 = and i32 %388, -64 ; <i32> [#uses=1] |
| 526 | %392 = or i32 %390, %391 ; <i32> [#uses=1] |
| 527 | %393 = inttoptr i32 %392 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 528 | %394 = getelementptr %struct.edge_rec* %393, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 529 | %395 = load %struct.edge_rec** %394, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 530 | %396 = getelementptr %struct.edge_rec* %385, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 531 | %397 = load %struct.edge_rec** %396, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 532 | store %struct.edge_rec* %395, %struct.edge_rec** %396, align 4 |
| 533 | store %struct.edge_rec* %397, %struct.edge_rec** %394, align 4 |
| 534 | %398 = load %struct.edge_rec** %378, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 535 | %399 = load %struct.edge_rec** %386, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 536 | store %struct.edge_rec* %398, %struct.edge_rec** %386, align 4 |
| 537 | store %struct.edge_rec* %399, %struct.edge_rec** %378, align 4 |
| 538 | %400 = xor i32 %364, 32 ; <i32> [#uses=2] |
| 539 | %401 = add i32 %400, 16 ; <i32> [#uses=1] |
| 540 | %402 = and i32 %401, 63 ; <i32> [#uses=1] |
| 541 | %403 = or i32 %402, %367 ; <i32> [#uses=1] |
| 542 | %404 = inttoptr i32 %403 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 543 | %405 = getelementptr %struct.edge_rec* %404, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 544 | %406 = load %struct.edge_rec** %405, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 545 | %407 = ptrtoint %struct.edge_rec* %406 to i32 ; <i32> [#uses=2] |
| 546 | %408 = add i32 %407, 16 ; <i32> [#uses=1] |
| 547 | %409 = and i32 %408, 63 ; <i32> [#uses=1] |
| 548 | %410 = and i32 %407, -64 ; <i32> [#uses=1] |
| 549 | %411 = or i32 %409, %410 ; <i32> [#uses=1] |
| 550 | %412 = inttoptr i32 %411 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 551 | %413 = inttoptr i32 %400 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 552 | %414 = getelementptr %struct.edge_rec* %413, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 553 | %415 = load %struct.edge_rec** %414, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 554 | %416 = ptrtoint %struct.edge_rec* %415 to i32 ; <i32> [#uses=2] |
| 555 | %417 = add i32 %416, 16 ; <i32> [#uses=1] |
| 556 | %418 = and i32 %417, 63 ; <i32> [#uses=1] |
| 557 | %419 = and i32 %416, -64 ; <i32> [#uses=1] |
| 558 | %420 = or i32 %418, %419 ; <i32> [#uses=1] |
| 559 | %421 = inttoptr i32 %420 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 560 | %422 = getelementptr %struct.edge_rec* %412, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 561 | %423 = load %struct.edge_rec** %422, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 562 | %424 = ptrtoint %struct.edge_rec* %423 to i32 ; <i32> [#uses=2] |
| 563 | %425 = add i32 %424, 16 ; <i32> [#uses=1] |
| 564 | %426 = and i32 %425, 63 ; <i32> [#uses=1] |
| 565 | %427 = and i32 %424, -64 ; <i32> [#uses=1] |
| 566 | %428 = or i32 %426, %427 ; <i32> [#uses=1] |
| 567 | %429 = inttoptr i32 %428 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 568 | %430 = getelementptr %struct.edge_rec* %429, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 569 | %431 = load %struct.edge_rec** %430, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 570 | %432 = getelementptr %struct.edge_rec* %421, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 571 | %433 = load %struct.edge_rec** %432, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 572 | store %struct.edge_rec* %431, %struct.edge_rec** %432, align 4 |
| 573 | store %struct.edge_rec* %433, %struct.edge_rec** %430, align 4 |
| 574 | %434 = load %struct.edge_rec** %414, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 575 | %435 = load %struct.edge_rec** %422, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 576 | store %struct.edge_rec* %434, %struct.edge_rec** %422, align 4 |
| 577 | store %struct.edge_rec* %435, %struct.edge_rec** %414, align 4 |
| 578 | %436 = inttoptr i32 %367 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 579 | %437 = getelementptr %struct.edge_rec* %436, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 580 | store %struct.edge_rec* %avail_edge.tmp.0, %struct.edge_rec** %437, align 4 |
| 581 | %438 = add i32 %t.1.in.i, 16 ; <i32> [#uses=1] |
| 582 | %439 = and i32 %438, 63 ; <i32> [#uses=1] |
| 583 | %440 = and i32 %t.1.in.i, -64 ; <i32> [#uses=1] |
| 584 | %441 = or i32 %439, %440 ; <i32> [#uses=1] |
| 585 | %442 = inttoptr i32 %441 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 586 | %443 = getelementptr %struct.edge_rec* %442, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 587 | %444 = load %struct.edge_rec** %443, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 588 | %445 = ptrtoint %struct.edge_rec* %444 to i32 ; <i32> [#uses=2] |
| 589 | %446 = add i32 %445, 16 ; <i32> [#uses=1] |
| 590 | %447 = and i32 %446, 63 ; <i32> [#uses=1] |
| 591 | %448 = and i32 %445, -64 ; <i32> [#uses=1] |
| 592 | %449 = or i32 %447, %448 ; <i32> [#uses=2] |
| 593 | %.pre25.i = load double* %351, align 4 ; <double> [#uses=1] |
| 594 | %.pre26.i = load double* %353, align 4 ; <double> [#uses=1] |
| 595 | br label %bb16.i |
| 596 | |
| 597 | bb16.i: ; preds = %bb15.i, %bb14.i |
| 598 | %avail_edge.tmp.0 = phi %struct.edge_rec* [ %avail_edge.promoted, %bb14.i ], [ %436, %bb15.i ] ; <%struct.edge_rec*> [#uses=2] |
| 599 | %450 = phi double [ %.pre26.i, %bb15.i ], [ %354, %bb14.i ] ; <double> [#uses=3] |
| 600 | %451 = phi double [ %.pre25.i, %bb15.i ], [ %352, %bb14.i ] ; <double> [#uses=3] |
| 601 | %rcand.0.i = phi %struct.edge_rec* [ %rcand.2.i, %bb14.i ], [ %t.1.i, %bb15.i ] ; <%struct.edge_rec*> [#uses=3] |
| 602 | %t.1.in.i = phi i32 [ %338, %bb14.i ], [ %449, %bb15.i ] ; <i32> [#uses=3] |
| 603 | %.pn3.in.in.i = phi i32 [ %338, %bb14.i ], [ %449, %bb15.i ] ; <i32> [#uses=1] |
| 604 | %.pn.in.in.in.i = phi %struct.edge_rec* [ %rcand.2.i, %bb14.i ], [ %t.1.i, %bb15.i ] ; <%struct.edge_rec*> [#uses=1] |
| 605 | %rcand.2.pn.i = phi %struct.edge_rec* [ %rcand.2.i, %bb14.i ], [ %t.1.i, %bb15.i ] ; <%struct.edge_rec*> [#uses=1] |
| 606 | %t.1.i = inttoptr i32 %t.1.in.i to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=3] |
| 607 | %.pn.in.in.i = ptrtoint %struct.edge_rec* %.pn.in.in.in.i to i32 ; <i32> [#uses=1] |
| 608 | %.pn3.in.i = xor i32 %.pn3.in.in.i, 32 ; <i32> [#uses=1] |
| 609 | %.pn.in.i = xor i32 %.pn.in.in.i, 32 ; <i32> [#uses=1] |
| 610 | %.pn3.i = inttoptr i32 %.pn3.in.i to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 611 | %.pn.i = inttoptr i32 %.pn.in.i to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 612 | %v1.1.in.i = getelementptr %struct.edge_rec* %.pn3.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 613 | %v2.1.in.i = getelementptr %struct.edge_rec* %.pn.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 614 | %v3.1.in.i = getelementptr %struct.edge_rec* %rcand.2.pn.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 615 | %v1.1.i = load %struct.VERTEX** %v1.1.in.i ; <%struct.VERTEX*> [#uses=3] |
| 616 | %v2.1.i = load %struct.VERTEX** %v2.1.in.i ; <%struct.VERTEX*> [#uses=3] |
| 617 | %v3.1.i = load %struct.VERTEX** %v3.1.in.i ; <%struct.VERTEX*> [#uses=3] |
| 618 | %452 = load double* %363, align 4 ; <double> [#uses=3] |
| 619 | %453 = getelementptr %struct.VERTEX* %v1.1.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 620 | %454 = load double* %453, align 4 ; <double> [#uses=1] |
| 621 | %455 = fsub double %454, %451 ; <double> [#uses=2] |
| 622 | %456 = getelementptr %struct.VERTEX* %v1.1.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 623 | %457 = load double* %456, align 4 ; <double> [#uses=1] |
| 624 | %458 = fsub double %457, %450 ; <double> [#uses=2] |
| 625 | %459 = getelementptr %struct.VERTEX* %v1.1.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 626 | %460 = load double* %459, align 4 ; <double> [#uses=1] |
| 627 | %461 = getelementptr %struct.VERTEX* %v2.1.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 628 | %462 = load double* %461, align 4 ; <double> [#uses=1] |
| 629 | %463 = fsub double %462, %451 ; <double> [#uses=2] |
| 630 | %464 = getelementptr %struct.VERTEX* %v2.1.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 631 | %465 = load double* %464, align 4 ; <double> [#uses=1] |
| 632 | %466 = fsub double %465, %450 ; <double> [#uses=2] |
| 633 | %467 = getelementptr %struct.VERTEX* %v2.1.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 634 | %468 = load double* %467, align 4 ; <double> [#uses=1] |
| 635 | %469 = getelementptr %struct.VERTEX* %v3.1.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 636 | %470 = load double* %469, align 4 ; <double> [#uses=1] |
| 637 | %471 = fsub double %470, %451 ; <double> [#uses=2] |
| 638 | %472 = getelementptr %struct.VERTEX* %v3.1.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 639 | %473 = load double* %472, align 4 ; <double> [#uses=1] |
| 640 | %474 = fsub double %473, %450 ; <double> [#uses=2] |
| 641 | %475 = getelementptr %struct.VERTEX* %v3.1.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 642 | %476 = load double* %475, align 4 ; <double> [#uses=1] |
| 643 | %477 = fsub double %460, %452 ; <double> [#uses=1] |
| 644 | %478 = fmul double %463, %474 ; <double> [#uses=1] |
| 645 | %479 = fmul double %466, %471 ; <double> [#uses=1] |
| 646 | %480 = fsub double %478, %479 ; <double> [#uses=1] |
| 647 | %481 = fmul double %477, %480 ; <double> [#uses=1] |
| 648 | %482 = fsub double %468, %452 ; <double> [#uses=1] |
| 649 | %483 = fmul double %471, %458 ; <double> [#uses=1] |
| 650 | %484 = fmul double %474, %455 ; <double> [#uses=1] |
| 651 | %485 = fsub double %483, %484 ; <double> [#uses=1] |
| 652 | %486 = fmul double %482, %485 ; <double> [#uses=1] |
| 653 | %487 = fadd double %486, %481 ; <double> [#uses=1] |
| 654 | %488 = fsub double %476, %452 ; <double> [#uses=1] |
| 655 | %489 = fmul double %455, %466 ; <double> [#uses=1] |
| 656 | %490 = fmul double %458, %463 ; <double> [#uses=1] |
| 657 | %491 = fsub double %489, %490 ; <double> [#uses=1] |
| 658 | %492 = fmul double %488, %491 ; <double> [#uses=1] |
| 659 | %493 = fadd double %492, %487 ; <double> [#uses=1] |
| 660 | %494 = fcmp ogt double %493, 0.000000e+00 ; <i1> [#uses=1] |
| 661 | br i1 %494, label %bb15.i, label %bb17.loopexit.i |
| 662 | |
| 663 | bb17.loopexit.i: ; preds = %bb16.i |
| 664 | store %struct.edge_rec* %avail_edge.tmp.0, %struct.edge_rec** @avail_edge |
| 665 | %.pre27.i = load %struct.VERTEX** %170, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 666 | %.pre28.i = load %struct.VERTEX** %175, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 667 | br label %bb17.i |
| 668 | |
| 669 | bb17.i: ; preds = %bb17.loopexit.i, %bb13.i |
| 670 | %495 = phi %struct.VERTEX* [ %.pre28.i, %bb17.loopexit.i ], [ %324, %bb13.i ] ; <%struct.VERTEX*> [#uses=3] |
| 671 | %496 = phi %struct.VERTEX* [ %.pre27.i, %bb17.loopexit.i ], [ %325, %bb13.i ] ; <%struct.VERTEX*> [#uses=3] |
| 672 | %rcand.1.i = phi %struct.edge_rec* [ %rcand.0.i, %bb17.loopexit.i ], [ %rcand.2.i, %bb13.i ] ; <%struct.edge_rec*> [#uses=3] |
| 673 | %497 = ptrtoint %struct.edge_rec* %lcand.1.i to i32 ; <i32> [#uses=1] |
| 674 | %498 = xor i32 %497, 32 ; <i32> [#uses=1] |
| 675 | %499 = inttoptr i32 %498 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 676 | %500 = getelementptr %struct.edge_rec* %499, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 677 | %501 = load %struct.VERTEX** %500, align 4 ; <%struct.VERTEX*> [#uses=4] |
| 678 | %502 = getelementptr %struct.VERTEX* %496, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 679 | %503 = load double* %502, align 4 ; <double> [#uses=1] |
| 680 | %504 = getelementptr %struct.VERTEX* %496, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 681 | %505 = load double* %504, align 4 ; <double> [#uses=1] |
| 682 | %506 = getelementptr %struct.VERTEX* %501, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 683 | %507 = load double* %506, align 4 ; <double> [#uses=2] |
| 684 | %508 = getelementptr %struct.VERTEX* %501, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 685 | %509 = load double* %508, align 4 ; <double> [#uses=2] |
| 686 | %510 = getelementptr %struct.VERTEX* %495, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 687 | %511 = load double* %510, align 4 ; <double> [#uses=3] |
| 688 | %512 = getelementptr %struct.VERTEX* %495, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 689 | %513 = load double* %512, align 4 ; <double> [#uses=3] |
| 690 | %514 = fsub double %503, %511 ; <double> [#uses=2] |
| 691 | %515 = fsub double %509, %513 ; <double> [#uses=1] |
| 692 | %516 = fmul double %514, %515 ; <double> [#uses=1] |
| 693 | %517 = fsub double %507, %511 ; <double> [#uses=1] |
| 694 | %518 = fsub double %505, %513 ; <double> [#uses=2] |
| 695 | %519 = fmul double %517, %518 ; <double> [#uses=1] |
| 696 | %520 = fsub double %516, %519 ; <double> [#uses=1] |
| 697 | %521 = fcmp ogt double %520, 0.000000e+00 ; <i1> [#uses=2] |
| 698 | %522 = ptrtoint %struct.edge_rec* %rcand.1.i to i32 ; <i32> [#uses=3] |
| 699 | %523 = xor i32 %522, 32 ; <i32> [#uses=1] |
| 700 | %524 = inttoptr i32 %523 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 701 | %525 = getelementptr %struct.edge_rec* %524, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 702 | %526 = load %struct.VERTEX** %525, align 4 ; <%struct.VERTEX*> [#uses=4] |
| 703 | %527 = getelementptr %struct.VERTEX* %526, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 704 | %528 = load double* %527, align 4 ; <double> [#uses=4] |
| 705 | %529 = getelementptr %struct.VERTEX* %526, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 706 | %530 = load double* %529, align 4 ; <double> [#uses=4] |
| 707 | %531 = fsub double %530, %513 ; <double> [#uses=1] |
| 708 | %532 = fmul double %514, %531 ; <double> [#uses=1] |
| 709 | %533 = fsub double %528, %511 ; <double> [#uses=1] |
| 710 | %534 = fmul double %533, %518 ; <double> [#uses=1] |
| 711 | %535 = fsub double %532, %534 ; <double> [#uses=1] |
| 712 | %536 = fcmp ogt double %535, 0.000000e+00 ; <i1> [#uses=2] |
| 713 | %537 = or i1 %536, %521 ; <i1> [#uses=1] |
| 714 | br i1 %537, label %bb21.i, label %do_merge.exit |
| 715 | |
| 716 | bb21.i: ; preds = %bb17.i |
| 717 | %538 = getelementptr %struct.edge_rec* %lcand.1.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 718 | %539 = load %struct.VERTEX** %538, align 4 ; <%struct.VERTEX*> [#uses=3] |
| 719 | %540 = getelementptr %struct.edge_rec* %rcand.1.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 720 | %541 = load %struct.VERTEX** %540, align 4 ; <%struct.VERTEX*> [#uses=3] |
| 721 | br i1 %521, label %bb22.i, label %bb24.i |
| 722 | |
| 723 | bb22.i: ; preds = %bb21.i |
| 724 | br i1 %536, label %bb23.i, label %bb25.i |
| 725 | |
| 726 | bb23.i: ; preds = %bb22.i |
| 727 | %542 = getelementptr %struct.VERTEX* %526, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 728 | %543 = load double* %542, align 4 ; <double> [#uses=3] |
| 729 | %544 = fsub double %507, %528 ; <double> [#uses=2] |
| 730 | %545 = fsub double %509, %530 ; <double> [#uses=2] |
| 731 | %546 = getelementptr %struct.VERTEX* %501, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 732 | %547 = load double* %546, align 4 ; <double> [#uses=1] |
| 733 | %548 = getelementptr %struct.VERTEX* %539, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 734 | %549 = load double* %548, align 4 ; <double> [#uses=1] |
| 735 | %550 = fsub double %549, %528 ; <double> [#uses=2] |
| 736 | %551 = getelementptr %struct.VERTEX* %539, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 737 | %552 = load double* %551, align 4 ; <double> [#uses=1] |
| 738 | %553 = fsub double %552, %530 ; <double> [#uses=2] |
| 739 | %554 = getelementptr %struct.VERTEX* %539, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 740 | %555 = load double* %554, align 4 ; <double> [#uses=1] |
| 741 | %556 = getelementptr %struct.VERTEX* %541, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 742 | %557 = load double* %556, align 4 ; <double> [#uses=1] |
| 743 | %558 = fsub double %557, %528 ; <double> [#uses=2] |
| 744 | %559 = getelementptr %struct.VERTEX* %541, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 745 | %560 = load double* %559, align 4 ; <double> [#uses=1] |
| 746 | %561 = fsub double %560, %530 ; <double> [#uses=2] |
| 747 | %562 = getelementptr %struct.VERTEX* %541, i32 0, i32 0, i32 2 ; <double*> [#uses=1] |
| 748 | %563 = load double* %562, align 4 ; <double> [#uses=1] |
| 749 | %564 = fsub double %547, %543 ; <double> [#uses=1] |
| 750 | %565 = fmul double %550, %561 ; <double> [#uses=1] |
| 751 | %566 = fmul double %553, %558 ; <double> [#uses=1] |
| 752 | %567 = fsub double %565, %566 ; <double> [#uses=1] |
| 753 | %568 = fmul double %564, %567 ; <double> [#uses=1] |
| 754 | %569 = fsub double %555, %543 ; <double> [#uses=1] |
| 755 | %570 = fmul double %558, %545 ; <double> [#uses=1] |
| 756 | %571 = fmul double %561, %544 ; <double> [#uses=1] |
| 757 | %572 = fsub double %570, %571 ; <double> [#uses=1] |
| 758 | %573 = fmul double %569, %572 ; <double> [#uses=1] |
| 759 | %574 = fadd double %573, %568 ; <double> [#uses=1] |
| 760 | %575 = fsub double %563, %543 ; <double> [#uses=1] |
| 761 | %576 = fmul double %544, %553 ; <double> [#uses=1] |
| 762 | %577 = fmul double %545, %550 ; <double> [#uses=1] |
| 763 | %578 = fsub double %576, %577 ; <double> [#uses=1] |
| 764 | %579 = fmul double %575, %578 ; <double> [#uses=1] |
| 765 | %580 = fadd double %579, %574 ; <double> [#uses=1] |
| 766 | %581 = fcmp ogt double %580, 0.000000e+00 ; <i1> [#uses=1] |
| 767 | br i1 %581, label %bb24.i, label %bb25.i |
| 768 | |
| 769 | bb24.i: ; preds = %bb23.i, %bb21.i |
| 770 | %582 = add i32 %522, 48 ; <i32> [#uses=1] |
| 771 | %583 = and i32 %582, 63 ; <i32> [#uses=1] |
| 772 | %584 = and i32 %522, -64 ; <i32> [#uses=1] |
| 773 | %585 = or i32 %583, %584 ; <i32> [#uses=1] |
| 774 | %586 = inttoptr i32 %585 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 775 | %587 = getelementptr %struct.edge_rec* %586, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 776 | %588 = load %struct.edge_rec** %587, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 777 | %589 = ptrtoint %struct.edge_rec* %588 to i32 ; <i32> [#uses=2] |
| 778 | %590 = add i32 %589, 16 ; <i32> [#uses=1] |
| 779 | %591 = and i32 %590, 63 ; <i32> [#uses=1] |
| 780 | %592 = and i32 %589, -64 ; <i32> [#uses=1] |
| 781 | %593 = or i32 %591, %592 ; <i32> [#uses=1] |
| 782 | %594 = inttoptr i32 %593 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 783 | %595 = call arm_apcscc %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=5] |
| 784 | %596 = getelementptr %struct.edge_rec* %595, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=4] |
| 785 | store %struct.edge_rec* %595, %struct.edge_rec** %596, align 4 |
| 786 | %597 = getelementptr %struct.edge_rec* %595, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 787 | store %struct.VERTEX* %526, %struct.VERTEX** %597, align 4 |
| 788 | %598 = ptrtoint %struct.edge_rec* %595 to i32 ; <i32> [#uses=5] |
| 789 | %599 = add i32 %598, 16 ; <i32> [#uses=1] |
| 790 | %600 = inttoptr i32 %599 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 791 | %601 = add i32 %598, 48 ; <i32> [#uses=1] |
| 792 | %602 = inttoptr i32 %601 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 793 | %603 = getelementptr %struct.edge_rec* %600, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 794 | store %struct.edge_rec* %602, %struct.edge_rec** %603, align 4 |
| 795 | %604 = add i32 %598, 32 ; <i32> [#uses=1] |
| 796 | %605 = inttoptr i32 %604 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=3] |
| 797 | %606 = getelementptr %struct.edge_rec* %605, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 798 | store %struct.edge_rec* %605, %struct.edge_rec** %606, align 4 |
| 799 | %607 = getelementptr %struct.edge_rec* %605, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 800 | store %struct.VERTEX* %495, %struct.VERTEX** %607, align 4 |
| 801 | %608 = getelementptr %struct.edge_rec* %602, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 802 | store %struct.edge_rec* %600, %struct.edge_rec** %608, align 4 |
| 803 | %609 = load %struct.edge_rec** %596, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 804 | %610 = ptrtoint %struct.edge_rec* %609 to i32 ; <i32> [#uses=2] |
| 805 | %611 = add i32 %610, 16 ; <i32> [#uses=1] |
| 806 | %612 = and i32 %611, 63 ; <i32> [#uses=1] |
| 807 | %613 = and i32 %610, -64 ; <i32> [#uses=1] |
| 808 | %614 = or i32 %612, %613 ; <i32> [#uses=1] |
| 809 | %615 = inttoptr i32 %614 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 810 | %616 = getelementptr %struct.edge_rec* %594, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 811 | %617 = load %struct.edge_rec** %616, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 812 | %618 = ptrtoint %struct.edge_rec* %617 to i32 ; <i32> [#uses=2] |
| 813 | %619 = add i32 %618, 16 ; <i32> [#uses=1] |
| 814 | %620 = and i32 %619, 63 ; <i32> [#uses=1] |
| 815 | %621 = and i32 %618, -64 ; <i32> [#uses=1] |
| 816 | %622 = or i32 %620, %621 ; <i32> [#uses=1] |
| 817 | %623 = inttoptr i32 %622 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 818 | %624 = getelementptr %struct.edge_rec* %623, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 819 | %625 = load %struct.edge_rec** %624, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 820 | %626 = getelementptr %struct.edge_rec* %615, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 821 | %627 = load %struct.edge_rec** %626, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 822 | store %struct.edge_rec* %625, %struct.edge_rec** %626, align 4 |
| 823 | store %struct.edge_rec* %627, %struct.edge_rec** %624, align 4 |
| 824 | %628 = load %struct.edge_rec** %596, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 825 | %629 = load %struct.edge_rec** %616, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 826 | store %struct.edge_rec* %628, %struct.edge_rec** %616, align 4 |
| 827 | store %struct.edge_rec* %629, %struct.edge_rec** %596, align 4 |
| 828 | %630 = xor i32 %598, 32 ; <i32> [#uses=2] |
| 829 | %631 = inttoptr i32 %630 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 830 | %632 = getelementptr %struct.edge_rec* %631, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 831 | %633 = load %struct.edge_rec** %632, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 832 | %634 = ptrtoint %struct.edge_rec* %633 to i32 ; <i32> [#uses=2] |
| 833 | %635 = add i32 %634, 16 ; <i32> [#uses=1] |
| 834 | %636 = and i32 %635, 63 ; <i32> [#uses=1] |
| 835 | %637 = and i32 %634, -64 ; <i32> [#uses=1] |
| 836 | %638 = or i32 %636, %637 ; <i32> [#uses=1] |
| 837 | %639 = inttoptr i32 %638 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 838 | %640 = getelementptr %struct.edge_rec* %174, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 839 | %641 = load %struct.edge_rec** %640, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 840 | %642 = ptrtoint %struct.edge_rec* %641 to i32 ; <i32> [#uses=2] |
| 841 | %643 = add i32 %642, 16 ; <i32> [#uses=1] |
| 842 | %644 = and i32 %643, 63 ; <i32> [#uses=1] |
| 843 | %645 = and i32 %642, -64 ; <i32> [#uses=1] |
| 844 | %646 = or i32 %644, %645 ; <i32> [#uses=1] |
| 845 | %647 = inttoptr i32 %646 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 846 | %648 = getelementptr %struct.edge_rec* %647, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 847 | %649 = load %struct.edge_rec** %648, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 848 | %650 = getelementptr %struct.edge_rec* %639, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 849 | %651 = load %struct.edge_rec** %650, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 850 | store %struct.edge_rec* %649, %struct.edge_rec** %650, align 4 |
| 851 | store %struct.edge_rec* %651, %struct.edge_rec** %648, align 4 |
| 852 | %652 = load %struct.edge_rec** %632, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 853 | %653 = load %struct.edge_rec** %640, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 854 | store %struct.edge_rec* %652, %struct.edge_rec** %640, align 4 |
| 855 | store %struct.edge_rec* %653, %struct.edge_rec** %632, align 4 |
| 856 | %654 = add i32 %630, 48 ; <i32> [#uses=1] |
| 857 | %655 = and i32 %654, 63 ; <i32> [#uses=1] |
| 858 | %656 = and i32 %598, -64 ; <i32> [#uses=1] |
| 859 | %657 = or i32 %655, %656 ; <i32> [#uses=1] |
| 860 | %658 = inttoptr i32 %657 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 861 | %659 = getelementptr %struct.edge_rec* %658, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 862 | %660 = load %struct.edge_rec** %659, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 863 | %661 = ptrtoint %struct.edge_rec* %660 to i32 ; <i32> [#uses=2] |
| 864 | %662 = add i32 %661, 16 ; <i32> [#uses=1] |
| 865 | %663 = and i32 %662, 63 ; <i32> [#uses=1] |
| 866 | %664 = and i32 %661, -64 ; <i32> [#uses=1] |
| 867 | %665 = or i32 %663, %664 ; <i32> [#uses=1] |
| 868 | %666 = inttoptr i32 %665 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 869 | br label %bb9.i |
| 870 | |
| 871 | bb25.i: ; preds = %bb23.i, %bb22.i |
| 872 | %667 = add i32 %172, 16 ; <i32> [#uses=1] |
| 873 | %668 = and i32 %667, 63 ; <i32> [#uses=1] |
| 874 | %669 = and i32 %172, -64 ; <i32> [#uses=1] |
| 875 | %670 = or i32 %668, %669 ; <i32> [#uses=1] |
| 876 | %671 = inttoptr i32 %670 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 877 | %672 = getelementptr %struct.edge_rec* %671, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 878 | %673 = load %struct.edge_rec** %672, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 879 | %674 = ptrtoint %struct.edge_rec* %673 to i32 ; <i32> [#uses=2] |
| 880 | %675 = add i32 %674, 16 ; <i32> [#uses=1] |
| 881 | %676 = and i32 %675, 63 ; <i32> [#uses=1] |
| 882 | %677 = and i32 %674, -64 ; <i32> [#uses=1] |
| 883 | %678 = or i32 %676, %677 ; <i32> [#uses=1] |
| 884 | %679 = inttoptr i32 %678 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 885 | %680 = call arm_apcscc %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=4] |
| 886 | %681 = getelementptr %struct.edge_rec* %680, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=5] |
| 887 | store %struct.edge_rec* %680, %struct.edge_rec** %681, align 4 |
| 888 | %682 = getelementptr %struct.edge_rec* %680, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 889 | store %struct.VERTEX* %501, %struct.VERTEX** %682, align 4 |
| 890 | %683 = ptrtoint %struct.edge_rec* %680 to i32 ; <i32> [#uses=4] |
| 891 | %684 = add i32 %683, 16 ; <i32> [#uses=1] |
| 892 | %685 = inttoptr i32 %684 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 893 | %686 = add i32 %683, 48 ; <i32> [#uses=1] |
| 894 | %687 = inttoptr i32 %686 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 895 | %688 = getelementptr %struct.edge_rec* %685, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 896 | store %struct.edge_rec* %687, %struct.edge_rec** %688, align 4 |
| 897 | %689 = add i32 %683, 32 ; <i32> [#uses=1] |
| 898 | %690 = inttoptr i32 %689 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=3] |
| 899 | %691 = getelementptr %struct.edge_rec* %690, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 900 | store %struct.edge_rec* %690, %struct.edge_rec** %691, align 4 |
| 901 | %692 = getelementptr %struct.edge_rec* %690, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 902 | store %struct.VERTEX* %496, %struct.VERTEX** %692, align 4 |
| 903 | %693 = getelementptr %struct.edge_rec* %687, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 904 | store %struct.edge_rec* %685, %struct.edge_rec** %693, align 4 |
| 905 | %694 = load %struct.edge_rec** %681, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 906 | %695 = ptrtoint %struct.edge_rec* %694 to i32 ; <i32> [#uses=2] |
| 907 | %696 = add i32 %695, 16 ; <i32> [#uses=1] |
| 908 | %697 = and i32 %696, 63 ; <i32> [#uses=1] |
| 909 | %698 = and i32 %695, -64 ; <i32> [#uses=1] |
| 910 | %699 = or i32 %697, %698 ; <i32> [#uses=1] |
| 911 | %700 = inttoptr i32 %699 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 912 | %701 = getelementptr %struct.edge_rec* %499, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 913 | %702 = load %struct.edge_rec** %701, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 914 | %703 = ptrtoint %struct.edge_rec* %702 to i32 ; <i32> [#uses=2] |
| 915 | %704 = add i32 %703, 16 ; <i32> [#uses=1] |
| 916 | %705 = and i32 %704, 63 ; <i32> [#uses=1] |
| 917 | %706 = and i32 %703, -64 ; <i32> [#uses=1] |
| 918 | %707 = or i32 %705, %706 ; <i32> [#uses=1] |
| 919 | %708 = inttoptr i32 %707 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 920 | %709 = getelementptr %struct.edge_rec* %708, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 921 | %710 = load %struct.edge_rec** %709, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 922 | %711 = getelementptr %struct.edge_rec* %700, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 923 | %712 = load %struct.edge_rec** %711, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 924 | store %struct.edge_rec* %710, %struct.edge_rec** %711, align 4 |
| 925 | store %struct.edge_rec* %712, %struct.edge_rec** %709, align 4 |
| 926 | %713 = load %struct.edge_rec** %681, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 927 | %714 = load %struct.edge_rec** %701, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 928 | store %struct.edge_rec* %713, %struct.edge_rec** %701, align 4 |
| 929 | store %struct.edge_rec* %714, %struct.edge_rec** %681, align 4 |
| 930 | %715 = xor i32 %683, 32 ; <i32> [#uses=1] |
| 931 | %716 = inttoptr i32 %715 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 932 | %717 = getelementptr %struct.edge_rec* %716, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 933 | %718 = load %struct.edge_rec** %717, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 934 | %719 = ptrtoint %struct.edge_rec* %718 to i32 ; <i32> [#uses=2] |
| 935 | %720 = add i32 %719, 16 ; <i32> [#uses=1] |
| 936 | %721 = and i32 %720, 63 ; <i32> [#uses=1] |
| 937 | %722 = and i32 %719, -64 ; <i32> [#uses=1] |
| 938 | %723 = or i32 %721, %722 ; <i32> [#uses=1] |
| 939 | %724 = inttoptr i32 %723 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 940 | %725 = getelementptr %struct.edge_rec* %679, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 941 | %726 = load %struct.edge_rec** %725, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 942 | %727 = ptrtoint %struct.edge_rec* %726 to i32 ; <i32> [#uses=2] |
| 943 | %728 = add i32 %727, 16 ; <i32> [#uses=1] |
| 944 | %729 = and i32 %728, 63 ; <i32> [#uses=1] |
| 945 | %730 = and i32 %727, -64 ; <i32> [#uses=1] |
| 946 | %731 = or i32 %729, %730 ; <i32> [#uses=1] |
| 947 | %732 = inttoptr i32 %731 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 948 | %733 = getelementptr %struct.edge_rec* %732, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 949 | %734 = load %struct.edge_rec** %733, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 950 | %735 = getelementptr %struct.edge_rec* %724, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 951 | %736 = load %struct.edge_rec** %735, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 952 | store %struct.edge_rec* %734, %struct.edge_rec** %735, align 4 |
| 953 | store %struct.edge_rec* %736, %struct.edge_rec** %733, align 4 |
| 954 | %737 = load %struct.edge_rec** %717, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 955 | %738 = load %struct.edge_rec** %725, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 956 | store %struct.edge_rec* %737, %struct.edge_rec** %725, align 4 |
| 957 | store %struct.edge_rec* %738, %struct.edge_rec** %717, align 4 |
| 958 | %739 = load %struct.edge_rec** %681, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 959 | br label %bb9.i |
| 960 | |
| 961 | do_merge.exit: ; preds = %bb17.i |
| 962 | %740 = getelementptr %struct.edge_rec* %ldo_addr.0.ph.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 963 | %741 = load %struct.VERTEX** %740, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 964 | %742 = icmp eq %struct.VERTEX* %741, %tree_addr.0.i ; <i1> [#uses=1] |
| 965 | br i1 %742, label %bb5.loopexit, label %bb2 |
| 966 | |
| 967 | bb2: ; preds = %bb2, %do_merge.exit |
| 968 | %ldo.07 = phi %struct.edge_rec* [ %747, %bb2 ], [ %ldo_addr.0.ph.i, %do_merge.exit ] ; <%struct.edge_rec*> [#uses=1] |
| 969 | %743 = ptrtoint %struct.edge_rec* %ldo.07 to i32 ; <i32> [#uses=1] |
| 970 | %744 = xor i32 %743, 32 ; <i32> [#uses=1] |
| 971 | %745 = inttoptr i32 %744 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 972 | %746 = getelementptr %struct.edge_rec* %745, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 973 | %747 = load %struct.edge_rec** %746, align 4 ; <%struct.edge_rec*> [#uses=3] |
| 974 | %748 = getelementptr %struct.edge_rec* %747, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 975 | %749 = load %struct.VERTEX** %748, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 976 | %750 = icmp eq %struct.VERTEX* %749, %tree_addr.0.i ; <i1> [#uses=1] |
| 977 | br i1 %750, label %bb5.loopexit, label %bb2 |
| 978 | |
| 979 | bb4: ; preds = %bb5.loopexit, %bb4 |
| 980 | %rdo.05 = phi %struct.edge_rec* [ %755, %bb4 ], [ %rdo_addr.0.i, %bb5.loopexit ] ; <%struct.edge_rec*> [#uses=1] |
| 981 | %751 = getelementptr %struct.edge_rec* %rdo.05, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 982 | %752 = load %struct.edge_rec** %751, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 983 | %753 = ptrtoint %struct.edge_rec* %752 to i32 ; <i32> [#uses=1] |
| 984 | %754 = xor i32 %753, 32 ; <i32> [#uses=1] |
| 985 | %755 = inttoptr i32 %754 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=3] |
| 986 | %756 = getelementptr %struct.edge_rec* %755, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 987 | %757 = load %struct.VERTEX** %756, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 988 | %758 = icmp eq %struct.VERTEX* %757, %extra ; <i1> [#uses=1] |
| 989 | br i1 %758, label %bb6, label %bb4 |
| 990 | |
| 991 | bb5.loopexit: ; preds = %bb2, %do_merge.exit |
| 992 | %ldo.0.lcssa = phi %struct.edge_rec* [ %ldo_addr.0.ph.i, %do_merge.exit ], [ %747, %bb2 ] ; <%struct.edge_rec*> [#uses=1] |
| 993 | %759 = getelementptr %struct.edge_rec* %rdo_addr.0.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 994 | %760 = load %struct.VERTEX** %759, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 995 | %761 = icmp eq %struct.VERTEX* %760, %extra ; <i1> [#uses=1] |
| 996 | br i1 %761, label %bb6, label %bb4 |
| 997 | |
| 998 | bb6: ; preds = %bb5.loopexit, %bb4 |
| 999 | %rdo.0.lcssa = phi %struct.edge_rec* [ %rdo_addr.0.i, %bb5.loopexit ], [ %755, %bb4 ] ; <%struct.edge_rec*> [#uses=1] |
| 1000 | %tmp16 = ptrtoint %struct.edge_rec* %ldo.0.lcssa to i32 ; <i32> [#uses=1] |
| 1001 | %tmp4 = ptrtoint %struct.edge_rec* %rdo.0.lcssa to i32 ; <i32> [#uses=1] |
| 1002 | br label %bb15 |
| 1003 | |
| 1004 | bb7: ; preds = %bb |
| 1005 | %762 = getelementptr %struct.VERTEX* %tree, i32 0, i32 1 ; <%struct.VERTEX**> [#uses=1] |
| 1006 | %763 = load %struct.VERTEX** %762, align 4 ; <%struct.VERTEX*> [#uses=4] |
| 1007 | %764 = icmp eq %struct.VERTEX* %763, null ; <i1> [#uses=1] |
| 1008 | %765 = call arm_apcscc %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=5] |
| 1009 | %766 = getelementptr %struct.edge_rec* %765, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=4] |
| 1010 | store %struct.edge_rec* %765, %struct.edge_rec** %766, align 4 |
| 1011 | %767 = getelementptr %struct.edge_rec* %765, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=3] |
| 1012 | br i1 %764, label %bb10, label %bb11 |
| 1013 | |
| 1014 | bb8: ; preds = %entry |
| 1015 | %768 = call arm_apcscc i32 @puts(i8* getelementptr ([21 x i8]* @_2E_str7, i32 0, i32 0)) nounwind ; <i32> [#uses=0] |
| 1016 | call arm_apcscc void @exit(i32 -1) noreturn nounwind |
| 1017 | unreachable |
| 1018 | |
| 1019 | bb10: ; preds = %bb7 |
| 1020 | store %struct.VERTEX* %tree, %struct.VERTEX** %767, align 4 |
| 1021 | %769 = ptrtoint %struct.edge_rec* %765 to i32 ; <i32> [#uses=5] |
| 1022 | %770 = add i32 %769, 16 ; <i32> [#uses=1] |
| 1023 | %771 = inttoptr i32 %770 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 1024 | %772 = add i32 %769, 48 ; <i32> [#uses=1] |
| 1025 | %773 = inttoptr i32 %772 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 1026 | %774 = getelementptr %struct.edge_rec* %771, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1027 | store %struct.edge_rec* %773, %struct.edge_rec** %774, align 4 |
| 1028 | %775 = add i32 %769, 32 ; <i32> [#uses=1] |
| 1029 | %776 = inttoptr i32 %775 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=3] |
| 1030 | %777 = getelementptr %struct.edge_rec* %776, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1031 | store %struct.edge_rec* %776, %struct.edge_rec** %777, align 4 |
| 1032 | %778 = getelementptr %struct.edge_rec* %776, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 1033 | store %struct.VERTEX* %extra, %struct.VERTEX** %778, align 4 |
| 1034 | %779 = getelementptr %struct.edge_rec* %773, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1035 | store %struct.edge_rec* %771, %struct.edge_rec** %779, align 4 |
| 1036 | %780 = xor i32 %769, 32 ; <i32> [#uses=1] |
| 1037 | br label %bb15 |
| 1038 | |
| 1039 | bb11: ; preds = %bb7 |
| 1040 | store %struct.VERTEX* %763, %struct.VERTEX** %767, align 4 |
| 1041 | %781 = ptrtoint %struct.edge_rec* %765 to i32 ; <i32> [#uses=6] |
| 1042 | %782 = add i32 %781, 16 ; <i32> [#uses=1] |
| 1043 | %783 = inttoptr i32 %782 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 1044 | %784 = add i32 %781, 48 ; <i32> [#uses=1] |
| 1045 | %785 = inttoptr i32 %784 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 1046 | %786 = getelementptr %struct.edge_rec* %783, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1047 | store %struct.edge_rec* %785, %struct.edge_rec** %786, align 4 |
| 1048 | %787 = add i32 %781, 32 ; <i32> [#uses=1] |
| 1049 | %788 = inttoptr i32 %787 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=3] |
| 1050 | %789 = getelementptr %struct.edge_rec* %788, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1051 | store %struct.edge_rec* %788, %struct.edge_rec** %789, align 4 |
| 1052 | %790 = getelementptr %struct.edge_rec* %788, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 1053 | store %struct.VERTEX* %tree, %struct.VERTEX** %790, align 4 |
| 1054 | %791 = getelementptr %struct.edge_rec* %785, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1055 | store %struct.edge_rec* %783, %struct.edge_rec** %791, align 4 |
| 1056 | %792 = call arm_apcscc %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=4] |
| 1057 | %793 = getelementptr %struct.edge_rec* %792, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=4] |
| 1058 | store %struct.edge_rec* %792, %struct.edge_rec** %793, align 4 |
| 1059 | %794 = getelementptr %struct.edge_rec* %792, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 1060 | store %struct.VERTEX* %tree, %struct.VERTEX** %794, align 4 |
| 1061 | %795 = ptrtoint %struct.edge_rec* %792 to i32 ; <i32> [#uses=5] |
| 1062 | %796 = add i32 %795, 16 ; <i32> [#uses=1] |
| 1063 | %797 = inttoptr i32 %796 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 1064 | %798 = add i32 %795, 48 ; <i32> [#uses=2] |
| 1065 | %799 = inttoptr i32 %798 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 1066 | %800 = getelementptr %struct.edge_rec* %797, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1067 | store %struct.edge_rec* %799, %struct.edge_rec** %800, align 4 |
| 1068 | %801 = add i32 %795, 32 ; <i32> [#uses=1] |
| 1069 | %802 = inttoptr i32 %801 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=3] |
| 1070 | %803 = getelementptr %struct.edge_rec* %802, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1071 | store %struct.edge_rec* %802, %struct.edge_rec** %803, align 4 |
| 1072 | %804 = getelementptr %struct.edge_rec* %802, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 1073 | store %struct.VERTEX* %extra, %struct.VERTEX** %804, align 4 |
| 1074 | %805 = getelementptr %struct.edge_rec* %799, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1075 | store %struct.edge_rec* %797, %struct.edge_rec** %805, align 4 |
| 1076 | %806 = xor i32 %781, 32 ; <i32> [#uses=1] |
| 1077 | %807 = inttoptr i32 %806 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1078 | %808 = getelementptr %struct.edge_rec* %807, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 1079 | %809 = load %struct.edge_rec** %808, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1080 | %810 = ptrtoint %struct.edge_rec* %809 to i32 ; <i32> [#uses=2] |
| 1081 | %811 = add i32 %810, 16 ; <i32> [#uses=1] |
| 1082 | %812 = and i32 %811, 63 ; <i32> [#uses=1] |
| 1083 | %813 = and i32 %810, -64 ; <i32> [#uses=1] |
| 1084 | %814 = or i32 %812, %813 ; <i32> [#uses=1] |
| 1085 | %815 = inttoptr i32 %814 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1086 | %816 = load %struct.edge_rec** %793, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1087 | %817 = ptrtoint %struct.edge_rec* %816 to i32 ; <i32> [#uses=2] |
| 1088 | %818 = add i32 %817, 16 ; <i32> [#uses=1] |
| 1089 | %819 = and i32 %818, 63 ; <i32> [#uses=1] |
| 1090 | %820 = and i32 %817, -64 ; <i32> [#uses=1] |
| 1091 | %821 = or i32 %819, %820 ; <i32> [#uses=1] |
| 1092 | %822 = inttoptr i32 %821 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1093 | %823 = getelementptr %struct.edge_rec* %822, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 1094 | %824 = load %struct.edge_rec** %823, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1095 | %825 = getelementptr %struct.edge_rec* %815, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 1096 | %826 = load %struct.edge_rec** %825, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1097 | store %struct.edge_rec* %824, %struct.edge_rec** %825, align 4 |
| 1098 | store %struct.edge_rec* %826, %struct.edge_rec** %823, align 4 |
| 1099 | %827 = load %struct.edge_rec** %808, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1100 | %828 = load %struct.edge_rec** %793, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1101 | store %struct.edge_rec* %827, %struct.edge_rec** %793, align 4 |
| 1102 | store %struct.edge_rec* %828, %struct.edge_rec** %808, align 4 |
| 1103 | %829 = xor i32 %795, 32 ; <i32> [#uses=3] |
| 1104 | %830 = inttoptr i32 %829 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1105 | %831 = getelementptr %struct.edge_rec* %830, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 1106 | %832 = load %struct.VERTEX** %831, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 1107 | %833 = and i32 %798, 63 ; <i32> [#uses=1] |
| 1108 | %834 = and i32 %795, -64 ; <i32> [#uses=1] |
| 1109 | %835 = or i32 %833, %834 ; <i32> [#uses=1] |
| 1110 | %836 = inttoptr i32 %835 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1111 | %837 = getelementptr %struct.edge_rec* %836, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1112 | %838 = load %struct.edge_rec** %837, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1113 | %839 = ptrtoint %struct.edge_rec* %838 to i32 ; <i32> [#uses=2] |
| 1114 | %840 = add i32 %839, 16 ; <i32> [#uses=1] |
| 1115 | %841 = and i32 %840, 63 ; <i32> [#uses=1] |
| 1116 | %842 = and i32 %839, -64 ; <i32> [#uses=1] |
| 1117 | %843 = or i32 %841, %842 ; <i32> [#uses=1] |
| 1118 | %844 = inttoptr i32 %843 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1119 | %845 = load %struct.VERTEX** %767, align 4 ; <%struct.VERTEX*> [#uses=1] |
| 1120 | %846 = call arm_apcscc %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=4] |
| 1121 | %847 = getelementptr %struct.edge_rec* %846, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=7] |
| 1122 | store %struct.edge_rec* %846, %struct.edge_rec** %847, align 4 |
| 1123 | %848 = getelementptr %struct.edge_rec* %846, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 1124 | store %struct.VERTEX* %832, %struct.VERTEX** %848, align 4 |
| 1125 | %849 = ptrtoint %struct.edge_rec* %846 to i32 ; <i32> [#uses=6] |
| 1126 | %850 = add i32 %849, 16 ; <i32> [#uses=2] |
| 1127 | %851 = inttoptr i32 %850 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 1128 | %852 = add i32 %849, 48 ; <i32> [#uses=1] |
| 1129 | %853 = inttoptr i32 %852 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 1130 | %854 = getelementptr %struct.edge_rec* %851, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1131 | store %struct.edge_rec* %853, %struct.edge_rec** %854, align 4 |
| 1132 | %855 = add i32 %849, 32 ; <i32> [#uses=1] |
| 1133 | %856 = inttoptr i32 %855 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=3] |
| 1134 | %857 = getelementptr %struct.edge_rec* %856, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1135 | store %struct.edge_rec* %856, %struct.edge_rec** %857, align 4 |
| 1136 | %858 = getelementptr %struct.edge_rec* %856, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] |
| 1137 | store %struct.VERTEX* %845, %struct.VERTEX** %858, align 4 |
| 1138 | %859 = getelementptr %struct.edge_rec* %853, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1139 | store %struct.edge_rec* %851, %struct.edge_rec** %859, align 4 |
| 1140 | %860 = load %struct.edge_rec** %847, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1141 | %861 = ptrtoint %struct.edge_rec* %860 to i32 ; <i32> [#uses=2] |
| 1142 | %862 = add i32 %861, 16 ; <i32> [#uses=1] |
| 1143 | %863 = and i32 %862, 63 ; <i32> [#uses=1] |
| 1144 | %864 = and i32 %861, -64 ; <i32> [#uses=1] |
| 1145 | %865 = or i32 %863, %864 ; <i32> [#uses=1] |
| 1146 | %866 = inttoptr i32 %865 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1147 | %867 = getelementptr %struct.edge_rec* %844, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 1148 | %868 = load %struct.edge_rec** %867, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1149 | %869 = ptrtoint %struct.edge_rec* %868 to i32 ; <i32> [#uses=2] |
| 1150 | %870 = add i32 %869, 16 ; <i32> [#uses=1] |
| 1151 | %871 = and i32 %870, 63 ; <i32> [#uses=1] |
| 1152 | %872 = and i32 %869, -64 ; <i32> [#uses=1] |
| 1153 | %873 = or i32 %871, %872 ; <i32> [#uses=1] |
| 1154 | %874 = inttoptr i32 %873 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1155 | %875 = getelementptr %struct.edge_rec* %874, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 1156 | %876 = load %struct.edge_rec** %875, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1157 | %877 = getelementptr %struct.edge_rec* %866, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 1158 | %878 = load %struct.edge_rec** %877, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1159 | store %struct.edge_rec* %876, %struct.edge_rec** %877, align 4 |
| 1160 | store %struct.edge_rec* %878, %struct.edge_rec** %875, align 4 |
| 1161 | %879 = load %struct.edge_rec** %847, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1162 | %880 = load %struct.edge_rec** %867, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1163 | store %struct.edge_rec* %879, %struct.edge_rec** %867, align 4 |
| 1164 | store %struct.edge_rec* %880, %struct.edge_rec** %847, align 4 |
| 1165 | %881 = xor i32 %849, 32 ; <i32> [#uses=3] |
| 1166 | %882 = inttoptr i32 %881 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1167 | %883 = getelementptr %struct.edge_rec* %882, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=6] |
| 1168 | %884 = load %struct.edge_rec** %883, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1169 | %885 = ptrtoint %struct.edge_rec* %884 to i32 ; <i32> [#uses=2] |
| 1170 | %886 = add i32 %885, 16 ; <i32> [#uses=1] |
| 1171 | %887 = and i32 %886, 63 ; <i32> [#uses=1] |
| 1172 | %888 = and i32 %885, -64 ; <i32> [#uses=1] |
| 1173 | %889 = or i32 %887, %888 ; <i32> [#uses=1] |
| 1174 | %890 = inttoptr i32 %889 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1175 | %891 = load %struct.edge_rec** %766, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1176 | %892 = ptrtoint %struct.edge_rec* %891 to i32 ; <i32> [#uses=2] |
| 1177 | %893 = add i32 %892, 16 ; <i32> [#uses=1] |
| 1178 | %894 = and i32 %893, 63 ; <i32> [#uses=1] |
| 1179 | %895 = and i32 %892, -64 ; <i32> [#uses=1] |
| 1180 | %896 = or i32 %894, %895 ; <i32> [#uses=1] |
| 1181 | %897 = inttoptr i32 %896 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1182 | %898 = getelementptr %struct.edge_rec* %897, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 1183 | %899 = load %struct.edge_rec** %898, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1184 | %900 = getelementptr %struct.edge_rec* %890, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 1185 | %901 = load %struct.edge_rec** %900, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1186 | store %struct.edge_rec* %899, %struct.edge_rec** %900, align 4 |
| 1187 | store %struct.edge_rec* %901, %struct.edge_rec** %898, align 4 |
| 1188 | %902 = load %struct.edge_rec** %883, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1189 | %903 = load %struct.edge_rec** %766, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1190 | store %struct.edge_rec* %902, %struct.edge_rec** %766, align 4 |
| 1191 | store %struct.edge_rec* %903, %struct.edge_rec** %883, align 4 |
| 1192 | %904 = getelementptr %struct.VERTEX* %763, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 1193 | %905 = load double* %904, align 4 ; <double> [#uses=2] |
| 1194 | %906 = getelementptr %struct.VERTEX* %763, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 1195 | %907 = load double* %906, align 4 ; <double> [#uses=2] |
| 1196 | %908 = getelementptr %struct.VERTEX* %extra, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 1197 | %909 = load double* %908, align 4 ; <double> [#uses=3] |
| 1198 | %910 = getelementptr %struct.VERTEX* %extra, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 1199 | %911 = load double* %910, align 4 ; <double> [#uses=3] |
| 1200 | %912 = getelementptr %struct.VERTEX* %tree, i32 0, i32 0, i32 0 ; <double*> [#uses=1] |
| 1201 | %913 = load double* %912, align 4 ; <double> [#uses=3] |
| 1202 | %914 = getelementptr %struct.VERTEX* %tree, i32 0, i32 0, i32 1 ; <double*> [#uses=1] |
| 1203 | %915 = load double* %914, align 4 ; <double> [#uses=3] |
| 1204 | %916 = fsub double %905, %913 ; <double> [#uses=1] |
| 1205 | %917 = fsub double %911, %915 ; <double> [#uses=1] |
| 1206 | %918 = fmul double %916, %917 ; <double> [#uses=1] |
| 1207 | %919 = fsub double %909, %913 ; <double> [#uses=1] |
| 1208 | %920 = fsub double %907, %915 ; <double> [#uses=1] |
| 1209 | %921 = fmul double %919, %920 ; <double> [#uses=1] |
| 1210 | %922 = fsub double %918, %921 ; <double> [#uses=1] |
| 1211 | %923 = fcmp ogt double %922, 0.000000e+00 ; <i1> [#uses=1] |
| 1212 | br i1 %923, label %bb15, label %bb13 |
| 1213 | |
| 1214 | bb13: ; preds = %bb11 |
| 1215 | %924 = fsub double %905, %909 ; <double> [#uses=1] |
| 1216 | %925 = fsub double %915, %911 ; <double> [#uses=1] |
| 1217 | %926 = fmul double %924, %925 ; <double> [#uses=1] |
| 1218 | %927 = fsub double %913, %909 ; <double> [#uses=1] |
| 1219 | %928 = fsub double %907, %911 ; <double> [#uses=1] |
| 1220 | %929 = fmul double %927, %928 ; <double> [#uses=1] |
| 1221 | %930 = fsub double %926, %929 ; <double> [#uses=1] |
| 1222 | %931 = fcmp ogt double %930, 0.000000e+00 ; <i1> [#uses=1] |
| 1223 | br i1 %931, label %bb15, label %bb14 |
| 1224 | |
| 1225 | bb14: ; preds = %bb13 |
| 1226 | %932 = and i32 %850, 63 ; <i32> [#uses=1] |
| 1227 | %933 = and i32 %849, -64 ; <i32> [#uses=3] |
| 1228 | %934 = or i32 %932, %933 ; <i32> [#uses=1] |
| 1229 | %935 = inttoptr i32 %934 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1230 | %936 = getelementptr %struct.edge_rec* %935, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1231 | %937 = load %struct.edge_rec** %936, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1232 | %938 = ptrtoint %struct.edge_rec* %937 to i32 ; <i32> [#uses=2] |
| 1233 | %939 = add i32 %938, 16 ; <i32> [#uses=1] |
| 1234 | %940 = and i32 %939, 63 ; <i32> [#uses=1] |
| 1235 | %941 = and i32 %938, -64 ; <i32> [#uses=1] |
| 1236 | %942 = or i32 %940, %941 ; <i32> [#uses=1] |
| 1237 | %943 = inttoptr i32 %942 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1238 | %944 = load %struct.edge_rec** %847, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1239 | %945 = ptrtoint %struct.edge_rec* %944 to i32 ; <i32> [#uses=2] |
| 1240 | %946 = add i32 %945, 16 ; <i32> [#uses=1] |
| 1241 | %947 = and i32 %946, 63 ; <i32> [#uses=1] |
| 1242 | %948 = and i32 %945, -64 ; <i32> [#uses=1] |
| 1243 | %949 = or i32 %947, %948 ; <i32> [#uses=1] |
| 1244 | %950 = inttoptr i32 %949 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1245 | %951 = getelementptr %struct.edge_rec* %943, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 1246 | %952 = load %struct.edge_rec** %951, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1247 | %953 = ptrtoint %struct.edge_rec* %952 to i32 ; <i32> [#uses=2] |
| 1248 | %954 = add i32 %953, 16 ; <i32> [#uses=1] |
| 1249 | %955 = and i32 %954, 63 ; <i32> [#uses=1] |
| 1250 | %956 = and i32 %953, -64 ; <i32> [#uses=1] |
| 1251 | %957 = or i32 %955, %956 ; <i32> [#uses=1] |
| 1252 | %958 = inttoptr i32 %957 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1253 | %959 = getelementptr %struct.edge_rec* %958, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 1254 | %960 = load %struct.edge_rec** %959, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1255 | %961 = getelementptr %struct.edge_rec* %950, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 1256 | %962 = load %struct.edge_rec** %961, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1257 | store %struct.edge_rec* %960, %struct.edge_rec** %961, align 4 |
| 1258 | store %struct.edge_rec* %962, %struct.edge_rec** %959, align 4 |
| 1259 | %963 = load %struct.edge_rec** %847, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1260 | %964 = load %struct.edge_rec** %951, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1261 | store %struct.edge_rec* %963, %struct.edge_rec** %951, align 4 |
| 1262 | store %struct.edge_rec* %964, %struct.edge_rec** %847, align 4 |
| 1263 | %965 = add i32 %881, 16 ; <i32> [#uses=1] |
| 1264 | %966 = and i32 %965, 63 ; <i32> [#uses=1] |
| 1265 | %967 = or i32 %966, %933 ; <i32> [#uses=1] |
| 1266 | %968 = inttoptr i32 %967 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1267 | %969 = getelementptr %struct.edge_rec* %968, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1268 | %970 = load %struct.edge_rec** %969, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1269 | %971 = ptrtoint %struct.edge_rec* %970 to i32 ; <i32> [#uses=2] |
| 1270 | %972 = add i32 %971, 16 ; <i32> [#uses=1] |
| 1271 | %973 = and i32 %972, 63 ; <i32> [#uses=1] |
| 1272 | %974 = and i32 %971, -64 ; <i32> [#uses=1] |
| 1273 | %975 = or i32 %973, %974 ; <i32> [#uses=1] |
| 1274 | %976 = inttoptr i32 %975 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1275 | %977 = load %struct.edge_rec** %883, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1276 | %978 = ptrtoint %struct.edge_rec* %977 to i32 ; <i32> [#uses=2] |
| 1277 | %979 = add i32 %978, 16 ; <i32> [#uses=1] |
| 1278 | %980 = and i32 %979, 63 ; <i32> [#uses=1] |
| 1279 | %981 = and i32 %978, -64 ; <i32> [#uses=1] |
| 1280 | %982 = or i32 %980, %981 ; <i32> [#uses=1] |
| 1281 | %983 = inttoptr i32 %982 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1282 | %984 = getelementptr %struct.edge_rec* %976, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] |
| 1283 | %985 = load %struct.edge_rec** %984, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1284 | %986 = ptrtoint %struct.edge_rec* %985 to i32 ; <i32> [#uses=2] |
| 1285 | %987 = add i32 %986, 16 ; <i32> [#uses=1] |
| 1286 | %988 = and i32 %987, 63 ; <i32> [#uses=1] |
| 1287 | %989 = and i32 %986, -64 ; <i32> [#uses=1] |
| 1288 | %990 = or i32 %988, %989 ; <i32> [#uses=1] |
| 1289 | %991 = inttoptr i32 %990 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=1] |
| 1290 | %992 = getelementptr %struct.edge_rec* %991, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 1291 | %993 = load %struct.edge_rec** %992, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1292 | %994 = getelementptr %struct.edge_rec* %983, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] |
| 1293 | %995 = load %struct.edge_rec** %994, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1294 | store %struct.edge_rec* %993, %struct.edge_rec** %994, align 4 |
| 1295 | store %struct.edge_rec* %995, %struct.edge_rec** %992, align 4 |
| 1296 | %996 = load %struct.edge_rec** %883, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1297 | %997 = load %struct.edge_rec** %984, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1298 | store %struct.edge_rec* %996, %struct.edge_rec** %984, align 4 |
| 1299 | store %struct.edge_rec* %997, %struct.edge_rec** %883, align 4 |
| 1300 | %998 = inttoptr i32 %933 to %struct.edge_rec* ; <%struct.edge_rec*> [#uses=2] |
| 1301 | %999 = load %struct.edge_rec** @avail_edge, align 4 ; <%struct.edge_rec*> [#uses=1] |
| 1302 | %1000 = getelementptr %struct.edge_rec* %998, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] |
| 1303 | store %struct.edge_rec* %999, %struct.edge_rec** %1000, align 4 |
| 1304 | store %struct.edge_rec* %998, %struct.edge_rec** @avail_edge, align 4 |
| 1305 | br label %bb15 |
| 1306 | |
| 1307 | bb15: ; preds = %bb14, %bb13, %bb11, %bb10, %bb6 |
| 1308 | %retval.1.0 = phi i32 [ %780, %bb10 ], [ %829, %bb13 ], [ %829, %bb14 ], [ %tmp4, %bb6 ], [ %849, %bb11 ] ; <i32> [#uses=1] |
| 1309 | %retval.0.0 = phi i32 [ %769, %bb10 ], [ %781, %bb13 ], [ %781, %bb14 ], [ %tmp16, %bb6 ], [ %881, %bb11 ] ; <i32> [#uses=1] |
| 1310 | %agg.result162 = bitcast %struct.EDGE_PAIR* %agg.result to i64* ; <i64*> [#uses=1] |
| 1311 | %1001 = zext i32 %retval.0.0 to i64 ; <i64> [#uses=1] |
| 1312 | %1002 = zext i32 %retval.1.0 to i64 ; <i64> [#uses=1] |
| 1313 | %1003 = shl i64 %1002, 32 ; <i64> [#uses=1] |
| 1314 | %1004 = or i64 %1003, %1001 ; <i64> [#uses=1] |
| 1315 | store i64 %1004, i64* %agg.result162, align 4 |
| 1316 | ret void |
| 1317 | } |
| 1318 | |
| 1319 | declare arm_apcscc i32 @puts(i8* nocapture) nounwind |
| 1320 | |
| 1321 | declare arm_apcscc void @exit(i32) noreturn nounwind |
| 1322 | |
| 1323 | declare arm_apcscc %struct.edge_rec* @alloc_edge() nounwind |