[ARM] Adjust how NEON shifts are lowered
[llvm-core.git] / test / CodeGen / ARM / 2010-03-04-eabi-fp-spill.ll
blobd21b488bb3a0e170b61f13672077381c100f11c5
1 ; RUN: llc < %s -mtriple=arm-unknown-linux-gnueabi
3 define void @"java.lang.String::getChars"([84 x i8]* %method, i32 %base_pc, [788 x i8]* %thread) {
4   %1 = load i32, i32* undef                            ; <i32> [#uses=1]
5   %2 = sub i32 %1, 48                             ; <i32> [#uses=1]
6   br i1 undef, label %stack_overflow, label %no_overflow
8 stack_overflow:                                   ; preds = %0
9   unreachable
11 no_overflow:                                      ; preds = %0
12   %frame = inttoptr i32 %2 to [17 x i32]*         ; <[17 x i32]*> [#uses=4]
13   %3 = load i32, i32* undef                            ; <i32> [#uses=1]
14   %4 = load i32, i32* null                             ; <i32> [#uses=1]
15   %5 = getelementptr inbounds [17 x i32], [17 x i32]* %frame, i32 0, i32 13 ; <i32*> [#uses=1]
16   %6 = bitcast i32* %5 to [8 x i8]**              ; <[8 x i8]**> [#uses=1]
17   %7 = load [8 x i8]*, [8 x i8]** %6                         ; <[8 x i8]*> [#uses=1]
18   %8 = getelementptr inbounds [17 x i32], [17 x i32]* %frame, i32 0, i32 12 ; <i32*> [#uses=1]
19   %9 = load i32, i32* %8                               ; <i32> [#uses=1]
20   br i1 undef, label %bci_13, label %bci_4
22 bci_13:                                           ; preds = %no_overflow
23   br i1 undef, label %bci_30, label %bci_21
25 bci_30:                                           ; preds = %bci_13
26   br i1 undef, label %bci_46, label %bci_35
28 bci_46:                                           ; preds = %bci_30
29   %10 = sub i32 %4, %3                            ; <i32> [#uses=1]
30   %11 = load [8 x i8]*, [8 x i8]** null                      ; <[8 x i8]*> [#uses=1]
31   %callee = bitcast [8 x i8]* %11 to [84 x i8]*   ; <[84 x i8]*> [#uses=1]
32   %12 = bitcast i8* undef to i32*                 ; <i32*> [#uses=1]
33   %base_pc7 = load i32, i32* %12                       ; <i32> [#uses=2]
34   %13 = add i32 %base_pc7, 0                      ; <i32> [#uses=1]
35   %14 = inttoptr i32 %13 to void ([84 x i8]*, i32, [788 x i8]*)** ; <void ([84 x i8]*, i32, [788 x i8]*)**> [#uses=1]
36   %entry_point = load void ([84 x i8]*, i32, [788 x i8]*)*, void ([84 x i8]*, i32, [788 x i8]*)** %14 ; <void ([84 x i8]*, i32, [788 x i8]*)*> [#uses=1]
37   %15 = getelementptr inbounds [17 x i32], [17 x i32]* %frame, i32 0, i32 1 ; <i32*> [#uses=1]
38   %16 = ptrtoint i32* %15 to i32                  ; <i32> [#uses=1]
39   %stack_pointer_addr9 = bitcast i8* undef to i32* ; <i32*> [#uses=1]
40   store i32 %16, i32* %stack_pointer_addr9
41   %17 = getelementptr inbounds [17 x i32], [17 x i32]* %frame, i32 0, i32 2 ; <i32*> [#uses=1]
42   store i32 %9, i32* %17
43   store i32 %10, i32* undef
44   store [84 x i8]* %method, [84 x i8]** undef
45   %18 = add i32 %base_pc, 20                      ; <i32> [#uses=1]
46   store i32 %18, i32* undef
47   store [8 x i8]* %7, [8 x i8]** undef
48   call void %entry_point([84 x i8]* %callee, i32 %base_pc7, [788 x i8]* %thread)
49   br i1 undef, label %no_exception, label %exception
51 exception:                                        ; preds = %bci_46
52   ret void
54 no_exception:                                     ; preds = %bci_46
55   ret void
57 bci_35:                                           ; preds = %bci_30
58   ret void
60 bci_21:                                           ; preds = %bci_13
61   ret void
63 bci_4:                                            ; preds = %no_overflow
64   ret void