1339 lines
50 KiB
LLVM
1339 lines
50 KiB
LLVM
; RUN: llc -mtriple armv6-apple-darwin10 -mattr=+vfp2 -filetype asm -o - %s | FileCheck %s
|
|
|
|
%struct.EDGE_PAIR = type { ptr, ptr }
|
|
%struct.VEC2 = type { double, double, double }
|
|
%struct.VERTEX = type { %struct.VEC2, ptr, ptr }
|
|
%struct.edge_rec = type { ptr, ptr, i32, ptr }
|
|
@avail_edge = internal global ptr null
|
|
@_2E_str7 = internal constant [21 x i8] c"ERROR: Only 1 point!\00", section "__TEXT,__cstring,cstring_literals", align 1
|
|
@llvm.used = appending global [1 x ptr] [ptr @build_delaunay], section "llvm.metadata"
|
|
|
|
define void @build_delaunay(ptr noalias nocapture sret(%struct.EDGE_PAIR) %agg.result, ptr %tree, ptr %extra) nounwind {
|
|
entry:
|
|
%delright = alloca %struct.EDGE_PAIR, align 8
|
|
%delleft = alloca %struct.EDGE_PAIR, align 8
|
|
%0 = icmp eq ptr %tree, null
|
|
br i1 %0, label %bb8, label %bb
|
|
|
|
bb:
|
|
%1 = getelementptr %struct.VERTEX, ptr %tree, i32 0, i32 2
|
|
%2 = load ptr, ptr %1, align 4
|
|
%3 = icmp eq ptr %2, null
|
|
br i1 %3, label %bb7, label %bb1.i
|
|
|
|
bb1.i:
|
|
%tree_addr.0.i = phi ptr [ %5, %bb1.i ], [ %tree, %bb ]
|
|
%4 = getelementptr %struct.VERTEX, ptr %tree_addr.0.i, i32 0, i32 1
|
|
%5 = load ptr, ptr %4, align 4
|
|
%6 = icmp eq ptr %5, null
|
|
br i1 %6, label %get_low.exit, label %bb1.i
|
|
|
|
get_low.exit:
|
|
call void @build_delaunay(ptr noalias sret(%struct.EDGE_PAIR) %delright, ptr %2, ptr %extra) nounwind
|
|
%7 = getelementptr %struct.VERTEX, ptr %tree, i32 0, i32 1
|
|
%8 = load ptr, ptr %7, align 4
|
|
call void @build_delaunay(ptr noalias sret(%struct.EDGE_PAIR) %delleft, ptr %8, ptr %tree) nounwind
|
|
%9 = getelementptr %struct.EDGE_PAIR, ptr %delleft, i32 0, i32 0
|
|
%10 = load ptr, ptr %9, align 8
|
|
%11 = getelementptr %struct.EDGE_PAIR, ptr %delleft, i32 0, i32 1
|
|
%12 = load ptr, ptr %11, align 4
|
|
%13 = getelementptr %struct.EDGE_PAIR, ptr %delright, i32 0, i32 0
|
|
%14 = load ptr, ptr %13, align 8
|
|
%15 = getelementptr %struct.EDGE_PAIR, ptr %delright, i32 0, i32 1
|
|
%16 = load ptr, ptr %15, align 4
|
|
br label %bb.i
|
|
|
|
bb.i:
|
|
%rdi_addr.0.i = phi ptr [ %14, %get_low.exit ], [ %72, %bb4.i ]
|
|
%ldi_addr.1.i = phi ptr [ %12, %get_low.exit ], [ %ldi_addr.0.i, %bb4.i ]
|
|
%17 = getelementptr %struct.edge_rec, ptr %rdi_addr.0.i, i32 0, i32 0
|
|
%18 = load ptr, ptr %17, align 4
|
|
%19 = ptrtoint ptr %ldi_addr.1.i to i32
|
|
%20 = getelementptr %struct.VERTEX, ptr %18, i32 0, i32 0, i32 0
|
|
%21 = load double, ptr %20, align 4
|
|
%22 = getelementptr %struct.VERTEX, ptr %18, i32 0, i32 0, i32 1
|
|
%23 = load double, ptr %22, align 4
|
|
br label %bb2.i
|
|
|
|
bb1.i1:
|
|
%24 = ptrtoint ptr %ldi_addr.0.i to i32
|
|
%25 = add i32 %24, 48
|
|
%26 = and i32 %25, 63
|
|
%27 = and i32 %24, -64
|
|
%28 = or i32 %26, %27
|
|
%29 = inttoptr i32 %28 to ptr
|
|
%30 = getelementptr %struct.edge_rec, ptr %29, i32 0, i32 1
|
|
%31 = load ptr, ptr %30, align 4
|
|
%32 = ptrtoint ptr %31 to i32
|
|
%33 = add i32 %32, 16
|
|
%34 = and i32 %33, 63
|
|
%35 = and i32 %32, -64
|
|
%36 = or i32 %34, %35
|
|
%37 = inttoptr i32 %36 to ptr
|
|
br label %bb2.i
|
|
|
|
bb2.i:
|
|
%ldi_addr.1.pn.i = phi ptr [ %ldi_addr.1.i, %bb.i ], [ %37, %bb1.i1 ]
|
|
%.pn6.in.in.i = phi i32 [ %19, %bb.i ], [ %36, %bb1.i1 ]
|
|
%ldi_addr.0.i = phi ptr [ %ldi_addr.1.i, %bb.i ], [ %37, %bb1.i1 ]
|
|
%.pn6.in.i = xor i32 %.pn6.in.in.i, 32
|
|
%.pn6.i = inttoptr i32 %.pn6.in.i to ptr
|
|
%t1.0.in.i = getelementptr %struct.edge_rec, ptr %ldi_addr.1.pn.i, i32 0, i32 0
|
|
%t2.0.in.i = getelementptr %struct.edge_rec, ptr %.pn6.i, i32 0, i32 0
|
|
%t1.0.i = load ptr, ptr %t1.0.in.i
|
|
%t2.0.i = load ptr, ptr %t2.0.in.i
|
|
%38 = getelementptr %struct.VERTEX, ptr %t1.0.i, i32 0, i32 0, i32 0
|
|
%39 = load double, ptr %38, align 4
|
|
%40 = getelementptr %struct.VERTEX, ptr %t1.0.i, i32 0, i32 0, i32 1
|
|
%41 = load double, ptr %40, align 4
|
|
%42 = getelementptr %struct.VERTEX, ptr %t2.0.i, i32 0, i32 0, i32 0
|
|
%43 = load double, ptr %42, align 4
|
|
%44 = getelementptr %struct.VERTEX, ptr %t2.0.i, i32 0, i32 0, i32 1
|
|
%45 = load double, ptr %44, align 4
|
|
%46 = fsub double %39, %21
|
|
%47 = fsub double %45, %23
|
|
%48 = fmul double %46, %47
|
|
%49 = fsub double %43, %21
|
|
%50 = fsub double %41, %23
|
|
%51 = fmul double %49, %50
|
|
%52 = fsub double %48, %51
|
|
%53 = fcmp ogt double %52, 0.000000e+00
|
|
br i1 %53, label %bb1.i1, label %bb3.i
|
|
|
|
bb3.i:
|
|
%54 = ptrtoint ptr %rdi_addr.0.i to i32
|
|
%55 = xor i32 %54, 32
|
|
%56 = inttoptr i32 %55 to ptr
|
|
%57 = getelementptr %struct.edge_rec, ptr %56, i32 0, i32 0
|
|
%58 = load ptr, ptr %57, align 4
|
|
%59 = getelementptr %struct.VERTEX, ptr %58, i32 0, i32 0, i32 0
|
|
%60 = load double, ptr %59, align 4
|
|
%61 = getelementptr %struct.VERTEX, ptr %58, i32 0, i32 0, i32 1
|
|
%62 = load double, ptr %61, align 4
|
|
%63 = fsub double %60, %39
|
|
%64 = fsub double %23, %41
|
|
%65 = fmul double %63, %64
|
|
%66 = fsub double %21, %39
|
|
%67 = fsub double %62, %41
|
|
%68 = fmul double %66, %67
|
|
%69 = fsub double %65, %68
|
|
%70 = fcmp ogt double %69, 0.000000e+00
|
|
br i1 %70, label %bb4.i, label %bb5.i
|
|
|
|
bb4.i:
|
|
%71 = getelementptr %struct.edge_rec, ptr %56, i32 0, i32 1
|
|
%72 = load ptr, ptr %71, align 4
|
|
br label %bb.i
|
|
|
|
bb5.i:
|
|
%73 = add i32 %55, 48
|
|
%74 = and i32 %73, 63
|
|
%75 = and i32 %55, -64
|
|
%76 = or i32 %74, %75
|
|
%77 = inttoptr i32 %76 to ptr
|
|
%78 = getelementptr %struct.edge_rec, ptr %77, i32 0, i32 1
|
|
%79 = load ptr, ptr %78, align 4
|
|
%80 = ptrtoint ptr %79 to i32
|
|
%81 = add i32 %80, 16
|
|
%82 = and i32 %81, 63
|
|
%83 = and i32 %80, -64
|
|
%84 = or i32 %82, %83
|
|
%85 = inttoptr i32 %84 to ptr
|
|
%86 = getelementptr %struct.edge_rec, ptr %ldi_addr.0.i, i32 0, i32 0
|
|
%87 = load ptr, ptr %86, align 4
|
|
%88 = call ptr @alloc_edge() nounwind
|
|
%89 = getelementptr %struct.edge_rec, ptr %88, i32 0, i32 1
|
|
store ptr %88, ptr %89, align 4
|
|
%90 = getelementptr %struct.edge_rec, ptr %88, i32 0, i32 0
|
|
store ptr %18, ptr %90, align 4
|
|
%91 = ptrtoint ptr %88 to i32
|
|
%92 = add i32 %91, 16
|
|
%93 = inttoptr i32 %92 to ptr
|
|
%94 = add i32 %91, 48
|
|
%95 = inttoptr i32 %94 to ptr
|
|
%96 = getelementptr %struct.edge_rec, ptr %93, i32 0, i32 1
|
|
store ptr %95, ptr %96, align 4
|
|
%97 = add i32 %91, 32
|
|
%98 = inttoptr i32 %97 to ptr
|
|
%99 = getelementptr %struct.edge_rec, ptr %98, i32 0, i32 1
|
|
store ptr %98, ptr %99, align 4
|
|
%100 = getelementptr %struct.edge_rec, ptr %98, i32 0, i32 0
|
|
store ptr %87, ptr %100, align 4
|
|
%101 = getelementptr %struct.edge_rec, ptr %95, i32 0, i32 1
|
|
store ptr %93, ptr %101, align 4
|
|
%102 = load ptr, ptr %89, align 4
|
|
%103 = ptrtoint ptr %102 to i32
|
|
%104 = add i32 %103, 16
|
|
%105 = and i32 %104, 63
|
|
%106 = and i32 %103, -64
|
|
%107 = or i32 %105, %106
|
|
%108 = inttoptr i32 %107 to ptr
|
|
%109 = getelementptr %struct.edge_rec, ptr %85, i32 0, i32 1
|
|
%110 = load ptr, ptr %109, align 4
|
|
%111 = ptrtoint ptr %110 to i32
|
|
%112 = add i32 %111, 16
|
|
%113 = and i32 %112, 63
|
|
%114 = and i32 %111, -64
|
|
%115 = or i32 %113, %114
|
|
%116 = inttoptr i32 %115 to ptr
|
|
%117 = getelementptr %struct.edge_rec, ptr %116, i32 0, i32 1
|
|
%118 = load ptr, ptr %117, align 4
|
|
%119 = getelementptr %struct.edge_rec, ptr %108, i32 0, i32 1
|
|
%120 = load ptr, ptr %119, align 4
|
|
store ptr %118, ptr %119, align 4
|
|
store ptr %120, ptr %117, align 4
|
|
%121 = load ptr, ptr %89, align 4
|
|
%122 = load ptr, ptr %109, align 4
|
|
store ptr %121, ptr %109, align 4
|
|
store ptr %122, ptr %89, align 4
|
|
%123 = xor i32 %91, 32
|
|
%124 = inttoptr i32 %123 to ptr
|
|
%125 = getelementptr %struct.edge_rec, ptr %124, i32 0, i32 1
|
|
%126 = load ptr, ptr %125, align 4
|
|
%127 = ptrtoint ptr %126 to i32
|
|
%128 = add i32 %127, 16
|
|
%129 = and i32 %128, 63
|
|
%130 = and i32 %127, -64
|
|
%131 = or i32 %129, %130
|
|
%132 = inttoptr i32 %131 to ptr
|
|
%133 = getelementptr %struct.edge_rec, ptr %ldi_addr.0.i, i32 0, i32 1
|
|
%134 = load ptr, ptr %133, align 4
|
|
%135 = ptrtoint ptr %134 to i32
|
|
%136 = add i32 %135, 16
|
|
%137 = and i32 %136, 63
|
|
%138 = and i32 %135, -64
|
|
%139 = or i32 %137, %138
|
|
%140 = inttoptr i32 %139 to ptr
|
|
%141 = getelementptr %struct.edge_rec, ptr %140, i32 0, i32 1
|
|
%142 = load ptr, ptr %141, align 4
|
|
%143 = getelementptr %struct.edge_rec, ptr %132, i32 0, i32 1
|
|
%144 = load ptr, ptr %143, align 4
|
|
store ptr %142, ptr %143, align 4
|
|
store ptr %144, ptr %141, align 4
|
|
%145 = load ptr, ptr %125, align 4
|
|
%146 = load ptr, ptr %133, align 4
|
|
store ptr %145, ptr %133, align 4
|
|
store ptr %146, ptr %125, align 4
|
|
%147 = and i32 %92, 63
|
|
%148 = and i32 %91, -64
|
|
%149 = or i32 %147, %148
|
|
%150 = inttoptr i32 %149 to ptr
|
|
%151 = getelementptr %struct.edge_rec, ptr %150, i32 0, i32 1
|
|
%152 = load ptr, ptr %151, align 4
|
|
%153 = ptrtoint ptr %152 to i32
|
|
%154 = add i32 %153, 16
|
|
%155 = and i32 %154, 63
|
|
%156 = and i32 %153, -64
|
|
%157 = or i32 %155, %156
|
|
%158 = inttoptr i32 %157 to ptr
|
|
%159 = load ptr, ptr %90, align 4
|
|
%160 = getelementptr %struct.edge_rec, ptr %124, i32 0, i32 0
|
|
%161 = load ptr, ptr %160, align 4
|
|
%162 = getelementptr %struct.edge_rec, ptr %16, i32 0, i32 0
|
|
%163 = load ptr, ptr %162, align 4
|
|
%164 = icmp eq ptr %163, %159
|
|
%rdo_addr.0.i = select i1 %164, ptr %88, ptr %16
|
|
%165 = getelementptr %struct.edge_rec, ptr %10, i32 0, i32 0
|
|
%166 = load ptr, ptr %165, align 4
|
|
%167 = icmp eq ptr %166, %161
|
|
%ldo_addr.0.ph.i = select i1 %167, ptr %124, ptr %10
|
|
br label %bb9.i
|
|
|
|
bb9.i:
|
|
%lcand.2.i = phi ptr [ %146, %bb5.i ], [ %lcand.1.i, %bb24.i ], [ %739, %bb25.i ]
|
|
%rcand.2.i = phi ptr [ %158, %bb5.i ], [ %666, %bb24.i ], [ %rcand.1.i, %bb25.i ]
|
|
%basel.0.i = phi ptr [ %88, %bb5.i ], [ %595, %bb24.i ], [ %716, %bb25.i ]
|
|
%168 = getelementptr %struct.edge_rec, ptr %lcand.2.i, i32 0, i32 1
|
|
%169 = load ptr, ptr %168, align 4
|
|
%170 = getelementptr %struct.edge_rec, ptr %basel.0.i, i32 0, i32 0
|
|
%171 = load ptr, ptr %170, align 4
|
|
%172 = ptrtoint ptr %basel.0.i to i32
|
|
%173 = xor i32 %172, 32
|
|
%174 = inttoptr i32 %173 to ptr
|
|
%175 = getelementptr %struct.edge_rec, ptr %174, i32 0, i32 0
|
|
%176 = load ptr, ptr %175, align 4
|
|
%177 = ptrtoint ptr %169 to i32
|
|
%178 = xor i32 %177, 32
|
|
%179 = inttoptr i32 %178 to ptr
|
|
%180 = getelementptr %struct.edge_rec, ptr %179, i32 0, i32 0
|
|
%181 = load ptr, ptr %180, align 4
|
|
%182 = getelementptr %struct.VERTEX, ptr %171, i32 0, i32 0, i32 0
|
|
%183 = load double, ptr %182, align 4
|
|
%184 = getelementptr %struct.VERTEX, ptr %171, i32 0, i32 0, i32 1
|
|
%185 = load double, ptr %184, align 4
|
|
%186 = getelementptr %struct.VERTEX, ptr %181, i32 0, i32 0, i32 0
|
|
%187 = load double, ptr %186, align 4
|
|
%188 = getelementptr %struct.VERTEX, ptr %181, i32 0, i32 0, i32 1
|
|
%189 = load double, ptr %188, align 4
|
|
%190 = getelementptr %struct.VERTEX, ptr %176, i32 0, i32 0, i32 0
|
|
%191 = load double, ptr %190, align 4
|
|
%192 = getelementptr %struct.VERTEX, ptr %176, i32 0, i32 0, i32 1
|
|
%193 = load double, ptr %192, align 4
|
|
%194 = fsub double %183, %191
|
|
%195 = fsub double %189, %193
|
|
%196 = fmul double %194, %195
|
|
%197 = fsub double %187, %191
|
|
%198 = fsub double %185, %193
|
|
%199 = fmul double %197, %198
|
|
%200 = fsub double %196, %199
|
|
%201 = fcmp ogt double %200, 0.000000e+00
|
|
br i1 %201, label %bb10.i, label %bb13.i
|
|
|
|
bb10.i:
|
|
%202 = getelementptr %struct.VERTEX, ptr %171, i32 0, i32 0, i32 2
|
|
%avail_edge.promoted25 = load ptr, ptr @avail_edge
|
|
br label %bb12.i
|
|
|
|
bb11.i:
|
|
%203 = ptrtoint ptr %lcand.0.i to i32
|
|
%204 = add i32 %203, 16
|
|
%205 = and i32 %204, 63
|
|
%206 = and i32 %203, -64
|
|
%207 = or i32 %205, %206
|
|
%208 = inttoptr i32 %207 to ptr
|
|
%209 = getelementptr %struct.edge_rec, ptr %208, i32 0, i32 1
|
|
%210 = load ptr, ptr %209, align 4
|
|
%211 = ptrtoint ptr %210 to i32
|
|
%212 = add i32 %211, 16
|
|
%213 = and i32 %212, 63
|
|
%214 = and i32 %211, -64
|
|
%215 = or i32 %213, %214
|
|
%216 = inttoptr i32 %215 to ptr
|
|
%217 = getelementptr %struct.edge_rec, ptr %lcand.0.i, i32 0, i32 1
|
|
%218 = load ptr, ptr %217, align 4
|
|
%219 = ptrtoint ptr %218 to i32
|
|
%220 = add i32 %219, 16
|
|
%221 = and i32 %220, 63
|
|
%222 = and i32 %219, -64
|
|
%223 = or i32 %221, %222
|
|
%224 = inttoptr i32 %223 to ptr
|
|
%225 = getelementptr %struct.edge_rec, ptr %216, i32 0, i32 1
|
|
%226 = load ptr, ptr %225, align 4
|
|
%227 = ptrtoint ptr %226 to i32
|
|
%228 = add i32 %227, 16
|
|
%229 = and i32 %228, 63
|
|
%230 = and i32 %227, -64
|
|
%231 = or i32 %229, %230
|
|
%232 = inttoptr i32 %231 to ptr
|
|
%233 = getelementptr %struct.edge_rec, ptr %232, i32 0, i32 1
|
|
%234 = load ptr, ptr %233, align 4
|
|
%235 = getelementptr %struct.edge_rec, ptr %224, i32 0, i32 1
|
|
%236 = load ptr, ptr %235, align 4
|
|
store ptr %234, ptr %235, align 4
|
|
store ptr %236, ptr %233, align 4
|
|
%237 = load ptr, ptr %217, align 4
|
|
%238 = load ptr, ptr %225, align 4
|
|
store ptr %237, ptr %225, align 4
|
|
store ptr %238, ptr %217, align 4
|
|
%239 = xor i32 %203, 32
|
|
%240 = add i32 %239, 16
|
|
%241 = and i32 %240, 63
|
|
%242 = or i32 %241, %206
|
|
%243 = inttoptr i32 %242 to ptr
|
|
%244 = getelementptr %struct.edge_rec, ptr %243, i32 0, i32 1
|
|
%245 = load ptr, ptr %244, align 4
|
|
%246 = ptrtoint ptr %245 to i32
|
|
%247 = add i32 %246, 16
|
|
%248 = and i32 %247, 63
|
|
%249 = and i32 %246, -64
|
|
%250 = or i32 %248, %249
|
|
%251 = inttoptr i32 %250 to ptr
|
|
%252 = inttoptr i32 %239 to ptr
|
|
%253 = getelementptr %struct.edge_rec, ptr %252, i32 0, i32 1
|
|
%254 = load ptr, ptr %253, align 4
|
|
%255 = ptrtoint ptr %254 to i32
|
|
%256 = add i32 %255, 16
|
|
%257 = and i32 %256, 63
|
|
%258 = and i32 %255, -64
|
|
%259 = or i32 %257, %258
|
|
%260 = inttoptr i32 %259 to ptr
|
|
%261 = getelementptr %struct.edge_rec, ptr %251, i32 0, i32 1
|
|
%262 = load ptr, ptr %261, align 4
|
|
%263 = ptrtoint ptr %262 to i32
|
|
%264 = add i32 %263, 16
|
|
%265 = and i32 %264, 63
|
|
%266 = and i32 %263, -64
|
|
%267 = or i32 %265, %266
|
|
%268 = inttoptr i32 %267 to ptr
|
|
%269 = getelementptr %struct.edge_rec, ptr %268, i32 0, i32 1
|
|
%270 = load ptr, ptr %269, align 4
|
|
%271 = getelementptr %struct.edge_rec, ptr %260, i32 0, i32 1
|
|
%272 = load ptr, ptr %271, align 4
|
|
store ptr %270, ptr %271, align 4
|
|
store ptr %272, ptr %269, align 4
|
|
%273 = load ptr, ptr %253, align 4
|
|
%274 = load ptr, ptr %261, align 4
|
|
store ptr %273, ptr %261, align 4
|
|
store ptr %274, ptr %253, align 4
|
|
%275 = inttoptr i32 %206 to ptr
|
|
%276 = getelementptr %struct.edge_rec, ptr %275, i32 0, i32 1
|
|
store ptr %avail_edge.tmp.026, ptr %276, align 4
|
|
%277 = getelementptr %struct.edge_rec, ptr %t.0.i, i32 0, i32 1
|
|
%278 = load ptr, ptr %277, align 4
|
|
%.pre.i = load double, ptr %182, align 4
|
|
%.pre22.i = load double, ptr %184, align 4
|
|
br label %bb12.i
|
|
|
|
bb12.i:
|
|
%avail_edge.tmp.026 = phi ptr [ %avail_edge.promoted25, %bb10.i ], [ %275, %bb11.i ]
|
|
%279 = phi double [ %.pre22.i, %bb11.i ], [ %185, %bb10.i ]
|
|
%280 = phi double [ %.pre.i, %bb11.i ], [ %183, %bb10.i ]
|
|
%lcand.0.i = phi ptr [ %lcand.2.i, %bb10.i ], [ %t.0.i, %bb11.i ]
|
|
%t.0.i = phi ptr [ %169, %bb10.i ], [ %278, %bb11.i ]
|
|
%.pn5.in.in.in.i = phi ptr [ %lcand.2.i, %bb10.i ], [ %t.0.i, %bb11.i ]
|
|
%.pn4.in.in.in.i = phi ptr [ %169, %bb10.i ], [ %278, %bb11.i ]
|
|
%lcand.2.pn.i = phi ptr [ %lcand.2.i, %bb10.i ], [ %t.0.i, %bb11.i ]
|
|
%.pn5.in.in.i = ptrtoint ptr %.pn5.in.in.in.i to i32
|
|
%.pn4.in.in.i = ptrtoint ptr %.pn4.in.in.in.i to i32
|
|
%.pn5.in.i = xor i32 %.pn5.in.in.i, 32
|
|
%.pn4.in.i = xor i32 %.pn4.in.in.i, 32
|
|
%.pn5.i = inttoptr i32 %.pn5.in.i to ptr
|
|
%.pn4.i = inttoptr i32 %.pn4.in.i to ptr
|
|
%v1.0.in.i = getelementptr %struct.edge_rec, ptr %.pn5.i, i32 0, i32 0
|
|
%v2.0.in.i = getelementptr %struct.edge_rec, ptr %.pn4.i, i32 0, i32 0
|
|
%v3.0.in.i = getelementptr %struct.edge_rec, ptr %lcand.2.pn.i, i32 0, i32 0
|
|
%v1.0.i = load ptr, ptr %v1.0.in.i
|
|
%v2.0.i = load ptr, ptr %v2.0.in.i
|
|
%v3.0.i = load ptr, ptr %v3.0.in.i
|
|
%281 = load double, ptr %202, align 4
|
|
%282 = getelementptr %struct.VERTEX, ptr %v1.0.i, i32 0, i32 0, i32 0
|
|
%283 = load double, ptr %282, align 4
|
|
%284 = fsub double %283, %280
|
|
%285 = getelementptr %struct.VERTEX, ptr %v1.0.i, i32 0, i32 0, i32 1
|
|
%286 = load double, ptr %285, align 4
|
|
%287 = fsub double %286, %279
|
|
%288 = getelementptr %struct.VERTEX, ptr %v1.0.i, i32 0, i32 0, i32 2
|
|
%289 = load double, ptr %288, align 4
|
|
%290 = getelementptr %struct.VERTEX, ptr %v2.0.i, i32 0, i32 0, i32 0
|
|
%291 = load double, ptr %290, align 4
|
|
%292 = fsub double %291, %280
|
|
%293 = getelementptr %struct.VERTEX, ptr %v2.0.i, i32 0, i32 0, i32 1
|
|
%294 = load double, ptr %293, align 4
|
|
%295 = fsub double %294, %279
|
|
%296 = getelementptr %struct.VERTEX, ptr %v2.0.i, i32 0, i32 0, i32 2
|
|
%297 = load double, ptr %296, align 4
|
|
%298 = getelementptr %struct.VERTEX, ptr %v3.0.i, i32 0, i32 0, i32 0
|
|
%299 = load double, ptr %298, align 4
|
|
%300 = fsub double %299, %280
|
|
%301 = getelementptr %struct.VERTEX, ptr %v3.0.i, i32 0, i32 0, i32 1
|
|
%302 = load double, ptr %301, align 4
|
|
%303 = fsub double %302, %279
|
|
%304 = getelementptr %struct.VERTEX, ptr %v3.0.i, i32 0, i32 0, i32 2
|
|
%305 = load double, ptr %304, align 4
|
|
%306 = fsub double %289, %281
|
|
%307 = fmul double %292, %303
|
|
%308 = fmul double %295, %300
|
|
%309 = fsub double %307, %308
|
|
%310 = fmul double %306, %309
|
|
%311 = fsub double %297, %281
|
|
%312 = fmul double %300, %287
|
|
%313 = fmul double %303, %284
|
|
%314 = fsub double %312, %313
|
|
%315 = fmul double %311, %314
|
|
%316 = fadd double %315, %310
|
|
%317 = fsub double %305, %281
|
|
%318 = fmul double %284, %295
|
|
%319 = fmul double %287, %292
|
|
%320 = fsub double %318, %319
|
|
%321 = fmul double %317, %320
|
|
%322 = fadd double %321, %316
|
|
%323 = fcmp ogt double %322, 0.000000e+00
|
|
br i1 %323, label %bb11.i, label %bb13.loopexit.i
|
|
|
|
bb13.loopexit.i:
|
|
store ptr %avail_edge.tmp.026, ptr @avail_edge
|
|
%.pre23.i = load ptr, ptr %170, align 4
|
|
%.pre24.i = load ptr, ptr %175, align 4
|
|
br label %bb13.i
|
|
|
|
bb13.i:
|
|
%324 = phi ptr [ %.pre24.i, %bb13.loopexit.i ], [ %176, %bb9.i ]
|
|
%325 = phi ptr [ %.pre23.i, %bb13.loopexit.i ], [ %171, %bb9.i ]
|
|
%lcand.1.i = phi ptr [ %lcand.0.i, %bb13.loopexit.i ], [ %lcand.2.i, %bb9.i ]
|
|
%326 = ptrtoint ptr %rcand.2.i to i32
|
|
%327 = add i32 %326, 16
|
|
%328 = and i32 %327, 63
|
|
%329 = and i32 %326, -64
|
|
%330 = or i32 %328, %329
|
|
%331 = inttoptr i32 %330 to ptr
|
|
%332 = getelementptr %struct.edge_rec, ptr %331, i32 0, i32 1
|
|
%333 = load ptr, ptr %332, align 4
|
|
%334 = ptrtoint ptr %333 to i32
|
|
%335 = add i32 %334, 16
|
|
%336 = and i32 %335, 63
|
|
%337 = and i32 %334, -64
|
|
%338 = or i32 %336, %337
|
|
%339 = xor i32 %338, 32
|
|
%340 = inttoptr i32 %339 to ptr
|
|
%341 = getelementptr %struct.edge_rec, ptr %340, i32 0, i32 0
|
|
%342 = load ptr, ptr %341, align 4
|
|
%343 = getelementptr %struct.VERTEX, ptr %325, i32 0, i32 0, i32 0
|
|
%344 = load double, ptr %343, align 4
|
|
%345 = getelementptr %struct.VERTEX, ptr %325, i32 0, i32 0, i32 1
|
|
%346 = load double, ptr %345, align 4
|
|
%347 = getelementptr %struct.VERTEX, ptr %342, i32 0, i32 0, i32 0
|
|
%348 = load double, ptr %347, align 4
|
|
%349 = getelementptr %struct.VERTEX, ptr %342, i32 0, i32 0, i32 1
|
|
%350 = load double, ptr %349, align 4
|
|
%351 = getelementptr %struct.VERTEX, ptr %324, i32 0, i32 0, i32 0
|
|
%352 = load double, ptr %351, align 4
|
|
%353 = getelementptr %struct.VERTEX, ptr %324, i32 0, i32 0, i32 1
|
|
%354 = load double, ptr %353, align 4
|
|
%355 = fsub double %344, %352
|
|
%356 = fsub double %350, %354
|
|
%357 = fmul double %355, %356
|
|
%358 = fsub double %348, %352
|
|
%359 = fsub double %346, %354
|
|
%360 = fmul double %358, %359
|
|
%361 = fsub double %357, %360
|
|
%362 = fcmp ogt double %361, 0.000000e+00
|
|
br i1 %362, label %bb14.i, label %bb17.i
|
|
|
|
bb14.i:
|
|
%363 = getelementptr %struct.VERTEX, ptr %324, i32 0, i32 0, i32 2
|
|
%avail_edge.promoted = load ptr, ptr @avail_edge
|
|
br label %bb16.i
|
|
|
|
bb15.i:
|
|
%364 = ptrtoint ptr %rcand.0.i to i32
|
|
%365 = add i32 %364, 16
|
|
%366 = and i32 %365, 63
|
|
%367 = and i32 %364, -64
|
|
%368 = or i32 %366, %367
|
|
%369 = inttoptr i32 %368 to ptr
|
|
%370 = getelementptr %struct.edge_rec, ptr %369, i32 0, i32 1
|
|
%371 = load ptr, ptr %370, align 4
|
|
%372 = ptrtoint ptr %371 to i32
|
|
%373 = add i32 %372, 16
|
|
%374 = and i32 %373, 63
|
|
%375 = and i32 %372, -64
|
|
%376 = or i32 %374, %375
|
|
%377 = inttoptr i32 %376 to ptr
|
|
%378 = getelementptr %struct.edge_rec, ptr %rcand.0.i, i32 0, i32 1
|
|
%379 = load ptr, ptr %378, align 4
|
|
%380 = ptrtoint ptr %379 to i32
|
|
%381 = add i32 %380, 16
|
|
%382 = and i32 %381, 63
|
|
%383 = and i32 %380, -64
|
|
%384 = or i32 %382, %383
|
|
%385 = inttoptr i32 %384 to ptr
|
|
%386 = getelementptr %struct.edge_rec, ptr %377, i32 0, i32 1
|
|
%387 = load ptr, ptr %386, align 4
|
|
%388 = ptrtoint ptr %387 to i32
|
|
%389 = add i32 %388, 16
|
|
%390 = and i32 %389, 63
|
|
%391 = and i32 %388, -64
|
|
%392 = or i32 %390, %391
|
|
%393 = inttoptr i32 %392 to ptr
|
|
%394 = getelementptr %struct.edge_rec, ptr %393, i32 0, i32 1
|
|
%395 = load ptr, ptr %394, align 4
|
|
%396 = getelementptr %struct.edge_rec, ptr %385, i32 0, i32 1
|
|
%397 = load ptr, ptr %396, align 4
|
|
store ptr %395, ptr %396, align 4
|
|
store ptr %397, ptr %394, align 4
|
|
%398 = load ptr, ptr %378, align 4
|
|
%399 = load ptr, ptr %386, align 4
|
|
store ptr %398, ptr %386, align 4
|
|
store ptr %399, ptr %378, align 4
|
|
%400 = xor i32 %364, 32
|
|
%401 = add i32 %400, 16
|
|
%402 = and i32 %401, 63
|
|
%403 = or i32 %402, %367
|
|
%404 = inttoptr i32 %403 to ptr
|
|
%405 = getelementptr %struct.edge_rec, ptr %404, i32 0, i32 1
|
|
%406 = load ptr, ptr %405, align 4
|
|
%407 = ptrtoint ptr %406 to i32
|
|
%408 = add i32 %407, 16
|
|
%409 = and i32 %408, 63
|
|
%410 = and i32 %407, -64
|
|
%411 = or i32 %409, %410
|
|
%412 = inttoptr i32 %411 to ptr
|
|
%413 = inttoptr i32 %400 to ptr
|
|
%414 = getelementptr %struct.edge_rec, ptr %413, i32 0, i32 1
|
|
%415 = load ptr, ptr %414, align 4
|
|
%416 = ptrtoint ptr %415 to i32
|
|
%417 = add i32 %416, 16
|
|
%418 = and i32 %417, 63
|
|
%419 = and i32 %416, -64
|
|
%420 = or i32 %418, %419
|
|
%421 = inttoptr i32 %420 to ptr
|
|
%422 = getelementptr %struct.edge_rec, ptr %412, i32 0, i32 1
|
|
%423 = load ptr, ptr %422, align 4
|
|
%424 = ptrtoint ptr %423 to i32
|
|
%425 = add i32 %424, 16
|
|
%426 = and i32 %425, 63
|
|
%427 = and i32 %424, -64
|
|
%428 = or i32 %426, %427
|
|
%429 = inttoptr i32 %428 to ptr
|
|
%430 = getelementptr %struct.edge_rec, ptr %429, i32 0, i32 1
|
|
%431 = load ptr, ptr %430, align 4
|
|
%432 = getelementptr %struct.edge_rec, ptr %421, i32 0, i32 1
|
|
%433 = load ptr, ptr %432, align 4
|
|
store ptr %431, ptr %432, align 4
|
|
store ptr %433, ptr %430, align 4
|
|
%434 = load ptr, ptr %414, align 4
|
|
%435 = load ptr, ptr %422, align 4
|
|
store ptr %434, ptr %422, align 4
|
|
store ptr %435, ptr %414, align 4
|
|
%436 = inttoptr i32 %367 to ptr
|
|
%437 = getelementptr %struct.edge_rec, ptr %436, i32 0, i32 1
|
|
store ptr %avail_edge.tmp.0, ptr %437, align 4
|
|
%438 = add i32 %t.1.in.i, 16
|
|
%439 = and i32 %438, 63
|
|
%440 = and i32 %t.1.in.i, -64
|
|
%441 = or i32 %439, %440
|
|
%442 = inttoptr i32 %441 to ptr
|
|
%443 = getelementptr %struct.edge_rec, ptr %442, i32 0, i32 1
|
|
%444 = load ptr, ptr %443, align 4
|
|
%445 = ptrtoint ptr %444 to i32
|
|
%446 = add i32 %445, 16
|
|
%447 = and i32 %446, 63
|
|
%448 = and i32 %445, -64
|
|
%449 = or i32 %447, %448
|
|
%.pre25.i = load double, ptr %351, align 4
|
|
%.pre26.i = load double, ptr %353, align 4
|
|
br label %bb16.i
|
|
|
|
bb16.i:
|
|
%avail_edge.tmp.0 = phi ptr [ %avail_edge.promoted, %bb14.i ], [ %436, %bb15.i ]
|
|
%450 = phi double [ %.pre26.i, %bb15.i ], [ %354, %bb14.i ]
|
|
%451 = phi double [ %.pre25.i, %bb15.i ], [ %352, %bb14.i ]
|
|
%rcand.0.i = phi ptr [ %rcand.2.i, %bb14.i ], [ %t.1.i, %bb15.i ]
|
|
%t.1.in.i = phi i32 [ %338, %bb14.i ], [ %449, %bb15.i ]
|
|
%.pn3.in.in.i = phi i32 [ %338, %bb14.i ], [ %449, %bb15.i ]
|
|
%.pn.in.in.in.i = phi ptr [ %rcand.2.i, %bb14.i ], [ %t.1.i, %bb15.i ]
|
|
%rcand.2.pn.i = phi ptr [ %rcand.2.i, %bb14.i ], [ %t.1.i, %bb15.i ]
|
|
%t.1.i = inttoptr i32 %t.1.in.i to ptr
|
|
%.pn.in.in.i = ptrtoint ptr %.pn.in.in.in.i to i32
|
|
%.pn3.in.i = xor i32 %.pn3.in.in.i, 32
|
|
%.pn.in.i = xor i32 %.pn.in.in.i, 32
|
|
%.pn3.i = inttoptr i32 %.pn3.in.i to ptr
|
|
%.pn.i = inttoptr i32 %.pn.in.i to ptr
|
|
%v1.1.in.i = getelementptr %struct.edge_rec, ptr %.pn3.i, i32 0, i32 0
|
|
%v2.1.in.i = getelementptr %struct.edge_rec, ptr %.pn.i, i32 0, i32 0
|
|
%v3.1.in.i = getelementptr %struct.edge_rec, ptr %rcand.2.pn.i, i32 0, i32 0
|
|
%v1.1.i = load ptr, ptr %v1.1.in.i
|
|
%v2.1.i = load ptr, ptr %v2.1.in.i
|
|
%v3.1.i = load ptr, ptr %v3.1.in.i
|
|
%452 = load double, ptr %363, align 4
|
|
%453 = getelementptr %struct.VERTEX, ptr %v1.1.i, i32 0, i32 0, i32 0
|
|
%454 = load double, ptr %453, align 4
|
|
%455 = fsub double %454, %451
|
|
%456 = getelementptr %struct.VERTEX, ptr %v1.1.i, i32 0, i32 0, i32 1
|
|
%457 = load double, ptr %456, align 4
|
|
%458 = fsub double %457, %450
|
|
%459 = getelementptr %struct.VERTEX, ptr %v1.1.i, i32 0, i32 0, i32 2
|
|
%460 = load double, ptr %459, align 4
|
|
%461 = getelementptr %struct.VERTEX, ptr %v2.1.i, i32 0, i32 0, i32 0
|
|
%462 = load double, ptr %461, align 4
|
|
%463 = fsub double %462, %451
|
|
%464 = getelementptr %struct.VERTEX, ptr %v2.1.i, i32 0, i32 0, i32 1
|
|
%465 = load double, ptr %464, align 4
|
|
%466 = fsub double %465, %450
|
|
%467 = getelementptr %struct.VERTEX, ptr %v2.1.i, i32 0, i32 0, i32 2
|
|
%468 = load double, ptr %467, align 4
|
|
%469 = getelementptr %struct.VERTEX, ptr %v3.1.i, i32 0, i32 0, i32 0
|
|
%470 = load double, ptr %469, align 4
|
|
%471 = fsub double %470, %451
|
|
%472 = getelementptr %struct.VERTEX, ptr %v3.1.i, i32 0, i32 0, i32 1
|
|
%473 = load double, ptr %472, align 4
|
|
%474 = fsub double %473, %450
|
|
%475 = getelementptr %struct.VERTEX, ptr %v3.1.i, i32 0, i32 0, i32 2
|
|
%476 = load double, ptr %475, align 4
|
|
%477 = fsub double %460, %452
|
|
%478 = fmul double %463, %474
|
|
%479 = fmul double %466, %471
|
|
%480 = fsub double %478, %479
|
|
%481 = fmul double %477, %480
|
|
%482 = fsub double %468, %452
|
|
%483 = fmul double %471, %458
|
|
%484 = fmul double %474, %455
|
|
%485 = fsub double %483, %484
|
|
%486 = fmul double %482, %485
|
|
%487 = fadd double %486, %481
|
|
%488 = fsub double %476, %452
|
|
%489 = fmul double %455, %466
|
|
%490 = fmul double %458, %463
|
|
%491 = fsub double %489, %490
|
|
%492 = fmul double %488, %491
|
|
%493 = fadd double %492, %487
|
|
%494 = fcmp ogt double %493, 0.000000e+00
|
|
br i1 %494, label %bb15.i, label %bb17.loopexit.i
|
|
|
|
bb17.loopexit.i:
|
|
store ptr %avail_edge.tmp.0, ptr @avail_edge
|
|
%.pre27.i = load ptr, ptr %170, align 4
|
|
%.pre28.i = load ptr, ptr %175, align 4
|
|
br label %bb17.i
|
|
|
|
bb17.i:
|
|
%495 = phi ptr [ %.pre28.i, %bb17.loopexit.i ], [ %324, %bb13.i ]
|
|
%496 = phi ptr [ %.pre27.i, %bb17.loopexit.i ], [ %325, %bb13.i ]
|
|
%rcand.1.i = phi ptr [ %rcand.0.i, %bb17.loopexit.i ], [ %rcand.2.i, %bb13.i ]
|
|
%497 = ptrtoint ptr %lcand.1.i to i32
|
|
%498 = xor i32 %497, 32
|
|
%499 = inttoptr i32 %498 to ptr
|
|
%500 = getelementptr %struct.edge_rec, ptr %499, i32 0, i32 0
|
|
%501 = load ptr, ptr %500, align 4
|
|
%502 = getelementptr %struct.VERTEX, ptr %496, i32 0, i32 0, i32 0
|
|
%503 = load double, ptr %502, align 4
|
|
%504 = getelementptr %struct.VERTEX, ptr %496, i32 0, i32 0, i32 1
|
|
%505 = load double, ptr %504, align 4
|
|
%506 = getelementptr %struct.VERTEX, ptr %501, i32 0, i32 0, i32 0
|
|
%507 = load double, ptr %506, align 4
|
|
%508 = getelementptr %struct.VERTEX, ptr %501, i32 0, i32 0, i32 1
|
|
%509 = load double, ptr %508, align 4
|
|
%510 = getelementptr %struct.VERTEX, ptr %495, i32 0, i32 0, i32 0
|
|
%511 = load double, ptr %510, align 4
|
|
%512 = getelementptr %struct.VERTEX, ptr %495, i32 0, i32 0, i32 1
|
|
%513 = load double, ptr %512, align 4
|
|
%514 = fsub double %503, %511
|
|
%515 = fsub double %509, %513
|
|
%516 = fmul double %514, %515
|
|
%517 = fsub double %507, %511
|
|
%518 = fsub double %505, %513
|
|
%519 = fmul double %517, %518
|
|
%520 = fsub double %516, %519
|
|
%521 = fcmp ogt double %520, 0.000000e+00
|
|
%522 = ptrtoint ptr %rcand.1.i to i32
|
|
%523 = xor i32 %522, 32
|
|
%524 = inttoptr i32 %523 to ptr
|
|
%525 = getelementptr %struct.edge_rec, ptr %524, i32 0, i32 0
|
|
%526 = load ptr, ptr %525, align 4
|
|
%527 = getelementptr %struct.VERTEX, ptr %526, i32 0, i32 0, i32 0
|
|
%528 = load double, ptr %527, align 4
|
|
%529 = getelementptr %struct.VERTEX, ptr %526, i32 0, i32 0, i32 1
|
|
%530 = load double, ptr %529, align 4
|
|
%531 = fsub double %530, %513
|
|
%532 = fmul double %514, %531
|
|
%533 = fsub double %528, %511
|
|
%534 = fmul double %533, %518
|
|
%535 = fsub double %532, %534
|
|
%536 = fcmp ogt double %535, 0.000000e+00
|
|
%537 = or i1 %536, %521
|
|
br i1 %537, label %bb21.i, label %do_merge.exit
|
|
|
|
bb21.i:
|
|
%538 = getelementptr %struct.edge_rec, ptr %lcand.1.i, i32 0, i32 0
|
|
%539 = load ptr, ptr %538, align 4
|
|
%540 = getelementptr %struct.edge_rec, ptr %rcand.1.i, i32 0, i32 0
|
|
%541 = load ptr, ptr %540, align 4
|
|
br i1 %521, label %bb22.i, label %bb24.i
|
|
|
|
bb22.i:
|
|
br i1 %536, label %bb23.i, label %bb25.i
|
|
|
|
bb23.i:
|
|
%542 = getelementptr %struct.VERTEX, ptr %526, i32 0, i32 0, i32 2
|
|
%543 = load double, ptr %542, align 4
|
|
%544 = fsub double %507, %528
|
|
%545 = fsub double %509, %530
|
|
%546 = getelementptr %struct.VERTEX, ptr %501, i32 0, i32 0, i32 2
|
|
%547 = load double, ptr %546, align 4
|
|
%548 = getelementptr %struct.VERTEX, ptr %539, i32 0, i32 0, i32 0
|
|
%549 = load double, ptr %548, align 4
|
|
%550 = fsub double %549, %528
|
|
%551 = getelementptr %struct.VERTEX, ptr %539, i32 0, i32 0, i32 1
|
|
%552 = load double, ptr %551, align 4
|
|
%553 = fsub double %552, %530
|
|
%554 = getelementptr %struct.VERTEX, ptr %539, i32 0, i32 0, i32 2
|
|
%555 = load double, ptr %554, align 4
|
|
%556 = getelementptr %struct.VERTEX, ptr %541, i32 0, i32 0, i32 0
|
|
%557 = load double, ptr %556, align 4
|
|
%558 = fsub double %557, %528
|
|
%559 = getelementptr %struct.VERTEX, ptr %541, i32 0, i32 0, i32 1
|
|
%560 = load double, ptr %559, align 4
|
|
%561 = fsub double %560, %530
|
|
%562 = getelementptr %struct.VERTEX, ptr %541, i32 0, i32 0, i32 2
|
|
%563 = load double, ptr %562, align 4
|
|
%564 = fsub double %547, %543
|
|
%565 = fmul double %550, %561
|
|
%566 = fmul double %553, %558
|
|
%567 = fsub double %565, %566
|
|
%568 = fmul double %564, %567
|
|
%569 = fsub double %555, %543
|
|
%570 = fmul double %558, %545
|
|
%571 = fmul double %561, %544
|
|
%572 = fsub double %570, %571
|
|
%573 = fmul double %569, %572
|
|
%574 = fadd double %573, %568
|
|
%575 = fsub double %563, %543
|
|
%576 = fmul double %544, %553
|
|
%577 = fmul double %545, %550
|
|
%578 = fsub double %576, %577
|
|
%579 = fmul double %575, %578
|
|
%580 = fadd double %579, %574
|
|
%581 = fcmp ogt double %580, 0.000000e+00
|
|
br i1 %581, label %bb24.i, label %bb25.i
|
|
|
|
bb24.i:
|
|
%582 = add i32 %522, 48
|
|
%583 = and i32 %582, 63
|
|
%584 = and i32 %522, -64
|
|
%585 = or i32 %583, %584
|
|
%586 = inttoptr i32 %585 to ptr
|
|
%587 = getelementptr %struct.edge_rec, ptr %586, i32 0, i32 1
|
|
%588 = load ptr, ptr %587, align 4
|
|
%589 = ptrtoint ptr %588 to i32
|
|
%590 = add i32 %589, 16
|
|
%591 = and i32 %590, 63
|
|
%592 = and i32 %589, -64
|
|
%593 = or i32 %591, %592
|
|
%594 = inttoptr i32 %593 to ptr
|
|
%595 = call ptr @alloc_edge() nounwind
|
|
%596 = getelementptr %struct.edge_rec, ptr %595, i32 0, i32 1
|
|
store ptr %595, ptr %596, align 4
|
|
%597 = getelementptr %struct.edge_rec, ptr %595, i32 0, i32 0
|
|
store ptr %526, ptr %597, align 4
|
|
%598 = ptrtoint ptr %595 to i32
|
|
%599 = add i32 %598, 16
|
|
%600 = inttoptr i32 %599 to ptr
|
|
%601 = add i32 %598, 48
|
|
%602 = inttoptr i32 %601 to ptr
|
|
%603 = getelementptr %struct.edge_rec, ptr %600, i32 0, i32 1
|
|
store ptr %602, ptr %603, align 4
|
|
%604 = add i32 %598, 32
|
|
%605 = inttoptr i32 %604 to ptr
|
|
%606 = getelementptr %struct.edge_rec, ptr %605, i32 0, i32 1
|
|
store ptr %605, ptr %606, align 4
|
|
%607 = getelementptr %struct.edge_rec, ptr %605, i32 0, i32 0
|
|
store ptr %495, ptr %607, align 4
|
|
%608 = getelementptr %struct.edge_rec, ptr %602, i32 0, i32 1
|
|
store ptr %600, ptr %608, align 4
|
|
%609 = load ptr, ptr %596, align 4
|
|
%610 = ptrtoint ptr %609 to i32
|
|
%611 = add i32 %610, 16
|
|
%612 = and i32 %611, 63
|
|
%613 = and i32 %610, -64
|
|
%614 = or i32 %612, %613
|
|
%615 = inttoptr i32 %614 to ptr
|
|
%616 = getelementptr %struct.edge_rec, ptr %594, i32 0, i32 1
|
|
%617 = load ptr, ptr %616, align 4
|
|
%618 = ptrtoint ptr %617 to i32
|
|
%619 = add i32 %618, 16
|
|
%620 = and i32 %619, 63
|
|
%621 = and i32 %618, -64
|
|
%622 = or i32 %620, %621
|
|
%623 = inttoptr i32 %622 to ptr
|
|
%624 = getelementptr %struct.edge_rec, ptr %623, i32 0, i32 1
|
|
%625 = load ptr, ptr %624, align 4
|
|
%626 = getelementptr %struct.edge_rec, ptr %615, i32 0, i32 1
|
|
%627 = load ptr, ptr %626, align 4
|
|
store ptr %625, ptr %626, align 4
|
|
store ptr %627, ptr %624, align 4
|
|
%628 = load ptr, ptr %596, align 4
|
|
%629 = load ptr, ptr %616, align 4
|
|
store ptr %628, ptr %616, align 4
|
|
store ptr %629, ptr %596, align 4
|
|
%630 = xor i32 %598, 32
|
|
%631 = inttoptr i32 %630 to ptr
|
|
%632 = getelementptr %struct.edge_rec, ptr %631, i32 0, i32 1
|
|
%633 = load ptr, ptr %632, align 4
|
|
%634 = ptrtoint ptr %633 to i32
|
|
%635 = add i32 %634, 16
|
|
%636 = and i32 %635, 63
|
|
%637 = and i32 %634, -64
|
|
%638 = or i32 %636, %637
|
|
%639 = inttoptr i32 %638 to ptr
|
|
%640 = getelementptr %struct.edge_rec, ptr %174, i32 0, i32 1
|
|
%641 = load ptr, ptr %640, align 4
|
|
%642 = ptrtoint ptr %641 to i32
|
|
%643 = add i32 %642, 16
|
|
%644 = and i32 %643, 63
|
|
%645 = and i32 %642, -64
|
|
%646 = or i32 %644, %645
|
|
%647 = inttoptr i32 %646 to ptr
|
|
%648 = getelementptr %struct.edge_rec, ptr %647, i32 0, i32 1
|
|
%649 = load ptr, ptr %648, align 4
|
|
%650 = getelementptr %struct.edge_rec, ptr %639, i32 0, i32 1
|
|
%651 = load ptr, ptr %650, align 4
|
|
store ptr %649, ptr %650, align 4
|
|
store ptr %651, ptr %648, align 4
|
|
%652 = load ptr, ptr %632, align 4
|
|
%653 = load ptr, ptr %640, align 4
|
|
store ptr %652, ptr %640, align 4
|
|
store ptr %653, ptr %632, align 4
|
|
%654 = add i32 %630, 48
|
|
%655 = and i32 %654, 63
|
|
%656 = and i32 %598, -64
|
|
%657 = or i32 %655, %656
|
|
%658 = inttoptr i32 %657 to ptr
|
|
%659 = getelementptr %struct.edge_rec, ptr %658, i32 0, i32 1
|
|
%660 = load ptr, ptr %659, align 4
|
|
%661 = ptrtoint ptr %660 to i32
|
|
%662 = add i32 %661, 16
|
|
%663 = and i32 %662, 63
|
|
%664 = and i32 %661, -64
|
|
%665 = or i32 %663, %664
|
|
%666 = inttoptr i32 %665 to ptr
|
|
br label %bb9.i
|
|
|
|
bb25.i:
|
|
%667 = add i32 %172, 16
|
|
%668 = and i32 %667, 63
|
|
%669 = and i32 %172, -64
|
|
%670 = or i32 %668, %669
|
|
%671 = inttoptr i32 %670 to ptr
|
|
%672 = getelementptr %struct.edge_rec, ptr %671, i32 0, i32 1
|
|
%673 = load ptr, ptr %672, align 4
|
|
%674 = ptrtoint ptr %673 to i32
|
|
%675 = add i32 %674, 16
|
|
%676 = and i32 %675, 63
|
|
%677 = and i32 %674, -64
|
|
%678 = or i32 %676, %677
|
|
%679 = inttoptr i32 %678 to ptr
|
|
%680 = call ptr @alloc_edge() nounwind
|
|
%681 = getelementptr %struct.edge_rec, ptr %680, i32 0, i32 1
|
|
store ptr %680, ptr %681, align 4
|
|
%682 = getelementptr %struct.edge_rec, ptr %680, i32 0, i32 0
|
|
store ptr %501, ptr %682, align 4
|
|
%683 = ptrtoint ptr %680 to i32
|
|
%684 = add i32 %683, 16
|
|
%685 = inttoptr i32 %684 to ptr
|
|
%686 = add i32 %683, 48
|
|
%687 = inttoptr i32 %686 to ptr
|
|
%688 = getelementptr %struct.edge_rec, ptr %685, i32 0, i32 1
|
|
store ptr %687, ptr %688, align 4
|
|
%689 = add i32 %683, 32
|
|
%690 = inttoptr i32 %689 to ptr
|
|
%691 = getelementptr %struct.edge_rec, ptr %690, i32 0, i32 1
|
|
store ptr %690, ptr %691, align 4
|
|
%692 = getelementptr %struct.edge_rec, ptr %690, i32 0, i32 0
|
|
store ptr %496, ptr %692, align 4
|
|
%693 = getelementptr %struct.edge_rec, ptr %687, i32 0, i32 1
|
|
store ptr %685, ptr %693, align 4
|
|
%694 = load ptr, ptr %681, align 4
|
|
%695 = ptrtoint ptr %694 to i32
|
|
%696 = add i32 %695, 16
|
|
%697 = and i32 %696, 63
|
|
%698 = and i32 %695, -64
|
|
%699 = or i32 %697, %698
|
|
%700 = inttoptr i32 %699 to ptr
|
|
%701 = getelementptr %struct.edge_rec, ptr %499, i32 0, i32 1
|
|
%702 = load ptr, ptr %701, align 4
|
|
%703 = ptrtoint ptr %702 to i32
|
|
%704 = add i32 %703, 16
|
|
%705 = and i32 %704, 63
|
|
%706 = and i32 %703, -64
|
|
%707 = or i32 %705, %706
|
|
%708 = inttoptr i32 %707 to ptr
|
|
%709 = getelementptr %struct.edge_rec, ptr %708, i32 0, i32 1
|
|
%710 = load ptr, ptr %709, align 4
|
|
%711 = getelementptr %struct.edge_rec, ptr %700, i32 0, i32 1
|
|
%712 = load ptr, ptr %711, align 4
|
|
store ptr %710, ptr %711, align 4
|
|
store ptr %712, ptr %709, align 4
|
|
%713 = load ptr, ptr %681, align 4
|
|
%714 = load ptr, ptr %701, align 4
|
|
store ptr %713, ptr %701, align 4
|
|
store ptr %714, ptr %681, align 4
|
|
%715 = xor i32 %683, 32
|
|
%716 = inttoptr i32 %715 to ptr
|
|
%717 = getelementptr %struct.edge_rec, ptr %716, i32 0, i32 1
|
|
%718 = load ptr, ptr %717, align 4
|
|
%719 = ptrtoint ptr %718 to i32
|
|
%720 = add i32 %719, 16
|
|
%721 = and i32 %720, 63
|
|
%722 = and i32 %719, -64
|
|
%723 = or i32 %721, %722
|
|
%724 = inttoptr i32 %723 to ptr
|
|
%725 = getelementptr %struct.edge_rec, ptr %679, i32 0, i32 1
|
|
%726 = load ptr, ptr %725, align 4
|
|
%727 = ptrtoint ptr %726 to i32
|
|
%728 = add i32 %727, 16
|
|
%729 = and i32 %728, 63
|
|
%730 = and i32 %727, -64
|
|
%731 = or i32 %729, %730
|
|
%732 = inttoptr i32 %731 to ptr
|
|
%733 = getelementptr %struct.edge_rec, ptr %732, i32 0, i32 1
|
|
%734 = load ptr, ptr %733, align 4
|
|
%735 = getelementptr %struct.edge_rec, ptr %724, i32 0, i32 1
|
|
%736 = load ptr, ptr %735, align 4
|
|
store ptr %734, ptr %735, align 4
|
|
store ptr %736, ptr %733, align 4
|
|
%737 = load ptr, ptr %717, align 4
|
|
%738 = load ptr, ptr %725, align 4
|
|
store ptr %737, ptr %725, align 4
|
|
store ptr %738, ptr %717, align 4
|
|
%739 = load ptr, ptr %681, align 4
|
|
br label %bb9.i
|
|
|
|
do_merge.exit:
|
|
%740 = getelementptr %struct.edge_rec, ptr %ldo_addr.0.ph.i, i32 0, i32 0
|
|
%741 = load ptr, ptr %740, align 4
|
|
%742 = icmp eq ptr %741, %tree_addr.0.i
|
|
br i1 %742, label %bb5.loopexit, label %bb2
|
|
|
|
bb2:
|
|
%ldo.07 = phi ptr [ %747, %bb2 ], [ %ldo_addr.0.ph.i, %do_merge.exit ]
|
|
%743 = ptrtoint ptr %ldo.07 to i32
|
|
%744 = xor i32 %743, 32
|
|
%745 = inttoptr i32 %744 to ptr
|
|
%746 = getelementptr %struct.edge_rec, ptr %745, i32 0, i32 1
|
|
%747 = load ptr, ptr %746, align 4
|
|
%748 = getelementptr %struct.edge_rec, ptr %747, i32 0, i32 0
|
|
%749 = load ptr, ptr %748, align 4
|
|
%750 = icmp eq ptr %749, %tree_addr.0.i
|
|
br i1 %750, label %bb5.loopexit, label %bb2
|
|
|
|
bb4:
|
|
%rdo.05 = phi ptr [ %755, %bb4 ], [ %rdo_addr.0.i, %bb5.loopexit ]
|
|
%751 = getelementptr %struct.edge_rec, ptr %rdo.05, i32 0, i32 1
|
|
%752 = load ptr, ptr %751, align 4
|
|
%753 = ptrtoint ptr %752 to i32
|
|
%754 = xor i32 %753, 32
|
|
%755 = inttoptr i32 %754 to ptr
|
|
%756 = getelementptr %struct.edge_rec, ptr %755, i32 0, i32 0
|
|
%757 = load ptr, ptr %756, align 4
|
|
%758 = icmp eq ptr %757, %extra
|
|
br i1 %758, label %bb6, label %bb4
|
|
|
|
bb5.loopexit:
|
|
%ldo.0.lcssa = phi ptr [ %ldo_addr.0.ph.i, %do_merge.exit ], [ %747, %bb2 ]
|
|
%759 = getelementptr %struct.edge_rec, ptr %rdo_addr.0.i, i32 0, i32 0
|
|
%760 = load ptr, ptr %759, align 4
|
|
%761 = icmp eq ptr %760, %extra
|
|
br i1 %761, label %bb6, label %bb4
|
|
|
|
bb6:
|
|
%rdo.0.lcssa = phi ptr [ %rdo_addr.0.i, %bb5.loopexit ], [ %755, %bb4 ]
|
|
%tmp16 = ptrtoint ptr %ldo.0.lcssa to i32
|
|
%tmp4 = ptrtoint ptr %rdo.0.lcssa to i32
|
|
br label %bb15
|
|
|
|
bb7:
|
|
%762 = getelementptr %struct.VERTEX, ptr %tree, i32 0, i32 1
|
|
%763 = load ptr, ptr %762, align 4
|
|
%764 = icmp eq ptr %763, null
|
|
%765 = call ptr @alloc_edge() nounwind
|
|
%766 = getelementptr %struct.edge_rec, ptr %765, i32 0, i32 1
|
|
store ptr %765, ptr %766, align 4
|
|
%767 = getelementptr %struct.edge_rec, ptr %765, i32 0, i32 0
|
|
br i1 %764, label %bb10, label %bb11
|
|
|
|
bb8:
|
|
%768 = call i32 @puts(ptr @_2E_str7) nounwind
|
|
call void @exit(i32 -1) noreturn nounwind
|
|
unreachable
|
|
|
|
bb10:
|
|
store ptr %tree, ptr %767, align 4
|
|
%769 = ptrtoint ptr %765 to i32
|
|
%770 = add i32 %769, 16
|
|
%771 = inttoptr i32 %770 to ptr
|
|
%772 = add i32 %769, 48
|
|
%773 = inttoptr i32 %772 to ptr
|
|
%774 = getelementptr %struct.edge_rec, ptr %771, i32 0, i32 1
|
|
store ptr %773, ptr %774, align 4
|
|
%775 = add i32 %769, 32
|
|
%776 = inttoptr i32 %775 to ptr
|
|
%777 = getelementptr %struct.edge_rec, ptr %776, i32 0, i32 1
|
|
store ptr %776, ptr %777, align 4
|
|
%778 = getelementptr %struct.edge_rec, ptr %776, i32 0, i32 0
|
|
store ptr %extra, ptr %778, align 4
|
|
%779 = getelementptr %struct.edge_rec, ptr %773, i32 0, i32 1
|
|
store ptr %771, ptr %779, align 4
|
|
%780 = xor i32 %769, 32
|
|
br label %bb15
|
|
|
|
bb11:
|
|
store ptr %763, ptr %767, align 4
|
|
%781 = ptrtoint ptr %765 to i32
|
|
%782 = add i32 %781, 16
|
|
%783 = inttoptr i32 %782 to ptr
|
|
%784 = add i32 %781, 48
|
|
%785 = inttoptr i32 %784 to ptr
|
|
%786 = getelementptr %struct.edge_rec, ptr %783, i32 0, i32 1
|
|
store ptr %785, ptr %786, align 4
|
|
%787 = add i32 %781, 32
|
|
%788 = inttoptr i32 %787 to ptr
|
|
%789 = getelementptr %struct.edge_rec, ptr %788, i32 0, i32 1
|
|
store ptr %788, ptr %789, align 4
|
|
%790 = getelementptr %struct.edge_rec, ptr %788, i32 0, i32 0
|
|
store ptr %tree, ptr %790, align 4
|
|
%791 = getelementptr %struct.edge_rec, ptr %785, i32 0, i32 1
|
|
store ptr %783, ptr %791, align 4
|
|
%792 = call ptr @alloc_edge() nounwind
|
|
%793 = getelementptr %struct.edge_rec, ptr %792, i32 0, i32 1
|
|
store ptr %792, ptr %793, align 4
|
|
%794 = getelementptr %struct.edge_rec, ptr %792, i32 0, i32 0
|
|
store ptr %tree, ptr %794, align 4
|
|
%795 = ptrtoint ptr %792 to i32
|
|
%796 = add i32 %795, 16
|
|
%797 = inttoptr i32 %796 to ptr
|
|
%798 = add i32 %795, 48
|
|
%799 = inttoptr i32 %798 to ptr
|
|
%800 = getelementptr %struct.edge_rec, ptr %797, i32 0, i32 1
|
|
store ptr %799, ptr %800, align 4
|
|
%801 = add i32 %795, 32
|
|
%802 = inttoptr i32 %801 to ptr
|
|
%803 = getelementptr %struct.edge_rec, ptr %802, i32 0, i32 1
|
|
store ptr %802, ptr %803, align 4
|
|
%804 = getelementptr %struct.edge_rec, ptr %802, i32 0, i32 0
|
|
store ptr %extra, ptr %804, align 4
|
|
%805 = getelementptr %struct.edge_rec, ptr %799, i32 0, i32 1
|
|
store ptr %797, ptr %805, align 4
|
|
%806 = xor i32 %781, 32
|
|
%807 = inttoptr i32 %806 to ptr
|
|
%808 = getelementptr %struct.edge_rec, ptr %807, i32 0, i32 1
|
|
%809 = load ptr, ptr %808, align 4
|
|
%810 = ptrtoint ptr %809 to i32
|
|
%811 = add i32 %810, 16
|
|
%812 = and i32 %811, 63
|
|
%813 = and i32 %810, -64
|
|
%814 = or i32 %812, %813
|
|
%815 = inttoptr i32 %814 to ptr
|
|
%816 = load ptr, ptr %793, align 4
|
|
%817 = ptrtoint ptr %816 to i32
|
|
%818 = add i32 %817, 16
|
|
%819 = and i32 %818, 63
|
|
%820 = and i32 %817, -64
|
|
%821 = or i32 %819, %820
|
|
%822 = inttoptr i32 %821 to ptr
|
|
%823 = getelementptr %struct.edge_rec, ptr %822, i32 0, i32 1
|
|
%824 = load ptr, ptr %823, align 4
|
|
%825 = getelementptr %struct.edge_rec, ptr %815, i32 0, i32 1
|
|
%826 = load ptr, ptr %825, align 4
|
|
store ptr %824, ptr %825, align 4
|
|
store ptr %826, ptr %823, align 4
|
|
%827 = load ptr, ptr %808, align 4
|
|
%828 = load ptr, ptr %793, align 4
|
|
store ptr %827, ptr %793, align 4
|
|
store ptr %828, ptr %808, align 4
|
|
%829 = xor i32 %795, 32
|
|
%830 = inttoptr i32 %829 to ptr
|
|
%831 = getelementptr %struct.edge_rec, ptr %830, i32 0, i32 0
|
|
%832 = load ptr, ptr %831, align 4
|
|
%833 = and i32 %798, 63
|
|
%834 = and i32 %795, -64
|
|
%835 = or i32 %833, %834
|
|
%836 = inttoptr i32 %835 to ptr
|
|
%837 = getelementptr %struct.edge_rec, ptr %836, i32 0, i32 1
|
|
%838 = load ptr, ptr %837, align 4
|
|
%839 = ptrtoint ptr %838 to i32
|
|
%840 = add i32 %839, 16
|
|
%841 = and i32 %840, 63
|
|
%842 = and i32 %839, -64
|
|
%843 = or i32 %841, %842
|
|
%844 = inttoptr i32 %843 to ptr
|
|
%845 = load ptr, ptr %767, align 4
|
|
%846 = call ptr @alloc_edge() nounwind
|
|
%847 = getelementptr %struct.edge_rec, ptr %846, i32 0, i32 1
|
|
store ptr %846, ptr %847, align 4
|
|
%848 = getelementptr %struct.edge_rec, ptr %846, i32 0, i32 0
|
|
store ptr %832, ptr %848, align 4
|
|
%849 = ptrtoint ptr %846 to i32
|
|
%850 = add i32 %849, 16
|
|
%851 = inttoptr i32 %850 to ptr
|
|
%852 = add i32 %849, 48
|
|
%853 = inttoptr i32 %852 to ptr
|
|
%854 = getelementptr %struct.edge_rec, ptr %851, i32 0, i32 1
|
|
store ptr %853, ptr %854, align 4
|
|
%855 = add i32 %849, 32
|
|
%856 = inttoptr i32 %855 to ptr
|
|
%857 = getelementptr %struct.edge_rec, ptr %856, i32 0, i32 1
|
|
store ptr %856, ptr %857, align 4
|
|
%858 = getelementptr %struct.edge_rec, ptr %856, i32 0, i32 0
|
|
store ptr %845, ptr %858, align 4
|
|
%859 = getelementptr %struct.edge_rec, ptr %853, i32 0, i32 1
|
|
store ptr %851, ptr %859, align 4
|
|
%860 = load ptr, ptr %847, align 4
|
|
%861 = ptrtoint ptr %860 to i32
|
|
%862 = add i32 %861, 16
|
|
%863 = and i32 %862, 63
|
|
%864 = and i32 %861, -64
|
|
%865 = or i32 %863, %864
|
|
%866 = inttoptr i32 %865 to ptr
|
|
%867 = getelementptr %struct.edge_rec, ptr %844, i32 0, i32 1
|
|
%868 = load ptr, ptr %867, align 4
|
|
%869 = ptrtoint ptr %868 to i32
|
|
%870 = add i32 %869, 16
|
|
%871 = and i32 %870, 63
|
|
%872 = and i32 %869, -64
|
|
%873 = or i32 %871, %872
|
|
%874 = inttoptr i32 %873 to ptr
|
|
%875 = getelementptr %struct.edge_rec, ptr %874, i32 0, i32 1
|
|
%876 = load ptr, ptr %875, align 4
|
|
%877 = getelementptr %struct.edge_rec, ptr %866, i32 0, i32 1
|
|
%878 = load ptr, ptr %877, align 4
|
|
store ptr %876, ptr %877, align 4
|
|
store ptr %878, ptr %875, align 4
|
|
%879 = load ptr, ptr %847, align 4
|
|
%880 = load ptr, ptr %867, align 4
|
|
store ptr %879, ptr %867, align 4
|
|
store ptr %880, ptr %847, align 4
|
|
%881 = xor i32 %849, 32
|
|
%882 = inttoptr i32 %881 to ptr
|
|
%883 = getelementptr %struct.edge_rec, ptr %882, i32 0, i32 1
|
|
%884 = load ptr, ptr %883, align 4
|
|
%885 = ptrtoint ptr %884 to i32
|
|
%886 = add i32 %885, 16
|
|
%887 = and i32 %886, 63
|
|
%888 = and i32 %885, -64
|
|
%889 = or i32 %887, %888
|
|
%890 = inttoptr i32 %889 to ptr
|
|
%891 = load ptr, ptr %766, align 4
|
|
%892 = ptrtoint ptr %891 to i32
|
|
%893 = add i32 %892, 16
|
|
%894 = and i32 %893, 63
|
|
%895 = and i32 %892, -64
|
|
%896 = or i32 %894, %895
|
|
%897 = inttoptr i32 %896 to ptr
|
|
%898 = getelementptr %struct.edge_rec, ptr %897, i32 0, i32 1
|
|
%899 = load ptr, ptr %898, align 4
|
|
%900 = getelementptr %struct.edge_rec, ptr %890, i32 0, i32 1
|
|
%901 = load ptr, ptr %900, align 4
|
|
store ptr %899, ptr %900, align 4
|
|
store ptr %901, ptr %898, align 4
|
|
%902 = load ptr, ptr %883, align 4
|
|
%903 = load ptr, ptr %766, align 4
|
|
store ptr %902, ptr %766, align 4
|
|
store ptr %903, ptr %883, align 4
|
|
%904 = getelementptr %struct.VERTEX, ptr %763, i32 0, i32 0, i32 0
|
|
%905 = load double, ptr %904, align 4
|
|
%906 = getelementptr %struct.VERTEX, ptr %763, i32 0, i32 0, i32 1
|
|
%907 = load double, ptr %906, align 4
|
|
%908 = getelementptr %struct.VERTEX, ptr %extra, i32 0, i32 0, i32 0
|
|
%909 = load double, ptr %908, align 4
|
|
%910 = getelementptr %struct.VERTEX, ptr %extra, i32 0, i32 0, i32 1
|
|
%911 = load double, ptr %910, align 4
|
|
%912 = getelementptr %struct.VERTEX, ptr %tree, i32 0, i32 0, i32 0
|
|
%913 = load double, ptr %912, align 4
|
|
%914 = getelementptr %struct.VERTEX, ptr %tree, i32 0, i32 0, i32 1
|
|
%915 = load double, ptr %914, align 4
|
|
%916 = fsub double %905, %913
|
|
%917 = fsub double %911, %915
|
|
%918 = fmul double %916, %917
|
|
%919 = fsub double %909, %913
|
|
%920 = fsub double %907, %915
|
|
%921 = fmul double %919, %920
|
|
%922 = fsub double %918, %921
|
|
%923 = fcmp ogt double %922, 0.000000e+00
|
|
br i1 %923, label %bb15, label %bb13
|
|
|
|
bb13:
|
|
%924 = fsub double %905, %909
|
|
%925 = fsub double %915, %911
|
|
%926 = fmul double %924, %925
|
|
%927 = fsub double %913, %909
|
|
%928 = fsub double %907, %911
|
|
%929 = fmul double %927, %928
|
|
%930 = fsub double %926, %929
|
|
%931 = fcmp ogt double %930, 0.000000e+00
|
|
br i1 %931, label %bb15, label %bb14
|
|
|
|
bb14:
|
|
%932 = and i32 %850, 63
|
|
%933 = and i32 %849, -64
|
|
%934 = or i32 %932, %933
|
|
%935 = inttoptr i32 %934 to ptr
|
|
%936 = getelementptr %struct.edge_rec, ptr %935, i32 0, i32 1
|
|
%937 = load ptr, ptr %936, align 4
|
|
%938 = ptrtoint ptr %937 to i32
|
|
%939 = add i32 %938, 16
|
|
%940 = and i32 %939, 63
|
|
%941 = and i32 %938, -64
|
|
%942 = or i32 %940, %941
|
|
%943 = inttoptr i32 %942 to ptr
|
|
%944 = load ptr, ptr %847, align 4
|
|
%945 = ptrtoint ptr %944 to i32
|
|
%946 = add i32 %945, 16
|
|
%947 = and i32 %946, 63
|
|
%948 = and i32 %945, -64
|
|
%949 = or i32 %947, %948
|
|
%950 = inttoptr i32 %949 to ptr
|
|
%951 = getelementptr %struct.edge_rec, ptr %943, i32 0, i32 1
|
|
%952 = load ptr, ptr %951, align 4
|
|
%953 = ptrtoint ptr %952 to i32
|
|
%954 = add i32 %953, 16
|
|
%955 = and i32 %954, 63
|
|
%956 = and i32 %953, -64
|
|
%957 = or i32 %955, %956
|
|
%958 = inttoptr i32 %957 to ptr
|
|
%959 = getelementptr %struct.edge_rec, ptr %958, i32 0, i32 1
|
|
%960 = load ptr, ptr %959, align 4
|
|
%961 = getelementptr %struct.edge_rec, ptr %950, i32 0, i32 1
|
|
%962 = load ptr, ptr %961, align 4
|
|
store ptr %960, ptr %961, align 4
|
|
store ptr %962, ptr %959, align 4
|
|
%963 = load ptr, ptr %847, align 4
|
|
%964 = load ptr, ptr %951, align 4
|
|
store ptr %963, ptr %951, align 4
|
|
store ptr %964, ptr %847, align 4
|
|
%965 = add i32 %881, 16
|
|
%966 = and i32 %965, 63
|
|
%967 = or i32 %966, %933
|
|
%968 = inttoptr i32 %967 to ptr
|
|
%969 = getelementptr %struct.edge_rec, ptr %968, i32 0, i32 1
|
|
%970 = load ptr, ptr %969, align 4
|
|
%971 = ptrtoint ptr %970 to i32
|
|
%972 = add i32 %971, 16
|
|
%973 = and i32 %972, 63
|
|
%974 = and i32 %971, -64
|
|
%975 = or i32 %973, %974
|
|
%976 = inttoptr i32 %975 to ptr
|
|
%977 = load ptr, ptr %883, align 4
|
|
%978 = ptrtoint ptr %977 to i32
|
|
%979 = add i32 %978, 16
|
|
%980 = and i32 %979, 63
|
|
%981 = and i32 %978, -64
|
|
%982 = or i32 %980, %981
|
|
%983 = inttoptr i32 %982 to ptr
|
|
%984 = getelementptr %struct.edge_rec, ptr %976, i32 0, i32 1
|
|
%985 = load ptr, ptr %984, align 4
|
|
%986 = ptrtoint ptr %985 to i32
|
|
%987 = add i32 %986, 16
|
|
%988 = and i32 %987, 63
|
|
%989 = and i32 %986, -64
|
|
%990 = or i32 %988, %989
|
|
%991 = inttoptr i32 %990 to ptr
|
|
%992 = getelementptr %struct.edge_rec, ptr %991, i32 0, i32 1
|
|
%993 = load ptr, ptr %992, align 4
|
|
%994 = getelementptr %struct.edge_rec, ptr %983, i32 0, i32 1
|
|
%995 = load ptr, ptr %994, align 4
|
|
store ptr %993, ptr %994, align 4
|
|
store ptr %995, ptr %992, align 4
|
|
%996 = load ptr, ptr %883, align 4
|
|
%997 = load ptr, ptr %984, align 4
|
|
store ptr %996, ptr %984, align 4
|
|
store ptr %997, ptr %883, align 4
|
|
%998 = inttoptr i32 %933 to ptr
|
|
%999 = load ptr, ptr @avail_edge, align 4
|
|
%1000 = getelementptr %struct.edge_rec, ptr %998, i32 0, i32 1
|
|
store ptr %999, ptr %1000, align 4
|
|
store ptr %998, ptr @avail_edge, align 4
|
|
br label %bb15
|
|
|
|
bb15:
|
|
%retval.1.0 = phi i32 [ %780, %bb10 ], [ %829, %bb13 ], [ %829, %bb14 ], [ %tmp4, %bb6 ], [ %849, %bb11 ]
|
|
%retval.0.0 = phi i32 [ %769, %bb10 ], [ %781, %bb13 ], [ %781, %bb14 ], [ %tmp16, %bb6 ], [ %881, %bb11 ]
|
|
%agg.result162 = bitcast ptr %agg.result to ptr
|
|
%1001 = zext i32 %retval.0.0 to i64
|
|
%1002 = zext i32 %retval.1.0 to i64
|
|
%1003 = shl i64 %1002, 32
|
|
%1004 = or i64 %1003, %1001
|
|
store i64 %1004, ptr %agg.result162, align 4
|
|
ret void
|
|
}
|
|
|
|
; CHECK-LABEL: _build_delaunay:
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
; CHECK: vcmp
|
|
|
|
declare i32 @puts(ptr nocapture) nounwind
|
|
|
|
declare void @exit(i32) noreturn nounwind
|
|
|
|
declare ptr @alloc_edge() nounwind
|