Fix part 1 of pr4682. PICADD is a 16-bit instruction even in thumb2 mode.
[llvm/avr.git] / test / CodeGen / ARM / 2007-03-21-JoinIntervalsCrash.ll
blob32daf839f0fc96431e2da7dc1b12a143ed981f05
1 ; RUN: llvm-as < %s | llc -mtriple=arm-linux-gnueabi
2 ; PR1257
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
37 define void @declspecs_add_type(i32 %spec.1) {
38 entry:
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
48 cond_true:              ; preds = %entry
49         ret void
51 cond_next53:            ; preds = %entry
52         br i1 false, label %cond_true63, label %cond_next689
54 cond_true63:            ; preds = %cond_next53
55         ret void
57 cond_next689:           ; preds = %cond_next53
58         br i1 false, label %cond_false841, label %bb743
60 bb743:          ; preds = %cond_next689
61         ret void
63 cond_false841:          ; preds = %cond_next689
64         br i1 false, label %cond_true851, label %cond_true918
66 cond_true851:           ; preds = %cond_false841
67         tail call void @lookup_name( )
68         br i1 false, label %bb866, label %cond_next856
70 cond_next856:           ; preds = %cond_true851
71         ret void
73 bb866:          ; 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
79 cond_true878:           ; preds = %bb866
80         unreachable
82 cond_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
89 cond_true918:           ; preds = %cond_false841
90         %tmp920957 = trunc i64 %spec.1961.adj.ins to i32                ; <i32> [#uses=0]
91         ret void
94 declare void @error(i32, ...)
96 declare void @lookup_name()