2007-03-26-RegScavengerAssert.ll   [plain text]


; RUN: llvm-as < %s | llc -march=arm
; PR1266

target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64"
target triple = "arm-linux-gnueabi"
	%struct.CUMULATIVE_ARGS = type { i32, i32, i32, i32, i32, i32 }
	%struct.FILE = type { i32, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, %struct._IO_marker*, %struct.FILE*, i32, i32, i32, i16, i8, [1 x i8], i8*, i64, i8*, i8*, i32, [52 x i8] }
	%struct.VEC_edge = type { i32, i32, [1 x %struct.edge_def*] }
	%struct.VEC_tree = type { i32, i32, [1 x %struct.tree_node*] }
	%struct._IO_marker = type { %struct._IO_marker*, %struct.FILE*, i32 }
	%struct._obstack_chunk = type { i8*, %struct._obstack_chunk*, [4 x i8] }
	%struct.addr_diff_vec_flags = type { i8, i8, i8, i8 }
	%struct.arm_stack_offsets = type { i32, i32, i32, i32, i32 }
	%struct.attribute_spec = type { i8*, i32, i32, i8, i8, i8, %struct.tree_node* (%struct.tree_node**, %struct.tree_node*, %struct.tree_node*, i32, i8*)* }
	%struct.basic_block_def = type { %struct.rtx_def*, %struct.rtx_def*, %struct.tree_node*, %struct.VEC_edge*, %struct.VEC_edge*, %struct.bitmap_head_def*, %struct.bitmap_head_def*, i8*, %struct.loop*, [2 x %struct.et_node*], %struct.basic_block_def*, %struct.basic_block_def*, %struct.reorder_block_def*, %struct.bb_ann_d*, i64, i32, i32, i32, i32 }
	%struct.bb_ann_d = type { %struct.tree_node*, i8, %struct.edge_prediction* }
	%struct.bitmap_element_def = type { %struct.bitmap_element_def*, %struct.bitmap_element_def*, i32, [4 x i32] }
	%struct.bitmap_head_def = type { %struct.bitmap_element_def*, %struct.bitmap_element_def*, i32, %struct.bitmap_obstack* }
	%struct.bitmap_obstack = type { %struct.bitmap_element_def*, %struct.bitmap_head_def*, %struct.obstack }
	%struct.cgraph_edge = type { %struct.cgraph_node*, %struct.cgraph_node*, %struct.cgraph_edge*, %struct.cgraph_edge*, %struct.cgraph_edge*, %struct.cgraph_edge*, %struct.tree_node*, i8*, i8* }
	%struct.cgraph_global_info = type { %struct.cgraph_node*, i32, i8 }
	%struct.cgraph_local_info = type { i32, i8, i8, i8, i8, i8, i8, i8 }
	%struct.cgraph_node = type { %struct.tree_node*, %struct.cgraph_edge*, %struct.cgraph_edge*, %struct.cgraph_node*, %struct.cgraph_node*, %struct.cgraph_node*, %struct.cgraph_node*, %struct.cgraph_node*, %struct.cgraph_node*, %struct.cgraph_node*, i8*, %struct.cgraph_local_info, %struct.cgraph_global_info, %struct.cgraph_rtl_info, i32, i8, i8, i8, i8, i8 }
	%struct.cgraph_rtl_info = type { i32, i8, i8 }
	%struct.cl_perfunc_opts = type { i8, i8, i8, i8, i8, i8, i8, i8, i8, i8, i8, i8, i32, i32, i32, i32, i32, i32, i32, i32, i32 }
	%struct.cselib_val_struct = type opaque
	%struct.dataflow_d = type { %struct.varray_head_tag*, [2 x %struct.tree_node*] }
	%struct.def_operand_ptr = type { %struct.tree_node** }
	%struct.def_optype_d = type { i32, [1 x %struct.def_operand_ptr] }
	%struct.diagnostic_context = type { %struct.pretty_printer*, [8 x i32], i8, i8, i8, void (%struct.diagnostic_context*, %struct.diagnostic_info*)*, void (%struct.diagnostic_context*, %struct.diagnostic_info*)*, void (i8*, i8**)*, %struct.tree_node*, i32, i32 }
	%struct.diagnostic_info = type { %struct.text_info, %struct.location_t, i32 }
	%struct.die_struct = type opaque
	%struct.edge_def = type { %struct.basic_block_def*, %struct.basic_block_def*, %struct.edge_def_insns, i8*, %struct.location_t*, i32, i32, i64, i32 }
	%struct.edge_def_insns = type { %struct.rtx_def* }
	%struct.edge_prediction = type { %struct.edge_prediction*, %struct.edge_def*, i32, i32 }
	%struct.eh_status = type opaque
	%struct.elt_list = type opaque
	%struct.elt_t = type { %struct.tree_node*, %struct.tree_node* }
	%struct.emit_status = type { i32, i32, %struct.rtx_def*, %struct.rtx_def*, %struct.sequence_stack*, i32, %struct.location_t, i32, i8*, %struct.rtx_def** }
	%struct.et_node = type opaque
	%struct.expr_status = type { i32, i32, i32, %struct.rtx_def*, %struct.rtx_def*, %struct.rtx_def* }
	%struct.function = type { %struct.eh_status*, %struct.expr_status*, %struct.emit_status*, %struct.varasm_status*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.function*, i32, i32, i32, i32, %struct.rtx_def*, %struct.CUMULATIVE_ARGS, %struct.rtx_def*, %struct.rtx_def*, %struct.initial_value_struct*, %struct.rtx_def*, %struct.rtx_def*, %struct.rtx_def*, %struct.rtx_def*, %struct.rtx_def*, %struct.rtx_def*, i8, i32, i64, %struct.tree_node*, %struct.tree_node*, %struct.rtx_def*, %struct.varray_head_tag*, %struct.temp_slot*, i32, %struct.var_refs_queue*, i32, i32, %struct.rtvec_def*, %struct.tree_node*, i32, i32, i32, %struct.machine_function*, i32, i32, i8, i8, %struct.language_function*, %struct.rtx_def*, i32, i32, i32, i32, %struct.location_t, %struct.varray_head_tag*, %struct.tree_node*, i8, i8, i8 }
	%struct.ggc_root_tab = type { i8*, i32, i32, void (i8*)*, void (i8*)* }
	%struct.gimplify_ctx = type { %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.varray_head_tag*, %struct.htab*, i32, i8, i8 }
	%struct.gimplify_init_ctor_preeval_data = type { %struct.tree_node*, i32 }
	%struct.ht_identifier = type { i8*, i32, i32 }
	%struct.htab = type { i32 (i8*)*, i32 (i8*, i8*)*, void (i8*)*, i8**, i32, i32, i32, i32, i32, i8* (i32, i32)*, void (i8*)*, i8*, i8* (i8*, i32, i32)*, void (i8*, i8*)*, i32 }
	%struct.initial_value_struct = type opaque
	%struct.lang_decl = type opaque
	%struct.lang_hooks = type { i8*, i32, i32 (i32)*, i32 (i32, i8**)*, void (%struct.diagnostic_context*)*, i32 (i32, i8*, i32)*, i8 (i8*, i32) zeroext *, i8 (i8**) zeroext *, i8 () zeroext *, void ()*, void ()*, void (i32)*, void ()*, i64 (%struct.tree_node*)*, %struct.tree_node* (%struct.tree_node*)*, %struct.rtx_def* (%struct.tree_node*, %struct.rtx_def*, i32, i32, %struct.rtx_def**)*, i32 (%struct.tree_node*)*, %struct.tree_node* (%struct.tree_node*)*, i32 (%struct.rtx_def*, %struct.tree_node*)*, void (%struct.tree_node*)*, i8 (%struct.tree_node*) zeroext *, %struct.tree_node* (%struct.tree_node*)*, void (%struct.tree_node*)*, void (%struct.tree_node*)*, i8 () zeroext *, i8, i8, void ()*, void (%struct.FILE*, %struct.tree_node*, i32)*, void (%struct.FILE*, %struct.tree_node*, i32)*, void (%struct.FILE*, %struct.tree_node*, i32)*, void (%struct.FILE*, %struct.tree_node*, i32)*, i8* (%struct.tree_node*, i32)*, i32 (%struct.tree_node*, %struct.tree_node*)*, %struct.tree_node* (%struct.tree_node*)*, void (%struct.diagnostic_context*, i8*)*, %struct.tree_node* (%struct.tree_node*)*, i64 (i64)*, %struct.attribute_spec*, %struct.attribute_spec*, %struct.attribute_spec*, i32 (%struct.tree_node*)*, %struct.lang_hooks_for_functions, %struct.lang_hooks_for_tree_inlining, %struct.lang_hooks_for_callgraph, %struct.lang_hooks_for_tree_dump, %struct.lang_hooks_for_decls, %struct.lang_hooks_for_types, i32 (%struct.tree_node**, %struct.tree_node**, %struct.tree_node**)*, %struct.tree_node* (%struct.tree_node*, %struct.tree_node*)*, %struct.tree_node* (i8*, %struct.tree_node*, i32, i32, i8*, %struct.tree_node*)* }
	%struct.lang_hooks_for_callgraph = type { %struct.tree_node* (%struct.tree_node**, i32*, %struct.tree_node*)*, void (%struct.tree_node*)* }
	%struct.lang_hooks_for_decls = type { i32 ()*, void (%struct.tree_node*)*, %struct.tree_node* (%struct.tree_node*)*, %struct.tree_node* ()*, i8 (%struct.tree_node*) zeroext *, void ()*, void (%struct.tree_node*)*, i8 (%struct.tree_node*) zeroext *, i8* (%struct.tree_node*)* }
	%struct.lang_hooks_for_functions = type { void (%struct.function*)*, void (%struct.function*)*, void (%struct.function*)*, void (%struct.function*)*, i8 (%struct.tree_node*) zeroext * }
	%struct.lang_hooks_for_tree_dump = type { i8 (i8*, %struct.tree_node*) zeroext *, i32 (%struct.tree_node*)* }
	%struct.lang_hooks_for_tree_inlining = type { %struct.tree_node* (%struct.tree_node**, i32*, %struct.tree_node* (%struct.tree_node**, i32*, i8*)*, i8*, %struct.pointer_set_t*)*, i32 (%struct.tree_node**)*, i32 (%struct.tree_node*)*, %struct.tree_node* (i8*, %struct.tree_node*)*, i32 (%struct.tree_node*, %struct.tree_node*)*, i32 (%struct.tree_node*)*, i8 (%struct.tree_node*, %struct.tree_node*) zeroext *, i32 (%struct.tree_node*)*, void (%struct.tree_node*)*, %struct.tree_node* (%struct.tree_node*, %struct.tree_node*, %struct.tree_node*, i32)* }
	%struct.lang_hooks_for_types = type { %struct.tree_node* (i32)*, %struct.tree_node* (i32, i32)*, %struct.tree_node* (i32, i32)*, %struct.tree_node* (%struct.tree_node*)*, %struct.tree_node* (%struct.tree_node*)*, %struct.tree_node* (i32, %struct.tree_node*)*, %struct.tree_node* (%struct.tree_node*)*, void (%struct.tree_node*, i8*)*, void (%struct.tree_node*, %struct.tree_node*)*, %struct.tree_node* (%struct.tree_node*)*, i8 }
	%struct.lang_type = type opaque
	%struct.language_function = type opaque
	%struct.location_t = type { i8*, i32 }
	%struct.loop = type opaque
	%struct.machine_function = type { %struct.rtx_def*, i32, i32, i32, %struct.arm_stack_offsets, i32, i32, i32, [14 x %struct.rtx_def*] }
	%struct.mem_attrs = type { i64, %struct.tree_node*, %struct.rtx_def*, %struct.rtx_def*, i32 }
	%struct.obstack = type { i32, %struct._obstack_chunk*, i8*, i8*, i8*, i32, i32, %struct._obstack_chunk* (i8*, i32)*, void (i8*, %struct._obstack_chunk*)*, i8*, i8 }
	%struct.output_buffer = type { %struct.obstack, %struct.FILE*, i32, [128 x i8] }
	%struct.phi_arg_d = type { %struct.tree_node*, i8 }
	%struct.pointer_set_t = type opaque
	%struct.pretty_printer = type { %struct.output_buffer*, i8*, i32, i32, i32, i32, i32, i8 (%struct.pretty_printer*, %struct.text_info*) zeroext *, i8, i8 }
	%struct.ptr_info_def = type { i8, %struct.bitmap_head_def*, %struct.tree_node* }
	%struct.real_value = type { i8, [3 x i8], [5 x i32] }
	%struct.reg_attrs = type { %struct.tree_node*, i64 }
	%struct.reg_info_def = type opaque
	%struct.reorder_block_def = type { %struct.rtx_def*, %struct.rtx_def*, %struct.basic_block_def*, %struct.basic_block_def*, %struct.basic_block_def*, i32, i32, i32 }
	%struct.rtunion = type { i32 }
	%struct.rtvec_def = type { i32, [1 x %struct.rtx_def*] }
	%struct.rtx_def = type { i16, i8, i8, %struct.u }
	%struct.sequence_stack = type { %struct.rtx_def*, %struct.rtx_def*, %struct.sequence_stack* }
	%struct.stmt_ann_d = type { %struct.tree_ann_common_d, i8, %struct.basic_block_def*, %struct.stmt_operands_d, %struct.dataflow_d*, %struct.bitmap_head_def*, i32 }
	%struct.stmt_operands_d = type { %struct.def_optype_d*, %struct.def_optype_d*, %struct.v_may_def_optype_d*, %struct.vuse_optype_d*, %struct.v_may_def_optype_d* }
	%struct.temp_slot = type opaque
	%struct.text_info = type { i8*, i8**, i32 }
	%struct.tree_ann_common_d = type { i32, i8*, %struct.tree_node* }
	%struct.tree_ann_d = type { %struct.stmt_ann_d }
	%struct.tree_binfo = type { %struct.tree_common, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.VEC_tree*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.VEC_tree }
	%struct.tree_block = type { %struct.tree_common, i8, [3 x i8], %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node* }
	%struct.tree_common = type { %struct.tree_node*, %struct.tree_node*, %struct.tree_ann_d*, i8, i8, i8, i8, i8 }
	%struct.tree_complex = type { %struct.tree_common, %struct.tree_node*, %struct.tree_node* }
	%struct.tree_decl = type { %struct.tree_common, %struct.location_t, i32, %struct.tree_node*, i8, i8, i8, i8, i8, i8, i8, i8, i32, %struct.tree_decl_u1, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.rtx_def*, i32, %struct.tree_decl_u2, %struct.tree_node*, %struct.tree_node*, i64, %struct.lang_decl* }
	%struct.tree_decl_u1 = type { i64 }
	%struct.tree_decl_u1_a = type { i32 }
	%struct.tree_decl_u2 = type { %struct.function* }
	%struct.tree_exp = type { %struct.tree_common, %struct.location_t*, i32, %struct.tree_node*, [1 x %struct.tree_node*] }
	%struct.tree_identifier = type { %struct.tree_common, %struct.ht_identifier }
	%struct.tree_int_cst = type { %struct.tree_common, %struct.tree_int_cst_lowhi }
	%struct.tree_int_cst_lowhi = type { i64, i64 }
	%struct.tree_list = type { %struct.tree_common, %struct.tree_node*, %struct.tree_node* }
	%struct.tree_node = type { %struct.tree_decl }
	%struct.tree_phi_node = type { %struct.tree_common, %struct.tree_node*, i32, i32, i32, %struct.basic_block_def*, %struct.dataflow_d*, [1 x %struct.phi_arg_d] }
	%struct.tree_real_cst = type { %struct.tree_common, %struct.real_value* }
	%struct.tree_ssa_name = type { %struct.tree_common, %struct.tree_node*, i32, %struct.ptr_info_def*, %struct.tree_node*, i8* }
	%struct.tree_statement_list = type { %struct.tree_common, %struct.tree_statement_list_node*, %struct.tree_statement_list_node* }
	%struct.tree_statement_list_node = type { %struct.tree_statement_list_node*, %struct.tree_statement_list_node*, %struct.tree_node* }
	%struct.tree_stmt_iterator = type { %struct.tree_statement_list_node*, %struct.tree_node* }
	%struct.tree_string = type { %struct.tree_common, i32, [1 x i8] }
	%struct.tree_type = type { %struct.tree_common, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, i32, i16, i8, i8, i32, %struct.tree_node*, %struct.tree_node*, %struct.rtunion, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, i64, %struct.lang_type* }
	%struct.tree_type_symtab = type { i32 }
	%struct.tree_value_handle = type { %struct.tree_common, %struct.value_set*, i32 }
	%struct.tree_vec = type { %struct.tree_common, i32, [1 x %struct.tree_node*] }
	%struct.tree_vector = type { %struct.tree_common, %struct.tree_node* }
	%struct.u = type { [1 x i64] }
	%struct.use_operand_ptr = type { %struct.tree_node** }
	%struct.use_optype_d = type { i32, [1 x %struct.def_operand_ptr] }
	%struct.v_def_use_operand_type_t = type { %struct.tree_node*, %struct.tree_node* }
	%struct.v_may_def_optype_d = type { i32, [1 x %struct.elt_t] }
	%struct.v_must_def_optype_d = type { i32, [1 x %struct.elt_t] }
	%struct.value_set = type opaque
	%struct.var_ann_d = type { %struct.tree_ann_common_d, i8, i8, %struct.tree_node*, %struct.varray_head_tag*, i32, i32, i32, %struct.tree_node*, %struct.tree_node* }
	%struct.var_refs_queue = type { %struct.rtx_def*, i32, i32, %struct.var_refs_queue* }
	%struct.varasm_status = type opaque
	%struct.varray_data = type { [1 x i64] }
	%struct.varray_head_tag = type { i32, i32, i32, i8*, %struct.u }
	%struct.vuse_optype_d = type { i32, [1 x %struct.tree_node*] }
