[llvm-commits] CVS: llvm/test/CodeGen/ARM/2007-03-26-RegScavengerAssert.ll

Evan Cheng evan.cheng at apple.com
Mon Mar 26 15:58:52 PDT 2007



Changes in directory llvm/test/CodeGen/ARM:

2007-03-26-RegScavengerAssert.ll added (r1.1)
---
Log message:

Test case for PR1266: http://llvm.org/PR1266 .

---
Diffs of the changes:  (+948 -0)

 2007-03-26-RegScavengerAssert.ll |  948 +++++++++++++++++++++++++++++++++++++++
 1 files changed, 948 insertions(+)


Index: llvm/test/CodeGen/ARM/2007-03-26-RegScavengerAssert.ll
diff -c /dev/null llvm/test/CodeGen/ARM/2007-03-26-RegScavengerAssert.ll:1.1
*** /dev/null	Mon Mar 26 17:58:45 2007
--- llvm/test/CodeGen/ARM/2007-03-26-RegScavengerAssert.ll	Mon Mar 26 17:58:35 2007
***************
*** 0 ****
--- 1,948 ----
+ ; 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) zext *, i8 (i8**) zext *, i8 () zext *, 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*) zext *, %struct.tree_node* (%struct.tree_node*)*, void (%struct.tree_node*)*, void (%struct.tree_node*)*, i8 () zext *, 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.tre!
 e_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*) zext *, void ()*, void (%struct.tree_node*)*, i8 (%struct.tree_node*) zext *, 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*) zext * }
+ 	%struct.lang_hooks_for_tree_dump = type { i8 (i8*, %struct.tree_node*) zext *, 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*) zext *, 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*) zext *, 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]
+ 
+ implementation   ; Functions:
+ 
+ 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*) zext 
+ 
+ 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*) zext 
+ 
+ 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 zext )
+ 
+ define i32 @gimplify_expr(%struct.tree_node** %expr_p, %struct.tree_node** %pre_p, %struct.tree_node** %post_p, i8 (%struct.tree_node*) zext * %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 ) zext 		; <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*) zext * @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*) zext * %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*) zext * @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*) zext 
+ 
+ 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*) zext 
+ 
+ declare i8 @is_gimple_mem_rhs(%struct.tree_node*) zext 
+ 
+ declare fastcc i32 @gimplify_modify_expr_rhs(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**, %struct.tree_node**, %struct.tree_node**, i8 zext )
+ 
+ declare %struct.tree_node* @fold_indirect_ref(%struct.tree_node*)
+ 
+ declare fastcc i32 @gimplify_compound_expr(%struct.tree_node**, %struct.tree_node**, i8 zext )
+ 
+ declare i8 @is_gimple_lvalue(%struct.tree_node*) zext 
+ 
+ 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 zext )
+ 
+ declare %struct.tree_node* @build_complex(%struct.tree_node*, %struct.tree_node*, %struct.tree_node*)
+ 
+ declare i8 (%struct.tree_node*) zext * @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*) zext 
+ 
+ declare i8 @is_gimple_reg_type(%struct.tree_node*) zext 
+ 
+ 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 zext )
+ 
+ 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*) zext 
+ 
+ declare i8 @is_gimple_reg(%struct.tree_node*) zext 
+ 
+ declare %struct.tree_node* @make_ssa_name(%struct.tree_node*, %struct.tree_node*)
+ 
+ declare i8 @tree_ssa_useless_type_conversion(%struct.tree_node*) zext 
+ 
+ declare fastcc i32 @gimplify_self_mod_expr(%struct.tree_node**, %struct.tree_node**, %struct.tree_node**, i8 zext )
+ 
+ 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 zext )
+ 
+ declare void @error(i8*, ...)
+ 
+ declare %struct.tree_node* @build_empty_stmt()
+ 
+ declare i8 @fold_builtin_next_arg(%struct.tree_node*) zext 
+ 
+ declare fastcc i32 @gimplify_arg(%struct.tree_node**, %struct.tree_node**)
+ 
+ declare i8 @is_gimple_call_addr(%struct.tree_node*) zext 
+ 
+ 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*) zext 
+ 
+ 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 zext , %struct.tree_node*)
+ 
+ declare i8 @is_gimple_reg_rhs(%struct.tree_node*) zext 
+ 
+ declare void @add_referenced_tmp_var(%struct.tree_node*)
+ 
+ declare i8 @contains_placeholder_p(%struct.tree_node*) zext 
+ 
+ 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*) zext 
+ 
+ declare i8 @is_gimple_formal_tmp_reg(%struct.tree_node*) zext 
+ 
+ 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*) zext 
+ 
+ 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*) zext 
+ 
+ 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*) zext 
+ 
+ declare i8 @is_gimple_asm_val(%struct.tree_node*) zext 
+ 
+ declare void @gimplify_body(%struct.tree_node**, %struct.tree_node*, i8 zext )
+ 
+ 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*) zext 
+ 
+ declare %struct.tree_node* @invert_truthvalue(%struct.tree_node*)
+ 
+ declare i8 @initializer_zerop(%struct.tree_node*) zext 
+ 
+ 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*)






More information about the llvm-commits mailing list