1 ; RUN: llc < %s -mtriple=armv6-apple-darwin10 -mattr=+vfp2 | grep vcmpe | 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 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, %struct.VERTEX* %tree, i32 0, i32 2 ; <%struct.VERTEX**> [#uses=1] 20 %2 = load %struct.VERTEX*, %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, %struct.VERTEX* %tree_addr.0.i, i32 0, i32 1 ; <%struct.VERTEX**> [#uses=1] 27 %5 = load %struct.VERTEX*, %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 void @build_delaunay(%struct.EDGE_PAIR* noalias sret %delright, %struct.VERTEX* %2, %struct.VERTEX* %extra) nounwind 33 %7 = getelementptr %struct.VERTEX, %struct.VERTEX* %tree, i32 0, i32 1 ; <%struct.VERTEX**> [#uses=1] 34 %8 = load %struct.VERTEX*, %struct.VERTEX** %7, align 4 ; <%struct.VERTEX*> [#uses=1] 35 call void @build_delaunay(%struct.EDGE_PAIR* noalias sret %delleft, %struct.VERTEX* %8, %struct.VERTEX* %tree) nounwind 36 %9 = getelementptr %struct.EDGE_PAIR, %struct.EDGE_PAIR* %delleft, i32 0, i32 0 ; <%struct.edge_rec**> [#uses=1] 37 %10 = load %struct.edge_rec*, %struct.edge_rec** %9, align 8 ; <%struct.edge_rec*> [#uses=2] 38 %11 = getelementptr %struct.EDGE_PAIR, %struct.EDGE_PAIR* %delleft, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 39 %12 = load %struct.edge_rec*, %struct.edge_rec** %11, align 4 ; <%struct.edge_rec*> [#uses=1] 40 %13 = getelementptr %struct.EDGE_PAIR, %struct.EDGE_PAIR* %delright, i32 0, i32 0 ; <%struct.edge_rec**> [#uses=1] 41 %14 = load %struct.edge_rec*, %struct.edge_rec** %13, align 8 ; <%struct.edge_rec*> [#uses=1] 42 %15 = getelementptr %struct.EDGE_PAIR, %struct.EDGE_PAIR* %delright, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 43 %16 = load %struct.edge_rec*, %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, %struct.edge_rec* %rdi_addr.0.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 50 %18 = load %struct.VERTEX*, %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, %struct.VERTEX* %18, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 53 %21 = load double, double* %20, align 4 ; <double> [#uses=3] 54 %22 = getelementptr %struct.VERTEX, %struct.VERTEX* %18, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 55 %23 = load double, 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, %struct.edge_rec* %29, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 66 %31 = load %struct.edge_rec*, %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, %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, %struct.edge_rec* %.pn6.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 83 %t1.0.i = load %struct.VERTEX*, %struct.VERTEX** %t1.0.in.i ; <%struct.VERTEX*> [#uses=2] 84 %t2.0.i = load %struct.VERTEX*, %struct.VERTEX** %t2.0.in.i ; <%struct.VERTEX*> [#uses=2] 85 %38 = getelementptr %struct.VERTEX, %struct.VERTEX* %t1.0.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 86 %39 = load double, double* %38, align 4 ; <double> [#uses=3] 87 %40 = getelementptr %struct.VERTEX, %struct.VERTEX* %t1.0.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 88 %41 = load double, double* %40, align 4 ; <double> [#uses=3] 89 %42 = getelementptr %struct.VERTEX, %struct.VERTEX* %t2.0.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 90 %43 = load double, double* %42, align 4 ; <double> [#uses=1] 91 %44 = getelementptr %struct.VERTEX, %struct.VERTEX* %t2.0.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 92 %45 = load double, 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, %struct.edge_rec* %56, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 108 %58 = load %struct.VERTEX*, %struct.VERTEX** %57, align 4 ; <%struct.VERTEX*> [#uses=2] 109 %59 = getelementptr %struct.VERTEX, %struct.VERTEX* %58, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 110 %60 = load double, double* %59, align 4 ; <double> [#uses=1] 111 %61 = getelementptr %struct.VERTEX, %struct.VERTEX* %58, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 112 %62 = load double, 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, %struct.edge_rec* %56, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 125 %72 = load %struct.edge_rec*, %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, %struct.edge_rec* %77, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 135 %79 = load %struct.edge_rec*, %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, %struct.edge_rec* %ldi_addr.0.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 143 %87 = load %struct.VERTEX*, %struct.VERTEX** %86, align 4 ; <%struct.VERTEX*> [#uses=1] 144 %88 = call %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=6] 145 %89 = getelementptr %struct.edge_rec, %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, %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, %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, %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, %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, %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*, %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, %struct.edge_rec* %85, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 172 %110 = load %struct.edge_rec*, %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, %struct.edge_rec* %116, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 180 %118 = load %struct.edge_rec*, %struct.edge_rec** %117, align 4 ; <%struct.edge_rec*> [#uses=1] 181 %119 = getelementptr %struct.edge_rec, %struct.edge_rec* %108, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 182 %120 = load %struct.edge_rec*, %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*, %struct.edge_rec** %89, align 4 ; <%struct.edge_rec*> [#uses=1] 186 %122 = load %struct.edge_rec*, %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, %struct.edge_rec* %124, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 192 %126 = load %struct.edge_rec*, %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, %struct.edge_rec* %ldi_addr.0.i, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 200 %134 = load %struct.edge_rec*, %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, %struct.edge_rec* %140, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 208 %142 = load %struct.edge_rec*, %struct.edge_rec** %141, align 4 ; <%struct.edge_rec*> [#uses=1] 209 %143 = getelementptr %struct.edge_rec, %struct.edge_rec* %132, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 210 %144 = load %struct.edge_rec*, %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*, %struct.edge_rec** %125, align 4 ; <%struct.edge_rec*> [#uses=1] 214 %146 = load %struct.edge_rec*, %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, %struct.edge_rec* %150, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 222 %152 = load %struct.edge_rec*, %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*, %struct.VERTEX** %90, align 4 ; <%struct.VERTEX*> [#uses=1] 230 %160 = getelementptr %struct.edge_rec, %struct.edge_rec* %124, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 231 %161 = load %struct.VERTEX*, %struct.VERTEX** %160, align 4 ; <%struct.VERTEX*> [#uses=1] 232 %162 = getelementptr %struct.edge_rec, %struct.edge_rec* %16, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 233 %163 = load %struct.VERTEX*, %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, %struct.edge_rec* %10, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 237 %166 = load %struct.VERTEX*, %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, %struct.edge_rec* %lcand.2.i, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 247 %169 = load %struct.edge_rec*, %struct.edge_rec** %168, align 4 ; <%struct.edge_rec*> [#uses=3] 248 %170 = getelementptr %struct.edge_rec, %struct.edge_rec* %basel.0.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=3] 249 %171 = load %struct.VERTEX*, %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, %struct.edge_rec* %174, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=3] 254 %176 = load %struct.VERTEX*, %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, %struct.edge_rec* %179, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 259 %181 = load %struct.VERTEX*, %struct.VERTEX** %180, align 4 ; <%struct.VERTEX*> [#uses=2] 260 %182 = getelementptr %struct.VERTEX, %struct.VERTEX* %171, i32 0, i32 0, i32 0 ; <double*> [#uses=2] 261 %183 = load double, double* %182, align 4 ; <double> [#uses=2] 262 %184 = getelementptr %struct.VERTEX, %struct.VERTEX* %171, i32 0, i32 0, i32 1 ; <double*> [#uses=2] 263 %185 = load double, double* %184, align 4 ; <double> [#uses=2] 264 %186 = getelementptr %struct.VERTEX, %struct.VERTEX* %181, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 265 %187 = load double, double* %186, align 4 ; <double> [#uses=1] 266 %188 = getelementptr %struct.VERTEX, %struct.VERTEX* %181, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 267 %189 = load double, double* %188, align 4 ; <double> [#uses=1] 268 %190 = getelementptr %struct.VERTEX, %struct.VERTEX* %176, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 269 %191 = load double, double* %190, align 4 ; <double> [#uses=2] 270 %192 = getelementptr %struct.VERTEX, %struct.VERTEX* %176, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 271 %193 = load double, 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, %struct.VERTEX* %171, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 284 %avail_edge.promoted25 = load %struct.edge_rec*, %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, %struct.edge_rec* %208, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 295 %210 = load %struct.edge_rec*, %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, %struct.edge_rec* %lcand.0.i, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 303 %218 = load %struct.edge_rec*, %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, %struct.edge_rec* %216, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 311 %226 = load %struct.edge_rec*, %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, %struct.edge_rec* %232, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 319 %234 = load %struct.edge_rec*, %struct.edge_rec** %233, align 4 ; <%struct.edge_rec*> [#uses=1] 320 %235 = getelementptr %struct.edge_rec, %struct.edge_rec* %224, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 321 %236 = load %struct.edge_rec*, %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*, %struct.edge_rec** %217, align 4 ; <%struct.edge_rec*> [#uses=1] 325 %238 = load %struct.edge_rec*, %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, %struct.edge_rec* %243, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 334 %245 = load %struct.edge_rec*, %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, %struct.edge_rec* %252, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 343 %254 = load %struct.edge_rec*, %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, %struct.edge_rec* %251, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 351 %262 = load %struct.edge_rec*, %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, %struct.edge_rec* %268, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 359 %270 = load %struct.edge_rec*, %struct.edge_rec** %269, align 4 ; <%struct.edge_rec*> [#uses=1] 360 %271 = getelementptr %struct.edge_rec, %struct.edge_rec* %260, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 361 %272 = load %struct.edge_rec*, %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*, %struct.edge_rec** %253, align 4 ; <%struct.edge_rec*> [#uses=1] 365 %274 = load %struct.edge_rec*, %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, %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, %struct.edge_rec* %t.0.i, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 372 %278 = load %struct.edge_rec*, %struct.edge_rec** %277, align 4 ; <%struct.edge_rec*> [#uses=2] 373 %.pre.i = load double, double* %182, align 4 ; <double> [#uses=1] 374 %.pre22.i = load double, 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, %struct.edge_rec* %.pn5.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 393 %v2.0.in.i = getelementptr %struct.edge_rec, %struct.edge_rec* %.pn4.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 394 %v3.0.in.i = getelementptr %struct.edge_rec, %struct.edge_rec* %lcand.2.pn.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 395 %v1.0.i = load %struct.VERTEX*, %struct.VERTEX** %v1.0.in.i ; <%struct.VERTEX*> [#uses=3] 396 %v2.0.i = load %struct.VERTEX*, %struct.VERTEX** %v2.0.in.i ; <%struct.VERTEX*> [#uses=3] 397 %v3.0.i = load %struct.VERTEX*, %struct.VERTEX** %v3.0.in.i ; <%struct.VERTEX*> [#uses=3] 398 %281 = load double, double* %202, align 4 ; <double> [#uses=3] 399 %282 = getelementptr %struct.VERTEX, %struct.VERTEX* %v1.0.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 400 %283 = load double, double* %282, align 4 ; <double> [#uses=1] 401 %284 = fsub double %283, %280 ; <double> [#uses=2] 402 %285 = getelementptr %struct.VERTEX, %struct.VERTEX* %v1.0.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 403 %286 = load double, double* %285, align 4 ; <double> [#uses=1] 404 %287 = fsub double %286, %279 ; <double> [#uses=2] 405 %288 = getelementptr %struct.VERTEX, %struct.VERTEX* %v1.0.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 406 %289 = load double, double* %288, align 4 ; <double> [#uses=1] 407 %290 = getelementptr %struct.VERTEX, %struct.VERTEX* %v2.0.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 408 %291 = load double, double* %290, align 4 ; <double> [#uses=1] 409 %292 = fsub double %291, %280 ; <double> [#uses=2] 410 %293 = getelementptr %struct.VERTEX, %struct.VERTEX* %v2.0.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 411 %294 = load double, double* %293, align 4 ; <double> [#uses=1] 412 %295 = fsub double %294, %279 ; <double> [#uses=2] 413 %296 = getelementptr %struct.VERTEX, %struct.VERTEX* %v2.0.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 414 %297 = load double, double* %296, align 4 ; <double> [#uses=1] 415 %298 = getelementptr %struct.VERTEX, %struct.VERTEX* %v3.0.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 416 %299 = load double, double* %298, align 4 ; <double> [#uses=1] 417 %300 = fsub double %299, %280 ; <double> [#uses=2] 418 %301 = getelementptr %struct.VERTEX, %struct.VERTEX* %v3.0.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 419 %302 = load double, double* %301, align 4 ; <double> [#uses=1] 420 %303 = fsub double %302, %279 ; <double> [#uses=2] 421 %304 = getelementptr %struct.VERTEX, %struct.VERTEX* %v3.0.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 422 %305 = load double, 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*, %struct.VERTEX** %170, align 4 ; <%struct.VERTEX*> [#uses=1] 446 %.pre24.i = load %struct.VERTEX*, %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, %struct.edge_rec* %331, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 460 %333 = load %struct.edge_rec*, %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, %struct.edge_rec* %340, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 469 %342 = load %struct.VERTEX*, %struct.VERTEX** %341, align 4 ; <%struct.VERTEX*> [#uses=2] 470 %343 = getelementptr %struct.VERTEX, %struct.VERTEX* %325, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 471 %344 = load double, double* %343, align 4 ; <double> [#uses=1] 472 %345 = getelementptr %struct.VERTEX, %struct.VERTEX* %325, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 473 %346 = load double, double* %345, align 4 ; <double> [#uses=1] 474 %347 = getelementptr %struct.VERTEX, %struct.VERTEX* %342, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 475 %348 = load double, double* %347, align 4 ; <double> [#uses=1] 476 %349 = getelementptr %struct.VERTEX, %struct.VERTEX* %342, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 477 %350 = load double, double* %349, align 4 ; <double> [#uses=1] 478 %351 = getelementptr %struct.VERTEX, %struct.VERTEX* %324, i32 0, i32 0, i32 0 ; <double*> [#uses=2] 479 %352 = load double, double* %351, align 4 ; <double> [#uses=3] 480 %353 = getelementptr %struct.VERTEX, %struct.VERTEX* %324, i32 0, i32 0, i32 1 ; <double*> [#uses=2] 481 %354 = load double, 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, %struct.VERTEX* %324, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 494 %avail_edge.promoted = load %struct.edge_rec*, %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, %struct.edge_rec* %369, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 505 %371 = load %struct.edge_rec*, %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, %struct.edge_rec* %rcand.0.i, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 513 %379 = load %struct.edge_rec*, %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, %struct.edge_rec* %377, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 521 %387 = load %struct.edge_rec*, %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, %struct.edge_rec* %393, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 529 %395 = load %struct.edge_rec*, %struct.edge_rec** %394, align 4 ; <%struct.edge_rec*> [#uses=1] 530 %396 = getelementptr %struct.edge_rec, %struct.edge_rec* %385, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 531 %397 = load %struct.edge_rec*, %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*, %struct.edge_rec** %378, align 4 ; <%struct.edge_rec*> [#uses=1] 535 %399 = load %struct.edge_rec*, %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, %struct.edge_rec* %404, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 544 %406 = load %struct.edge_rec*, %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, %struct.edge_rec* %413, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 553 %415 = load %struct.edge_rec*, %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, %struct.edge_rec* %412, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 561 %423 = load %struct.edge_rec*, %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, %struct.edge_rec* %429, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 569 %431 = load %struct.edge_rec*, %struct.edge_rec** %430, align 4 ; <%struct.edge_rec*> [#uses=1] 570 %432 = getelementptr %struct.edge_rec, %struct.edge_rec* %421, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 571 %433 = load %struct.edge_rec*, %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*, %struct.edge_rec** %414, align 4 ; <%struct.edge_rec*> [#uses=1] 575 %435 = load %struct.edge_rec*, %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, %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, %struct.edge_rec* %442, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 587 %444 = load %struct.edge_rec*, %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, double* %351, align 4 ; <double> [#uses=1] 594 %.pre26.i = load double, 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, %struct.edge_rec* %.pn3.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 613 %v2.1.in.i = getelementptr %struct.edge_rec, %struct.edge_rec* %.pn.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 614 %v3.1.in.i = getelementptr %struct.edge_rec, %struct.edge_rec* %rcand.2.pn.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 615 %v1.1.i = load %struct.VERTEX*, %struct.VERTEX** %v1.1.in.i ; <%struct.VERTEX*> [#uses=3] 616 %v2.1.i = load %struct.VERTEX*, %struct.VERTEX** %v2.1.in.i ; <%struct.VERTEX*> [#uses=3] 617 %v3.1.i = load %struct.VERTEX*, %struct.VERTEX** %v3.1.in.i ; <%struct.VERTEX*> [#uses=3] 618 %452 = load double, double* %363, align 4 ; <double> [#uses=3] 619 %453 = getelementptr %struct.VERTEX, %struct.VERTEX* %v1.1.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 620 %454 = load double, double* %453, align 4 ; <double> [#uses=1] 621 %455 = fsub double %454, %451 ; <double> [#uses=2] 622 %456 = getelementptr %struct.VERTEX, %struct.VERTEX* %v1.1.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 623 %457 = load double, double* %456, align 4 ; <double> [#uses=1] 624 %458 = fsub double %457, %450 ; <double> [#uses=2] 625 %459 = getelementptr %struct.VERTEX, %struct.VERTEX* %v1.1.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 626 %460 = load double, double* %459, align 4 ; <double> [#uses=1] 627 %461 = getelementptr %struct.VERTEX, %struct.VERTEX* %v2.1.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 628 %462 = load double, double* %461, align 4 ; <double> [#uses=1] 629 %463 = fsub double %462, %451 ; <double> [#uses=2] 630 %464 = getelementptr %struct.VERTEX, %struct.VERTEX* %v2.1.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 631 %465 = load double, double* %464, align 4 ; <double> [#uses=1] 632 %466 = fsub double %465, %450 ; <double> [#uses=2] 633 %467 = getelementptr %struct.VERTEX, %struct.VERTEX* %v2.1.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 634 %468 = load double, double* %467, align 4 ; <double> [#uses=1] 635 %469 = getelementptr %struct.VERTEX, %struct.VERTEX* %v3.1.i, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 636 %470 = load double, double* %469, align 4 ; <double> [#uses=1] 637 %471 = fsub double %470, %451 ; <double> [#uses=2] 638 %472 = getelementptr %struct.VERTEX, %struct.VERTEX* %v3.1.i, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 639 %473 = load double, double* %472, align 4 ; <double> [#uses=1] 640 %474 = fsub double %473, %450 ; <double> [#uses=2] 641 %475 = getelementptr %struct.VERTEX, %struct.VERTEX* %v3.1.i, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 642 %476 = load double, 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*, %struct.VERTEX** %170, align 4 ; <%struct.VERTEX*> [#uses=1] 666 %.pre28.i = load %struct.VERTEX*, %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, %struct.edge_rec* %499, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 677 %501 = load %struct.VERTEX*, %struct.VERTEX** %500, align 4 ; <%struct.VERTEX*> [#uses=4] 678 %502 = getelementptr %struct.VERTEX, %struct.VERTEX* %496, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 679 %503 = load double, double* %502, align 4 ; <double> [#uses=1] 680 %504 = getelementptr %struct.VERTEX, %struct.VERTEX* %496, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 681 %505 = load double, double* %504, align 4 ; <double> [#uses=1] 682 %506 = getelementptr %struct.VERTEX, %struct.VERTEX* %501, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 683 %507 = load double, double* %506, align 4 ; <double> [#uses=2] 684 %508 = getelementptr %struct.VERTEX, %struct.VERTEX* %501, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 685 %509 = load double, double* %508, align 4 ; <double> [#uses=2] 686 %510 = getelementptr %struct.VERTEX, %struct.VERTEX* %495, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 687 %511 = load double, double* %510, align 4 ; <double> [#uses=3] 688 %512 = getelementptr %struct.VERTEX, %struct.VERTEX* %495, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 689 %513 = load double, 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, %struct.edge_rec* %524, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 702 %526 = load %struct.VERTEX*, %struct.VERTEX** %525, align 4 ; <%struct.VERTEX*> [#uses=4] 703 %527 = getelementptr %struct.VERTEX, %struct.VERTEX* %526, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 704 %528 = load double, double* %527, align 4 ; <double> [#uses=4] 705 %529 = getelementptr %struct.VERTEX, %struct.VERTEX* %526, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 706 %530 = load double, 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, %struct.edge_rec* %lcand.1.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 718 %539 = load %struct.VERTEX*, %struct.VERTEX** %538, align 4 ; <%struct.VERTEX*> [#uses=3] 719 %540 = getelementptr %struct.edge_rec, %struct.edge_rec* %rcand.1.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 720 %541 = load %struct.VERTEX*, %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, %struct.VERTEX* %526, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 728 %543 = load double, 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, %struct.VERTEX* %501, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 732 %547 = load double, double* %546, align 4 ; <double> [#uses=1] 733 %548 = getelementptr %struct.VERTEX, %struct.VERTEX* %539, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 734 %549 = load double, double* %548, align 4 ; <double> [#uses=1] 735 %550 = fsub double %549, %528 ; <double> [#uses=2] 736 %551 = getelementptr %struct.VERTEX, %struct.VERTEX* %539, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 737 %552 = load double, double* %551, align 4 ; <double> [#uses=1] 738 %553 = fsub double %552, %530 ; <double> [#uses=2] 739 %554 = getelementptr %struct.VERTEX, %struct.VERTEX* %539, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 740 %555 = load double, double* %554, align 4 ; <double> [#uses=1] 741 %556 = getelementptr %struct.VERTEX, %struct.VERTEX* %541, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 742 %557 = load double, double* %556, align 4 ; <double> [#uses=1] 743 %558 = fsub double %557, %528 ; <double> [#uses=2] 744 %559 = getelementptr %struct.VERTEX, %struct.VERTEX* %541, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 745 %560 = load double, double* %559, align 4 ; <double> [#uses=1] 746 %561 = fsub double %560, %530 ; <double> [#uses=2] 747 %562 = getelementptr %struct.VERTEX, %struct.VERTEX* %541, i32 0, i32 0, i32 2 ; <double*> [#uses=1] 748 %563 = load double, 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, %struct.edge_rec* %586, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 776 %588 = load %struct.edge_rec*, %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 %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=5] 784 %596 = getelementptr %struct.edge_rec, %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, %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, %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, %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, %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, %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*, %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, %struct.edge_rec* %594, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 811 %617 = load %struct.edge_rec*, %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, %struct.edge_rec* %623, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 819 %625 = load %struct.edge_rec*, %struct.edge_rec** %624, align 4 ; <%struct.edge_rec*> [#uses=1] 820 %626 = getelementptr %struct.edge_rec, %struct.edge_rec* %615, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 821 %627 = load %struct.edge_rec*, %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*, %struct.edge_rec** %596, align 4 ; <%struct.edge_rec*> [#uses=1] 825 %629 = load %struct.edge_rec*, %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, %struct.edge_rec* %631, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 831 %633 = load %struct.edge_rec*, %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, %struct.edge_rec* %174, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 839 %641 = load %struct.edge_rec*, %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, %struct.edge_rec* %647, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 847 %649 = load %struct.edge_rec*, %struct.edge_rec** %648, align 4 ; <%struct.edge_rec*> [#uses=1] 848 %650 = getelementptr %struct.edge_rec, %struct.edge_rec* %639, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 849 %651 = load %struct.edge_rec*, %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*, %struct.edge_rec** %632, align 4 ; <%struct.edge_rec*> [#uses=1] 853 %653 = load %struct.edge_rec*, %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, %struct.edge_rec* %658, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 862 %660 = load %struct.edge_rec*, %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, %struct.edge_rec* %671, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 878 %673 = load %struct.edge_rec*, %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 %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=4] 886 %681 = getelementptr %struct.edge_rec, %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, %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, %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, %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, %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, %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*, %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, %struct.edge_rec* %499, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 913 %702 = load %struct.edge_rec*, %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, %struct.edge_rec* %708, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 921 %710 = load %struct.edge_rec*, %struct.edge_rec** %709, align 4 ; <%struct.edge_rec*> [#uses=1] 922 %711 = getelementptr %struct.edge_rec, %struct.edge_rec* %700, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 923 %712 = load %struct.edge_rec*, %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*, %struct.edge_rec** %681, align 4 ; <%struct.edge_rec*> [#uses=1] 927 %714 = load %struct.edge_rec*, %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, %struct.edge_rec* %716, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 933 %718 = load %struct.edge_rec*, %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, %struct.edge_rec* %679, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 941 %726 = load %struct.edge_rec*, %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, %struct.edge_rec* %732, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 949 %734 = load %struct.edge_rec*, %struct.edge_rec** %733, align 4 ; <%struct.edge_rec*> [#uses=1] 950 %735 = getelementptr %struct.edge_rec, %struct.edge_rec* %724, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 951 %736 = load %struct.edge_rec*, %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*, %struct.edge_rec** %717, align 4 ; <%struct.edge_rec*> [#uses=1] 955 %738 = load %struct.edge_rec*, %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*, %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, %struct.edge_rec* %ldo_addr.0.ph.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 963 %741 = load %struct.VERTEX*, %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, %struct.edge_rec* %745, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 973 %747 = load %struct.edge_rec*, %struct.edge_rec** %746, align 4 ; <%struct.edge_rec*> [#uses=3] 974 %748 = getelementptr %struct.edge_rec, %struct.edge_rec* %747, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 975 %749 = load %struct.VERTEX*, %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, %struct.edge_rec* %rdo.05, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 982 %752 = load %struct.edge_rec*, %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, %struct.edge_rec* %755, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 987 %757 = load %struct.VERTEX*, %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, %struct.edge_rec* %rdo_addr.0.i, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 994 %760 = load %struct.VERTEX*, %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, %struct.VERTEX* %tree, i32 0, i32 1 ; <%struct.VERTEX**> [#uses=1] 1006 %763 = load %struct.VERTEX*, %struct.VERTEX** %762, align 4 ; <%struct.VERTEX*> [#uses=4] 1007 %764 = icmp eq %struct.VERTEX* %763, null ; <i1> [#uses=1] 1008 %765 = call %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=5] 1009 %766 = getelementptr %struct.edge_rec, %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, %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 i32 @puts(i8* getelementptr ([21 x i8], [21 x i8]* @_2E_str7, i32 0, i32 0)) nounwind ; <i32> [#uses=0] 1016 call 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, %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, %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, %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, %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, %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, %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, %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, %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 %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=4] 1057 %793 = getelementptr %struct.edge_rec, %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, %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, %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, %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, %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, %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, %struct.edge_rec* %807, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 1079 %809 = load %struct.edge_rec*, %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*, %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, %struct.edge_rec* %822, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 1094 %824 = load %struct.edge_rec*, %struct.edge_rec** %823, align 4 ; <%struct.edge_rec*> [#uses=1] 1095 %825 = getelementptr %struct.edge_rec, %struct.edge_rec* %815, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 1096 %826 = load %struct.edge_rec*, %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*, %struct.edge_rec** %808, align 4 ; <%struct.edge_rec*> [#uses=1] 1100 %828 = load %struct.edge_rec*, %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, %struct.edge_rec* %830, i32 0, i32 0 ; <%struct.VERTEX**> [#uses=1] 1106 %832 = load %struct.VERTEX*, %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, %struct.edge_rec* %836, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 1112 %838 = load %struct.edge_rec*, %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*, %struct.VERTEX** %767, align 4 ; <%struct.VERTEX*> [#uses=1] 1120 %846 = call %struct.edge_rec* @alloc_edge() nounwind ; <%struct.edge_rec*> [#uses=4] 1121 %847 = getelementptr %struct.edge_rec, %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, %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, %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, %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, %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, %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*, %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, %struct.edge_rec* %844, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 1148 %868 = load %struct.edge_rec*, %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, %struct.edge_rec* %874, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 1156 %876 = load %struct.edge_rec*, %struct.edge_rec** %875, align 4 ; <%struct.edge_rec*> [#uses=1] 1157 %877 = getelementptr %struct.edge_rec, %struct.edge_rec* %866, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 1158 %878 = load %struct.edge_rec*, %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*, %struct.edge_rec** %847, align 4 ; <%struct.edge_rec*> [#uses=1] 1162 %880 = load %struct.edge_rec*, %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, %struct.edge_rec* %882, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=6] 1168 %884 = load %struct.edge_rec*, %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*, %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, %struct.edge_rec* %897, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 1183 %899 = load %struct.edge_rec*, %struct.edge_rec** %898, align 4 ; <%struct.edge_rec*> [#uses=1] 1184 %900 = getelementptr %struct.edge_rec, %struct.edge_rec* %890, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 1185 %901 = load %struct.edge_rec*, %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*, %struct.edge_rec** %883, align 4 ; <%struct.edge_rec*> [#uses=1] 1189 %903 = load %struct.edge_rec*, %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, %struct.VERTEX* %763, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 1193 %905 = load double, double* %904, align 4 ; <double> [#uses=2] 1194 %906 = getelementptr %struct.VERTEX, %struct.VERTEX* %763, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 1195 %907 = load double, double* %906, align 4 ; <double> [#uses=2] 1196 %908 = getelementptr %struct.VERTEX, %struct.VERTEX* %extra, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 1197 %909 = load double, double* %908, align 4 ; <double> [#uses=3] 1198 %910 = getelementptr %struct.VERTEX, %struct.VERTEX* %extra, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 1199 %911 = load double, double* %910, align 4 ; <double> [#uses=3] 1200 %912 = getelementptr %struct.VERTEX, %struct.VERTEX* %tree, i32 0, i32 0, i32 0 ; <double*> [#uses=1] 1201 %913 = load double, double* %912, align 4 ; <double> [#uses=3] 1202 %914 = getelementptr %struct.VERTEX, %struct.VERTEX* %tree, i32 0, i32 0, i32 1 ; <double*> [#uses=1] 1203 %915 = load double, 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, %struct.edge_rec* %935, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 1231 %937 = load %struct.edge_rec*, %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*, %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, %struct.edge_rec* %943, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 1246 %952 = load %struct.edge_rec*, %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, %struct.edge_rec* %958, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 1254 %960 = load %struct.edge_rec*, %struct.edge_rec** %959, align 4 ; <%struct.edge_rec*> [#uses=1] 1255 %961 = getelementptr %struct.edge_rec, %struct.edge_rec* %950, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 1256 %962 = load %struct.edge_rec*, %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*, %struct.edge_rec** %847, align 4 ; <%struct.edge_rec*> [#uses=1] 1260 %964 = load %struct.edge_rec*, %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, %struct.edge_rec* %968, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=1] 1268 %970 = load %struct.edge_rec*, %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*, %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, %struct.edge_rec* %976, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=3] 1283 %985 = load %struct.edge_rec*, %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, %struct.edge_rec* %991, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 1291 %993 = load %struct.edge_rec*, %struct.edge_rec** %992, align 4 ; <%struct.edge_rec*> [#uses=1] 1292 %994 = getelementptr %struct.edge_rec, %struct.edge_rec* %983, i32 0, i32 1 ; <%struct.edge_rec**> [#uses=2] 1293 %995 = load %struct.edge_rec*, %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*, %struct.edge_rec** %883, align 4 ; <%struct.edge_rec*> [#uses=1] 1297 %997 = load %struct.edge_rec*, %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*, %struct.edge_rec** @avail_edge, align 4 ; <%struct.edge_rec*> [#uses=1] 1302 %1000 = getelementptr %struct.edge_rec, %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 i32 @puts(i8* nocapture) nounwind 1320 1321 declare void @exit(i32) noreturn nounwind 1322 1323 declare %struct.edge_rec* @alloc_edge() nounwind 1324