• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1; RUN: llc < %s -mtriple=arm-linux-gnueabi
2; PR1257
3
4	%struct.CUMULATIVE_ARGS = type { i32, i32, i32, i32, i32, i32 }
5	%struct.arm_stack_offsets = type { i32, i32, i32, i32, i32 }
6	%struct.c_arg_info = type { %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, %struct.tree_node*, i8 }
7	%struct.c_language_function = type { %struct.stmt_tree_s }
8	%struct.c_switch = type opaque
9	%struct.eh_status = type opaque
10	%struct.emit_status = type { i32, i32, %struct.rtx_def*, %struct.rtx_def*, %struct.sequence_stack*, i32, %struct.location_t, i32, i8*, %struct.rtx_def** }
11	%struct.expr_status = type { i32, i32, i32, %struct.rtx_def*, %struct.rtx_def*, %struct.rtx_def* }
12	%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 }
13	%struct.ht_identifier = type { i8*, i32, i32 }
14	%struct.initial_value_struct = type opaque
15	%struct.lang_decl = type { i8 }
16	%struct.language_function = type { %struct.c_language_function, %struct.tree_node*, %struct.tree_node*, %struct.c_switch*, %struct.c_arg_info*, i32, i32, i32, i32 }
17	%struct.location_t = type { i8*, i32 }
18	%struct.machine_function = type { %struct.rtx_def*, i32, i32, i32, %struct.arm_stack_offsets, i32, i32, i32, [14 x %struct.rtx_def*] }
19	%struct.rtvec_def = type { i32, [1 x %struct.rtx_def*] }
20	%struct.rtx_def = type { i16, i8, i8, %struct.u }
21	%struct.sequence_stack = type { %struct.rtx_def*, %struct.rtx_def*, %struct.sequence_stack* }
22	%struct.stmt_tree_s = type { %struct.tree_node*, i32 }
23	%struct.temp_slot = type opaque
24	%struct.tree_common = type { %struct.tree_node*, %struct.tree_node*, %union.tree_ann_d*, i8, i8, i8, i8, i8 }
25	%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* }
26	%struct.tree_decl_u1 = type { i64 }
27	%struct.tree_decl_u2 = type { %struct.function* }
28	%struct.tree_identifier = type { %struct.tree_common, %struct.ht_identifier }
29	%struct.tree_node = type { %struct.tree_decl }
30	%struct.u = type { [1 x i64] }
31	%struct.var_refs_queue = type { %struct.rtx_def*, i32, i32, %struct.var_refs_queue* }
32	%struct.varasm_status = type opaque
33	%struct.varray_head_tag = type opaque
34	%union.tree_ann_d = type opaque
35
36
37define void @declspecs_add_type(i32 %spec.1) {
38entry:
39	%spec.1961 = zext i32 %spec.1 to i64		; <i64> [#uses=1]
40	%spec.1961.adj = shl i64 %spec.1961, 32		; <i64> [#uses=1]
41	%spec.1961.adj.ins = or i64 %spec.1961.adj, 0		; <i64> [#uses=2]
42	%tmp10959 = lshr i64 %spec.1961.adj.ins, 32		; <i64> [#uses=2]
43	%tmp1920 = inttoptr i64 %tmp10959 to %struct.tree_common*		; <%struct.tree_common*> [#uses=1]
44	%tmp21 = getelementptr %struct.tree_common* %tmp1920, i32 0, i32 3		; <i8*> [#uses=1]
45	%tmp2122 = bitcast i8* %tmp21 to i32*		; <i32*> [#uses=1]
46	br i1 false, label %cond_next53, label %cond_true
47
48cond_true:		; preds = %entry
49	ret void
50
51cond_next53:		; preds = %entry
52	br i1 false, label %cond_true63, label %cond_next689
53
54cond_true63:		; preds = %cond_next53
55	ret void
56
57cond_next689:		; preds = %cond_next53
58	br i1 false, label %cond_false841, label %bb743
59
60bb743:		; preds = %cond_next689
61	ret void
62
63cond_false841:		; preds = %cond_next689
64	br i1 false, label %cond_true851, label %cond_true918
65
66cond_true851:		; preds = %cond_false841
67	tail call void @lookup_name( )
68	br i1 false, label %bb866, label %cond_next856
69
70cond_next856:		; preds = %cond_true851
71	ret void
72
73bb866:		; preds = %cond_true851
74	%tmp874 = load i32* %tmp2122		; <i32> [#uses=1]
75	%tmp876877 = trunc i32 %tmp874 to i8		; <i8> [#uses=1]
76	icmp eq i8 %tmp876877, 1		; <i1>:0 [#uses=1]
77	br i1 %0, label %cond_next881, label %cond_true878
78
79cond_true878:		; preds = %bb866
80	unreachable
81
82cond_next881:		; preds = %bb866
83	%tmp884885 = inttoptr i64 %tmp10959 to %struct.tree_identifier*		; <%struct.tree_identifier*> [#uses=1]
84	%tmp887 = getelementptr %struct.tree_identifier* %tmp884885, i32 0, i32 1, i32 0		; <i8**> [#uses=1]
85	%tmp888 = load i8** %tmp887		; <i8*> [#uses=1]
86	tail call void (i32, ...)* @error( i32 undef, i8* %tmp888 )
87	ret void
88
89cond_true918:		; preds = %cond_false841
90	%tmp920957 = trunc i64 %spec.1961.adj.ins to i32		; <i32> [#uses=0]
91	ret void
92}
93
94declare void @error(i32, ...)
95
96declare void @lookup_name()
97