@gt_pch_rs_gt_gimplify_h = external global [2 x %struct.ggc_root_tab]		; <[2 x %struct.ggc_root_tab]*> [#uses=0]
@tmp_var_id_num = external global i32		; <i32*> [#uses=0]
@gt_ggc_r_gt_gimplify_h = external global [1 x %struct.ggc_root_tab]		; <[1 x %struct.ggc_root_tab]*> [#uses=0]
@__FUNCTION__.19956 = external global [15 x i8]		; <[15 x i8]*> [#uses=0]
@str = external global [42 x i8]		; <[42 x i8]*> [#uses=1]
@__FUNCTION__.19974 = external global [22 x i8]		; <[22 x i8]*> [#uses=0]
@gimplify_ctxp = external global %struct.gimplify_ctx*		; <%struct.gimplify_ctx**> [#uses=0]
@cl_pf_opts = external global %struct.cl_perfunc_opts		; <%struct.cl_perfunc_opts*> [#uses=0]
@__FUNCTION__.20030 = external global [22 x i8]		; <[22 x i8]*> [#uses=0]
@__FUNCTION__.20099 = external global [24 x i8]		; <[24 x i8]*> [#uses=0]
@global_trees = external global [47 x %struct.tree_node*]		; <[47 x %struct.tree_node*]*> [#uses=0]
@tree_code_type = external global [0 x i32]		; <[0 x i32]*> [#uses=2]
@current_function_decl = external global %struct.tree_node*		; <%struct.tree_node**> [#uses=0]
@str1 = external global [2 x i8]		; <[2 x i8]*> [#uses=0]
@str2 = external global [7 x i8]		; <[7 x i8]*> [#uses=0]
@__FUNCTION__.20151 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@__FUNCTION__.20221 = external global [9 x i8]		; <[9 x i8]*> [#uses=0]
@tree_code_length = external global [0 x i8]		; <[0 x i8]*> [#uses=0]
@__FUNCTION__.20435 = external global [17 x i8]		; <[17 x i8]*> [#uses=0]
@__FUNCTION__.20496 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@cfun = external global %struct.function*		; <%struct.function**> [#uses=0]
@__FUNCTION__.20194 = external global [15 x i8]		; <[15 x i8]*> [#uses=0]
@__FUNCTION__.19987 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]
@__FUNCTION__.20532 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]
@__FUNCTION__.20583 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@__FUNCTION__.20606 = external global [22 x i8]		; <[22 x i8]*> [#uses=0]
@__FUNCTION__.20644 = external global [17 x i8]		; <[17 x i8]*> [#uses=0]
@__FUNCTION__.20681 = external global [13 x i8]		; <[13 x i8]*> [#uses=0]
@__FUNCTION__.20700 = external global [13 x i8]		; <[13 x i8]*> [#uses=0]
@__FUNCTION__.21426 = external global [20 x i8]		; <[20 x i8]*> [#uses=0]
@__FUNCTION__.21471 = external global [17 x i8]		; <[17 x i8]*> [#uses=0]
@__FUNCTION__.21962 = external global [27 x i8]		; <[27 x i8]*> [#uses=0]
@__FUNCTION__.22992 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]
@__FUNCTION__.23735 = external global [15 x i8]		; <[15 x i8]*> [#uses=0]
@lang_hooks = external global %struct.lang_hooks		; <%struct.lang_hooks*> [#uses=0]
@__FUNCTION__.27383 = external global [22 x i8]		; <[22 x i8]*> [#uses=0]
@__FUNCTION__.20776 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]
@__FUNCTION__.10672 = external global [9 x i8]		; <[9 x i8]*> [#uses=0]
@str3 = external global [47 x i8]		; <[47 x i8]*> [#uses=0]
@str4 = external global [7 x i8]		; <[7 x i8]*> [#uses=0]
@__FUNCTION__.20065 = external global [25 x i8]		; <[25 x i8]*> [#uses=0]
@__FUNCTION__.23256 = external global [16 x i8]		; <[16 x i8]*> [#uses=0]
@__FUNCTION__.23393 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@__FUNCTION__.20043 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]
@__FUNCTION__.20729 = external global [23 x i8]		; <[23 x i8]*> [#uses=0]
@__FUNCTION__.20563 = external global [24 x i8]		; <[24 x i8]*> [#uses=0]
@__FUNCTION__.10663 = external global [10 x i8]		; <[10 x i8]*> [#uses=0]
@__FUNCTION__.20367 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]
@__FUNCTION__.20342 = external global [15 x i8]		; <[15 x i8]*> [#uses=0]
@input_location = external global %struct.location_t		; <%struct.location_t*> [#uses=0]
@__FUNCTION__.24510 = external global [27 x i8]		; <[27 x i8]*> [#uses=0]
@__FUNCTION__.25097 = external global [25 x i8]		; <[25 x i8]*> [#uses=0]
@__FUNCTION__.24705 = external global [26 x i8]		; <[26 x i8]*> [#uses=0]
@str5 = external global [2 x i8]		; <[2 x i8]*> [#uses=0]
@__FUNCTION__.25136 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]
@__FUNCTION__.24450 = external global [31 x i8]		; <[31 x i8]*> [#uses=0]
@implicit_built_in_decls = external global [471 x %struct.tree_node*]		; <[471 x %struct.tree_node*]*> [#uses=0]
@__FUNCTION__.24398 = external global [31 x i8]		; <[31 x i8]*> [#uses=0]
@__FUNCTION__.26156 = external global [14 x i8]		; <[14 x i8]*> [#uses=1]
@unknown_location = external global %struct.location_t		; <%struct.location_t*> [#uses=0]
@__FUNCTION__.23038 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@str6 = external global [43 x i8]		; <[43 x i8]*> [#uses=0]
@__FUNCTION__.25476 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@__FUNCTION__.22136 = external global [20 x i8]		; <[20 x i8]*> [#uses=1]
@__FUNCTION__.21997 = external global [23 x i8]		; <[23 x i8]*> [#uses=0]
@__FUNCTION__.21247 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@built_in_decls = external global [471 x %struct.tree_node*]		; <[471 x %struct.tree_node*]*> [#uses=0]
@__FUNCTION__.21924 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@__FUNCTION__.21861 = external global [25 x i8]		; <[25 x i8]*> [#uses=0]
@global_dc = external global %struct.diagnostic_context*		; <%struct.diagnostic_context**> [#uses=0]
@__FUNCTION__.25246 = external global [32 x i8]		; <[32 x i8]*> [#uses=0]
@str7 = external global [4 x i8]		; <[4 x i8]*> [#uses=0]
@stderr = external global %struct.FILE*		; <%struct.FILE**> [#uses=0]
@str8 = external global [24 x i8]		; <[24 x i8]*> [#uses=0]
@str9 = external global [22 x i8]		; <[22 x i8]*> [#uses=0]
@__FUNCTION__.27653 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]
@__FUNCTION__.27322 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]
@__FUNCTION__.27139 = external global [20 x i8]		; <[20 x i8]*> [#uses=0]
@__FUNCTION__.22462 = external global [23 x i8]		; <[23 x i8]*> [#uses=0]
@str10 = external global [6 x i8]		; <[6 x i8]*> [#uses=0]
@__FUNCTION__.25389 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@__FUNCTION__.25650 = external global [18 x i8]		; <[18 x i8]*> [#uses=0]
@str11 = external global [32 x i8]		; <[32 x i8]*> [#uses=0]
@str12 = external global [3 x i8]		; <[3 x i8]*> [#uses=0]
@str13 = external global [44 x i8]		; <[44 x i8]*> [#uses=0]
@__FUNCTION__.27444 = external global [14 x i8]		; <[14 x i8]*> [#uses=0]
@timevar_enable = external global i8		; <i8*> [#uses=0]
@__FUNCTION__.27533 = external global [23 x i8]		; <[23 x i8]*> [#uses=0]
@flag_instrument_function_entry_exit = external global i32		; <i32*> [#uses=0]
@__FUNCTION__.25331 = external global [23 x i8]		; <[23 x i8]*> [#uses=0]
@__FUNCTION__.20965 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@str14 = external global [12 x i8]		; <[12 x i8]*> [#uses=0]
@__FUNCTION__.26053 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]
@__FUNCTION__.26004 = external global [20 x i8]		; <[20 x i8]*> [#uses=0]
@str15 = external global [8 x i8]		; <[8 x i8]*> [#uses=0]
@__FUNCTION__.21584 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]
@str16 = external global [12 x i8]		; <[12 x i8]*> [#uses=0]
@__FUNCTION__.25903 = external global [28 x i8]		; <[28 x i8]*> [#uses=0]
@__FUNCTION__.22930 = external global [23 x i8]		; <[23 x i8]*> [#uses=0]
@__FUNCTION__.23832 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@str17 = external global [6 x i8]		; <[6 x i8]*> [#uses=0]
@__FUNCTION__.24620 = external global [24 x i8]		; <[24 x i8]*> [#uses=0]
@__FUNCTION__.24582 = external global [30 x i8]		; <[30 x i8]*> [#uses=0]
@__FUNCTION__.21382 = external global [19 x i8]		; <[19 x i8]*> [#uses=0]
@__FUNCTION__.21117 = external global [21 x i8]		; <[21 x i8]*> [#uses=0]


declare void @push_gimplify_context()

declare i32 @gimple_tree_hash(i8*)

declare i32 @iterative_hash_expr(%struct.tree_node*, i32)

declare i32 @gimple_tree_eq(i8*, i8*)

declare i32 @operand_equal_p(%struct.tree_node*, %struct.tree_node*, i32)

declare void @fancy_abort(i8*, i32, i8*)

declare i8* @xcalloc(i32, i32)

declare %struct.htab* @htab_create(i32, i32 (i8*)*, i32 (i8*, i8*)*, void (i8*)*)

declare void @free(i8*)

declare void @gimple_push_bind_expr(%struct.tree_node*)

declare void @gimple_pop_bind_expr()

declare %struct.tree_node* @gimple_current_bind_expr()

declare fastcc void @gimple_push_condition()

declare %struct.tree_node* @create_artificial_label()

declare %struct.tree_node* @build_decl_stat(i32, %struct.tree_node*, %struct.tree_node*)

declare void @tree_class_check_failed(%struct.tree_node*, i32, i8*, i32, i8*)

declare %struct.tree_node* @create_tmp_var_name(i8*)

declare i32 @strlen(i8*)

declare void @llvm.memcpy.i32(i8*, i8*, i32, i32)

declare i32 @sprintf(i8*, i8*, ...)

declare %struct.tree_node* @get_identifier(i8*)

declare %struct.tree_node* @create_tmp_var_raw(%struct.tree_node*, i8*)

declare %struct.tree_node* @build_qualified_type(%struct.tree_node*, i32)

declare i8* @get_name(%struct.tree_node*)

declare void @tree_operand_check_failed(i32, i32, i8*, i32, i8*)

declare void @tree_check_failed(%struct.tree_node*, i8*, i32, i8*, ...)

declare void @declare_tmp_vars(%struct.tree_node*, %struct.tree_node*)

declare %struct.tree_node* @nreverse(%struct.tree_node*)

declare void @gimple_add_tmp_var(%struct.tree_node*)

declare void @record_vars(%struct.tree_node*)

declare %struct.tree_node* @create_tmp_var(%struct.tree_node*, i8*)

declare void @pop_gimplify_context(%struct.tree_node*)

declare void @htab_delete(%struct.htab*)

declare fastcc void @annotate_one_with_locus(%struct.tree_node*, i32, i32)

declare void @annotate_with_locus(%struct.tree_node*, i32, i32)

declare %struct.tree_node* @mostly_copy_tree_r(%struct.tree_node**, i32*, i8*)

declare %struct.tree_node* @copy_tree_r(%struct.tree_node**, i32*, i8*)

declare %struct.tree_node* @mark_decls_volatile_r(%struct.tree_node**, i32*, i8*)

declare %struct.tree_node* @copy_if_shared_r(%struct.tree_node**, i32*, i8*)

declare %struct.tree_node* @walk_tree(%struct.tree_node**, %struct.tree_node* (%struct.tree_node**, i32*, i8*)*, i8*, %struct.pointer_set_t*)

declare %struct.tree_node* @unmark_visited_r(%struct.tree_node**, i32*, i8*)

declare fastcc void @unshare_body(%struct.tree_node**, %struct.tree_node*)

declare %struct.cgraph_node* @cgraph_node(%struct.tree_node*)

declare fastcc void @unvisit_body(%struct.tree_node**, %struct.tree_node*)

declare void @unshare_all_trees(%struct.tree_node*)

declare %struct.tree_node* @unshare_expr(%struct.tree_node*)

declare %struct.tree_node* @build_and_jump(%struct.tree_node**)

declare %struct.tree_node* @build1_stat(i32, %struct.tree_node*, %struct.tree_node*)

declare i32 @compare_case_labels(i8*, i8*)

declare i32 @tree_int_cst_compare(%struct.tree_node*, %struct.tree_node*)

declare void @sort_case_labels(%struct.tree_node*)

declare void @tree_vec_elt_check_failed(i32, i32, i8*, i32, i8*)

declare void @qsort(i8*, i32, i32, i32 (i8*, i8*)*)

declare %struct.tree_node* @force_labels_r(%struct.tree_node**, i32*, i8*)

declare fastcc void @canonicalize_component_ref(%struct.tree_node**)

declare %struct.tree_node* @get_unwidened(%struct.tree_node*, %struct.tree_node*)

declare fastcc void @maybe_with_size_expr(%struct.tree_node**)

declare %struct.tree_node* @substitute_placeholder_in_expr(%struct.tree_node*, %struct.tree_node*)

declare %struct.tree_node* @build2_stat(i32, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*)

declare fastcc %struct.tree_node* @gimple_boolify(%struct.tree_node*)

declare %struct.tree_node* @convert(%struct.tree_node*, %struct.tree_node*)

declare %struct.tree_node* @gimplify_init_ctor_preeval_1(%struct.tree_node**, i32*, i8*)

declare i64 @get_alias_set(%struct.tree_node*)

declare i32 @alias_sets_conflict_p(i64, i64)

declare fastcc i8 @cpt_same_type(%struct.tree_node*, %struct.tree_node*) zeroext

declare %struct.tree_node* @check_pointer_types_r(%struct.tree_node**, i32*, i8*)

declare %struct.tree_node* @voidify_wrapper_expr(%struct.tree_node*, %struct.tree_node*)

declare i32 @integer_zerop(%struct.tree_node*)

declare fastcc void @append_to_statement_list_1(%struct.tree_node*, %struct.tree_node**)

declare %struct.tree_node* @alloc_stmt_list()

declare void @tsi_link_after(%struct.tree_stmt_iterator*, %struct.tree_node*, i32)

declare void @append_to_statement_list_force(%struct.tree_node*, %struct.tree_node**)

declare void @append_to_statement_list(%struct.tree_node*, %struct.tree_node**)

declare fastcc %struct.tree_node* @shortcut_cond_r(%struct.tree_node*, %struct.tree_node**, %struct.tree_node**)

declare %struct.tree_node* @build3_stat(i32, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*)

declare fastcc %struct.tree_node* @shortcut_cond_expr(%struct.tree_node*)

declare %struct.tree_node* @expr_last(%struct.tree_node*)

declare i8 @block_may_fallthru(%struct.tree_node*) zeroext 

declare fastcc void @gimple_pop_condition(%struct.tree_node**)

declare %struct.tree_node* @gimple_build_eh_filter(%struct.tree_node*, %struct.tree_node*, %struct.tree_node*)

declare void @annotate_all_with_locus(%struct.tree_node**, i32, i32)

declare fastcc %struct.tree_node* @internal_get_tmp_var(%struct.tree_node*, %struct.tree_node**, %struct.tree_node**, i8 zeroext )

define i32 @gimplify_expr(%struct.tree_node** %expr_p, %struct.tree_node** %pre_p, %struct.tree_node** %post_p, i8 (%struct.tree_node*) zeroext * %gimple_test_f, i32 %fallback) {
entry:
	%internal_post = alloca %struct.tree_node*, align 4		; <%struct.tree_node**> [#uses=2]
	%pre_p_addr.0 = select i1 false, %struct.tree_node** null, %struct.tree_node** %pre_p		; <%struct.tree_node**> [#uses=7]
	%post_p_addr.0 = select i1 false, %struct.tree_node** %internal_post, %struct.tree_node** %post_p		; <%struct.tree_node**> [#uses=7]
	br i1 false, label %bb277, label %bb191

bb191:		; preds = %entry
	ret i32 0

bb277:		; preds = %entry
	%tmp283 = call i32 null( %struct.tree_node** %expr_p, %struct.tree_node** %pre_p_addr.0, %struct.tree_node** %post_p_addr.0 )		; <i32> [#uses=1]
	switch i32 %tmp283, label %bb7478 [
		 i32 0, label %cond_next289
		 i32 -1, label %cond_next298
	]

cond_next289:		; preds = %bb277
	ret i32 0

cond_next298:		; preds = %bb277
	switch i32 0, label %bb7444 [
		 i32 24, label %bb7463
		 i32 25, label %bb7463
		 i32 26, label %bb7463
		 i32 27, label %bb7463
		 i32 28, label %bb7463
		 i32 33, label %bb4503
		 i32 39, label %bb397
		 i32 40, label %bb5650
		 i32 41, label %bb4339
		 i32 42, label %bb4350
		 i32 43, label %bb4350
		 i32 44, label %bb319
		 i32 45, label %bb397
		 i32 46, label %bb6124
		 i32 47, label %bb7463
		 i32 49, label %bb5524
		 i32 50, label %bb1283
		 i32 51, label %bb1289
		 i32 52, label %bb1289
		 i32 53, label %bb5969
		 i32 54, label %bb408
		 i32 56, label %bb5079
		 i32 57, label %bb428
		 i32 59, label %bb5965
		 i32 74, label %bb4275
		 i32 75, label %bb4275
		 i32 76, label %bb4275
		 i32 77, label %bb4275
		 i32 91, label %bb1296
		 i32 92, label %bb1296
		 i32 96, label %bb1322
		 i32 112, label %bb2548
		 i32 113, label %bb2548
		 i32 115, label %bb397
		 i32 116, label %bb5645
		 i32 117, label %bb1504
		 i32 121, label %bb397
		 i32 122, label %bb397
		 i32 123, label %bb313
		 i32 124, label %bb313
		 i32 125, label %bb313
		 i32 126, label %bb313
		 i32 127, label %bb2141
		 i32 128, label %cond_next5873
		 i32 129, label %cond_next5873
		 i32 130, label %bb4536
		 i32 131, label %bb5300
		 i32 132, label %bb5170
		 i32 133, label %bb5519
		 i32 134, label %bb5091
		 i32 135, label %bb5083
		 i32 136, label %bb5087
		 i32 137, label %bb5382
		 i32 139, label %bb7463
		 i32 140, label %bb7463
		 i32 142, label %bb5974
		 i32 143, label %bb6049
		 i32 147, label %bb6296
		 i32 151, label %cond_next6474
	]

bb313:		; preds = %cond_next298, %cond_next298, %cond_next298, %cond_next298
	ret i32 0

bb319:		; preds = %cond_next298
	ret i32 0

bb397:		; preds = %cond_next298, %cond_next298, %cond_next298, %cond_next298, %cond_next298
	ret i32 0

bb408:		; preds = %cond_next298
	%tmp413 = call fastcc i32 @gimplify_cond_expr( %struct.tree_node** %expr_p, %struct.tree_node** %pre_p_addr.0, %struct.tree_node** %post_p_addr.0, %struct.tree_node* null, i32 %fallback )		; <i32> [#uses=0]
	ret i32 0

bb428:		; preds = %cond_next298
	ret i32 0

bb1283:		; preds = %cond_next298
	ret i32 0

bb1289:		; preds = %cond_next298, %cond_next298
	ret i32 0

bb1296:		; preds = %cond_next298, %cond_next298
	ret i32 0

bb1322:		; preds = %cond_next298
	ret i32 0

bb1504:		; preds = %cond_next298
	ret i32 0

bb2141:		; preds = %cond_next298
	ret i32 0

bb2548:		; preds = %cond_next298, %cond_next298
	%tmp2554 = load %struct.tree_node** %expr_p		; <%struct.tree_node*> [#uses=2]
	%tmp2562 = and i32 0, 255		; <i32> [#uses=1]
	%tmp2569 = add i8 0, -4		; <i8> [#uses=1]
	icmp ugt i8 %tmp2569, 5		; <i1>:0 [#uses=2]
	%tmp2587 = load i8* null		; <i8> [#uses=1]
	icmp eq i8 %tmp2587, 0		; <i1>:1 [#uses=2]
	%tmp2607 = load %struct.tree_node** null		; <%struct.tree_node*> [#uses=2]
	br i1 false, label %bb2754, label %cond_next2617

cond_next2617:		; preds = %bb2548
	ret i32 0

bb2754:		; preds = %bb2548
	br i1 %0, label %cond_true2780, label %cond_next2783

cond_true2780:		; preds = %bb2754
	call void @tree_class_check_failed( %struct.tree_node* %tmp2554, i32 9, i8* getelementptr ([42 x i8]* @str, i32 0, i32 0), i32 1415, i8* getelementptr ([20 x i8]* @__FUNCTION__.22136, i32 0, i32 0) )
	unreachable

cond_next2783:		; preds = %bb2754
	%tmp2825 = and i32 0, 255		; <i32> [#uses=1]
	%tmp2829 = load i32* null		; <i32> [#uses=1]
	%tmp28292830 = trunc i32 %tmp2829 to i8		; <i8> [#uses=1]
	%tmp2832 = add i8 %tmp28292830, -4		; <i8> [#uses=1]
	icmp ugt i8 %tmp2832, 5		; <i1>:2 [#uses=1]
	icmp eq i8 0, 0		; <i1>:3 [#uses=1]
	%tmp28652866 = bitcast %struct.tree_node* %tmp2607 to %struct.tree_exp*		; <%struct.tree_exp*> [#uses=1]
	%tmp2868 = getelementptr %struct.tree_exp* %tmp28652866, i32 0, i32 4, i32 0		; <%struct.tree_node**> [#uses=1]
	%tmp2870 = load %struct.tree_node** %tmp2868		; <%struct.tree_node*> [#uses=1]
	br i1 %1, label %cond_true2915, label %cond_next2927

cond_true2915:		; preds = %cond_next2783
	unreachable

cond_next2927:		; preds = %cond_next2783
	%tmp2938 = load %struct.tree_node** null		; <%struct.tree_node*> [#uses=1]
	%tmp2944 = load i32* null		; <i32> [#uses=1]
	%tmp2946 = and i32 %tmp2944, 255		; <i32> [#uses=1]
	%tmp2949 = getelementptr [0 x i32]* @tree_code_type, i32 0, i32 %tmp2946		; <i32*> [#uses=1]
	%tmp2950 = load i32* %tmp2949		; <i32> [#uses=1]
	icmp eq i32 %tmp2950, 2		; <i1>:4 [#uses=1]
	br i1 %4, label %cond_next2954, label %cond_true2951

cond_true2951:		; preds = %cond_next2927
	call void @tree_class_check_failed( %struct.tree_node* %tmp2938, i32 2, i8* getelementptr ([42 x i8]* @str, i32 0, i32 0), i32 1415, i8* getelementptr ([20 x i8]* @__FUNCTION__.22136, i32 0, i32 0) )
	unreachable

cond_next2954:		; preds = %cond_next2927
	br i1 %0, label %cond_true2991, label %cond_next2994

cond_true2991:		; preds = %cond_next2954
	unreachable

cond_next2994:		; preds = %cond_next2954
	br i1 %1, label %cond_true3009, label %cond_next3021

cond_true3009:		; preds = %cond_next2994
	call void @tree_operand_check_failed( i32 0, i32 %tmp2562, i8* getelementptr ([42 x i8]* @str, i32 0, i32 0), i32 1415, i8* getelementptr ([20 x i8]* @__FUNCTION__.22136, i32 0, i32 0) )
	unreachable

cond_next3021:		; preds = %cond_next2994
	br i1 %2, label %cond_true3044, label %cond_next3047

cond_true3044:		; preds = %cond_next3021
	call void @tree_class_check_failed( %struct.tree_node* %tmp2607, i32 9, i8* getelementptr ([42 x i8]* @str, i32 0, i32 0), i32 1415, i8* getelementptr ([20 x i8]* @__FUNCTION__.22136, i32 0, i32 0) )
	unreachable

cond_next3047:		; preds = %cond_next3021
	br i1 %3, label %cond_true3062, label %cond_next3074

cond_true3062:		; preds = %cond_next3047
	call void @tree_operand_check_failed( i32 0, i32 %tmp2825, i8* getelementptr ([42 x i8]* @str, i32 0, i32 0), i32 1415, i8* getelementptr ([20 x i8]* @__FUNCTION__.22136, i32 0, i32 0) )
	unreachable

cond_next3074:		; preds = %cond_next3047
	%tmp3084 = getelementptr %struct.tree_node* %tmp2870, i32 0, i32 0, i32 0, i32 1		; <%struct.tree_node**> [#uses=1]
	%tmp3085 = load %struct.tree_node** %tmp3084		; <%struct.tree_node*> [#uses=1]
	%tmp31043105 = bitcast %struct.tree_node* %tmp3085 to %struct.tree_type*		; <%struct.tree_type*> [#uses=1]
	%tmp3106 = getelementptr %struct.tree_type* %tmp31043105, i32 0, i32 6		; <i16*> [#uses=1]
	%tmp31063107 = bitcast i16* %tmp3106 to i32*		; <i32*> [#uses=1]
	%tmp3108 = load i32* %tmp31063107		; <i32> [#uses=1]
	xor i32 %tmp3108, 0		; <i32>:5 [#uses=1]
	%tmp81008368 = and i32 %5, 65024		; <i32> [#uses=1]
	icmp eq i32 %tmp81008368, 0		; <i1>:6 [#uses=1]
	br i1 %6, label %cond_next3113, label %bb3351

cond_next3113:		; preds = %cond_next3074
	ret i32 0

bb3351:		; preds = %cond_next3074
	%tmp3354 = call i8 @tree_ssa_useless_type_conversion( %struct.tree_node* %tmp2554 ) zeroext 		; <i8> [#uses=1]
	icmp eq i8 %tmp3354, 0		; <i1>:7 [#uses=1]
	%tmp3424 = load i32* null		; <i32> [#uses=1]
	br i1 %7, label %cond_next3417, label %cond_true3356

cond_true3356:		; preds = %bb3351
	ret i32 0

cond_next3417:		; preds = %bb3351
	br i1 false, label %cond_true3429, label %cond_next4266

cond_true3429:		; preds = %cond_next3417
	%tmp3443 = and i32 %tmp3424, 255		; <i32> [#uses=0]
	ret i32 0

cond_next4266:		; preds = %cond_next3417
	%tmp4268 = load %struct.tree_node** %expr_p		; <%struct.tree_node*> [#uses=1]
	icmp eq %struct.tree_node* %tmp4268, null		; <i1>:8 [#uses=1]
	br i1 %8, label %bb4275, label %bb7463

bb4275:		; preds = %cond_next4266, %cond_next298, %cond_next298, %cond_next298, %cond_next298
	%tmp4289 = and i32 0, 255		; <i32> [#uses=2]
	%tmp4292 = getelementptr [0 x i32]* @tree_code_type, i32 0, i32 %tmp4289		; <i32*> [#uses=1]
	%tmp4293 = load i32* %tmp4292		; <i32> [#uses=1]
	%tmp42934294 = trunc i32 %tmp4293 to i8		; <i8> [#uses=1]
	%tmp4296 = add i8 %tmp42934294, -4		; <i8> [#uses=1]
	icmp ugt i8 %tmp4296, 5		; <i1>:9 [#uses=1]
	br i1 %9, label %cond_true4297, label %cond_next4300

cond_true4297:		; preds = %bb4275
	unreachable

cond_next4300:		; preds = %bb4275
	%tmp4314 = load i8* null		; <i8> [#uses=1]
	icmp eq i8 %tmp4314, 0		; <i1>:10 [#uses=1]
	br i1 %10, label %cond_true4315, label %cond_next4327

cond_true4315:		; preds = %cond_next4300
	call void @tree_operand_check_failed( i32 0, i32 %tmp4289, i8* getelementptr ([42 x i8]* @str, i32 0, i32 0), i32 3997, i8* getelementptr ([14 x i8]* @__FUNCTION__.26156, i32 0, i32 0) )
	unreachable

cond_next4327:		; preds = %cond_next4300
	%tmp4336 = call i32 @gimplify_expr( %struct.tree_node** null, %struct.tree_node** %pre_p_addr.0, %struct.tree_node** %post_p_addr.0, i8 (%struct.tree_node*) zeroext * @is_gimple_val, i32 1 )		; <i32> [#uses=0]
	ret i32 0

bb4339:		; preds = %cond_next298
	ret i32 0

bb4350:		; preds = %cond_next298, %cond_next298
	ret i32 0

bb4503:		; preds = %cond_next298
	ret i32 0

bb4536:		; preds = %cond_next298
	ret i32 0

bb5079:		; preds = %cond_next298
	ret i32 0

bb5083:		; preds = %cond_next298
	ret i32 0

bb5087:		; preds = %cond_next298
	ret i32 0

bb5091:		; preds = %cond_next298
	ret i32 0

bb5170:		; preds = %cond_next298
	ret i32 0

bb5300:		; preds = %cond_next298
	ret i32 0

bb5382:		; preds = %cond_next298
	ret i32 0

bb5519:		; preds = %cond_next298
	ret i32 0

bb5524:		; preds = %cond_next298
	ret i32 0

bb5645:		; preds = %cond_next298
	ret i32 0

bb5650:		; preds = %cond_next298
	ret i32 0

cond_next5873:		; preds = %cond_next298, %cond_next298
	ret i32 0

bb5965:		; preds = %cond_next298
	%tmp5968 = call fastcc i32 @gimplify_cleanup_point_expr( %struct.tree_node** %expr_p, %struct.tree_node** %pre_p_addr.0 )		; <i32> [#uses=0]
	ret i32 0

bb5969:		; preds = %cond_next298
	%tmp5973 = call fastcc i32 @gimplify_target_expr( %struct.tree_node** %expr_p, %struct.tree_node** %pre_p_addr.0, %struct.tree_node** %post_p_addr.0 )		; <i32> [#uses=0]
	ret i32 0

bb5974:		; preds = %cond_next298
	ret i32 0

bb6049:		; preds = %cond_next298
	ret i32 0

bb6124:		; preds = %cond_next298
	ret i32 0

bb6296:		; preds = %cond_next298
	ret i32 0

cond_next6474:		; preds = %cond_next298
	icmp eq %struct.tree_node** %internal_post, %post_p_addr.0		; <i1>:11 [#uses=1]
	%iftmp.381.0 = select i1 %11, %struct.tree_node** null, %struct.tree_node** %post_p_addr.0		; <%struct.tree_node**> [#uses=1]
	%tmp6490 = call i32 @gimplify_expr( %struct.tree_node** null, %struct.tree_node** %pre_p_addr.0, %struct.tree_node** %iftmp.381.0, i8 (%struct.tree_node*) zeroext * %gimple_test_f, i32 %fallback )		; <i32> [#uses=0]
	%tmp6551 = call i32 @gimplify_expr( %struct.tree_node** null, %struct.tree_node** %pre_p_addr.0, %struct.tree_node** %post_p_addr.0, i8 (%struct.tree_node*) zeroext * @is_gimple_val, i32 1 )		; <i32> [#uses=0]
	ret i32 0

bb7444:		; preds = %cond_next298
	ret i32 0

bb7463:		; preds = %cond_next4266, %cond_next298, %cond_next298, %cond_next298, %cond_next298, %cond_next298, %cond_next298, %cond_next298, %cond_next298
	ret i32 0

bb7478:		; preds = %bb277
	ret i32 0
}

declare i8 @is_gimple_formal_tmp_rhs(%struct.tree_node*) zeroext 

declare void @gimplify_and_add(%struct.tree_node*, %struct.tree_node**)

declare %struct.tree_node* @get_initialized_tmp_var(%struct.tree_node*, %struct.tree_node**, %struct.tree_node**)

declare %struct.tree_node* @get_formal_tmp_var(%struct.tree_node*, %struct.tree_node**)

declare fastcc void @gimplify_init_ctor_preeval(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**, %struct.gimplify_init_ctor_preeval_data*)

declare i8 @type_contains_placeholder_p(%struct.tree_node*) zeroext 

declare i8 @is_gimple_mem_rhs(%struct.tree_node*) zeroext 

declare fastcc i32 @gimplify_modify_expr_rhs(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**, %struct.tree_node**, %struct.tree_node**, i8 zeroext )

declare %struct.tree_node* @fold_indirect_ref(%struct.tree_node*)

declare fastcc i32 @gimplify_compound_expr(%struct.tree_node**, %struct.tree_node**, i8 zeroext )

declare i8 @is_gimple_lvalue(%struct.tree_node*) zeroext 

declare void @categorize_ctor_elements(%struct.tree_node*, i64*, i64*, i64*, i8*)

declare void @lhd_set_decl_assembler_name(%struct.tree_node*)

declare i64 @int_size_in_bytes(%struct.tree_node*)

declare i32 @can_move_by_pieces(i64, i32)

declare i64 @count_type_elements(%struct.tree_node*)

declare void @gimplify_stmt(%struct.tree_node**)

declare %struct.tree_node* @get_base_address(%struct.tree_node*)

declare fastcc void @gimplify_init_ctor_eval(%struct.tree_node*, %struct.tree_node*, %struct.tree_node**, i8 zeroext )

declare %struct.tree_node* @build_complex(%struct.tree_node*, %struct.tree_node*, %struct.tree_node*)

declare i8 (%struct.tree_node*) zeroext * @rhs_predicate_for(%struct.tree_node*)

declare %struct.tree_node* @build_vector(%struct.tree_node*, %struct.tree_node*)

declare i8 @is_gimple_val(%struct.tree_node*) zeroext 

declare i8 @is_gimple_reg_type(%struct.tree_node*) zeroext 

declare fastcc i32 @gimplify_cond_expr(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**, %struct.tree_node*, i32)

declare fastcc i32 @gimplify_modify_expr(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**, i8 zeroext )

declare %struct.tree_node* @tree_cons_stat(%struct.tree_node*, %struct.tree_node*, %struct.tree_node*)

declare %struct.tree_node* @build_fold_addr_expr(%struct.tree_node*)

declare %struct.tree_node* @build_function_call_expr(%struct.tree_node*, %struct.tree_node*)

declare i8 @is_gimple_addressable(%struct.tree_node*) zeroext 

declare i8 @is_gimple_reg(%struct.tree_node*) zeroext 

declare %struct.tree_node* @make_ssa_name(%struct.tree_node*, %struct.tree_node*)

declare i8 @tree_ssa_useless_type_conversion(%struct.tree_node*) zeroext 

declare fastcc i32 @gimplify_self_mod_expr(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**, i8 zeroext )

declare fastcc i32 @gimplify_compound_lval(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**, i32)

declare %struct.tree_node* @get_callee_fndecl(%struct.tree_node*)

declare %struct.tree_node* @fold_builtin(%struct.tree_node*, i8 zeroext )

declare void @error(i8*, ...)

declare %struct.tree_node* @build_empty_stmt()

declare i8 @fold_builtin_next_arg(%struct.tree_node*) zeroext 

declare fastcc i32 @gimplify_arg(%struct.tree_node**, %struct.tree_node**)

declare i8 @is_gimple_call_addr(%struct.tree_node*) zeroext 

declare i32 @call_expr_flags(%struct.tree_node*)

declare void @recalculate_side_effects(%struct.tree_node*)

declare %struct.tree_node* @fold_convert(%struct.tree_node*, %struct.tree_node*)

declare void @recompute_tree_invarant_for_addr_expr(%struct.tree_node*)

declare i32 @gimplify_va_arg_expr(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**)

declare %struct.tree_node* @size_int_kind(i64, i32)

declare %struct.tree_node* @size_binop(i32, %struct.tree_node*, %struct.tree_node*)

declare %struct.tree_node* @build4_stat(i32, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*)

declare void @gimplify_type_sizes(%struct.tree_node*, %struct.tree_node**)

declare void @gimplify_one_sizepos(%struct.tree_node**, %struct.tree_node**)

declare %struct.tree_node* @build_pointer_type(%struct.tree_node*)

declare %struct.tree_node* @build_fold_indirect_ref(%struct.tree_node*)

declare fastcc i32 @gimplify_bind_expr(%struct.tree_node**, %struct.tree_node*, %struct.tree_node**)

declare fastcc void @gimplify_loop_expr(%struct.tree_node**, %struct.tree_node**)

declare fastcc i32 @gimplify_switch_expr(%struct.tree_node**, %struct.tree_node**)

declare %struct.tree_node* @decl_function_context(%struct.tree_node*)

declare %struct.varray_head_tag* @varray_grow(%struct.varray_head_tag*, i32)

declare fastcc void @gimplify_return_expr(%struct.tree_node*, %struct.tree_node**)

declare fastcc i32 @gimplify_save_expr(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**)

declare fastcc i32 @gimplify_asm_expr(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**)

declare void @gimplify_to_stmt_list(%struct.tree_node**)

declare fastcc i32 @gimplify_cleanup_point_expr(%struct.tree_node**, %struct.tree_node**)

declare fastcc i32 @gimplify_target_expr(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**)

declare void @tsi_delink(%struct.tree_stmt_iterator*)

declare void @tsi_link_before(%struct.tree_stmt_iterator*, %struct.tree_node*, i32)

declare i8 @is_gimple_stmt(%struct.tree_node*) zeroext 

declare void @print_generic_expr(%struct.FILE*, %struct.tree_node*, i32)

declare void @debug_tree(%struct.tree_node*)

declare void @internal_error(i8*, ...)

declare %struct.tree_node* @force_gimple_operand(%struct.tree_node*, %struct.tree_node**, i8 zeroext , %struct.tree_node*)

declare i8 @is_gimple_reg_rhs(%struct.tree_node*) zeroext 

declare void @add_referenced_tmp_var(%struct.tree_node*)

declare i8 @contains_placeholder_p(%struct.tree_node*) zeroext 

declare %struct.varray_head_tag* @varray_init(i32, i32, i8*)

declare i32 @handled_component_p(%struct.tree_node*)

declare void @varray_check_failed(%struct.varray_head_tag*, i32, i8*, i32, i8*)

declare %struct.tree_node* @array_ref_low_bound(%struct.tree_node*)

declare i8 @is_gimple_min_invariant(%struct.tree_node*) zeroext 

declare i8 @is_gimple_formal_tmp_reg(%struct.tree_node*) zeroext 

declare %struct.tree_node* @array_ref_element_size(%struct.tree_node*)

declare %struct.tree_node* @component_ref_field_offset(%struct.tree_node*)

declare i8 @is_gimple_min_lval(%struct.tree_node*) zeroext 

declare void @varray_underflow(%struct.varray_head_tag*, i8*, i32, i8*)

declare i32 @list_length(%struct.tree_node*)

declare i8 @parse_output_constraint(i8**, i32, i32, i32, i8*, i8*, i8*) zeroext 

declare i8* @xstrdup(i8*)

declare %struct.tree_node* @build_string(i32, i8*)

declare i8* @strchr(i8*, i32)

declare %struct.tree_node* @build_tree_list_stat(%struct.tree_node*, %struct.tree_node*)

declare %struct.tree_node* @chainon(%struct.tree_node*, %struct.tree_node*)

declare i8 @parse_input_constraint(i8**, i32, i32, i32, i32, i8**, i8*, i8*) zeroext 

declare i8 @is_gimple_asm_val(%struct.tree_node*) zeroext 

declare void @gimplify_body(%struct.tree_node**, %struct.tree_node*, i8 zeroext )

declare void @timevar_push_1(i32)

declare %struct.tree_node* @gimplify_parameters()

declare %struct.tree_node* @expr_only(%struct.tree_node*)

declare void @timevar_pop_1(i32)

declare void @gimplify_function_tree(%struct.tree_node*)

declare void @allocate_struct_function(%struct.tree_node*)

declare %struct.tree_node* @make_tree_vec_stat(i32)

declare %struct.tree_node* @tsi_split_statement_list_after(%struct.tree_stmt_iterator*)

declare i8 @is_gimple_condexpr(%struct.tree_node*) zeroext 

declare %struct.tree_node* @invert_truthvalue(%struct.tree_node*)

declare i8 @initializer_zerop(%struct.tree_node*) zeroext 

declare i32 @simple_cst_equal(%struct.tree_node*, %struct.tree_node*)

declare i32 @aggregate_value_p(%struct.tree_node*, %struct.tree_node*)

declare i32 @fwrite(i8*, i32, i32, %struct.FILE*)