Evan Cheng | 48d8afa | 2009-11-01 21:12:51 +0000 | [diff] [blame^] | 1 | ; RUN: llc < %s -mtriple=thumbv7-apple-darwin -mcpu=cortex-a8 -relocation-model=pic -disable-fp-elim | FileCheck %s |
| 2 | ; rdar://7352504 |
| 3 | ; Make sure we use "str r9, [sp, #+28]" instead of "sub.w r4, r7, #256" followed by "str r9, [r4, #-32]". |
| 4 | |
| 5 | %0 = type { i16, i8, i8 } |
| 6 | %1 = type { [2 x i32], [2 x i32] } |
| 7 | %2 = type { %union.rec* } |
| 8 | %struct.FILE_POS = type { i8, i8, i16, i32 } |
| 9 | %struct.GAP = type { i8, i8, i16 } |
| 10 | %struct.LIST = type { %union.rec*, %union.rec* } |
| 11 | %struct.STYLE = type { %union.anon, %union.anon, i16, i16, i32 } |
| 12 | %struct.head_type = type { [2 x %struct.LIST], %union.FIRST_UNION, %union.SECOND_UNION, %union.THIRD_UNION, %union.FOURTH_UNION, %union.rec*, %2, %union.rec*, %union.rec*, %union.rec*, %union.rec*, %union.rec*, %union.rec*, %union.rec*, %union.rec*, i32 } |
| 13 | %union.FIRST_UNION = type { %struct.FILE_POS } |
| 14 | %union.FOURTH_UNION = type { %struct.STYLE } |
| 15 | %union.SECOND_UNION = type { %0 } |
| 16 | %union.THIRD_UNION = type { %1 } |
| 17 | %union.anon = type { %struct.GAP } |
| 18 | %union.rec = type { %struct.head_type } |
| 19 | |
| 20 | @zz_hold = external global %union.rec* ; <%union.rec**> [#uses=2] |
| 21 | @zz_res = external global %union.rec* ; <%union.rec**> [#uses=1] |
| 22 | |
| 23 | define arm_apcscc %union.rec* @Manifest(%union.rec* %x, %union.rec* %env, %struct.STYLE* %style, %union.rec** %bthr, %union.rec** %fthr, %union.rec** %target, %union.rec** %crs, i32 %ok, i32 %need_expand, %union.rec** %enclose, i32 %fcr) nounwind { |
| 24 | entry: |
| 25 | ; CHECK: ldr.w r9, [r7, #+32] |
| 26 | ; CHECK-NEXT : str.w r9, [sp, #+28] |
| 27 | %xgaps.i = alloca [32 x %union.rec*], align 4 ; <[32 x %union.rec*]*> [#uses=0] |
| 28 | %ycomp.i = alloca [32 x %union.rec*], align 4 ; <[32 x %union.rec*]*> [#uses=0] |
| 29 | br i1 false, label %bb, label %bb20 |
| 30 | |
| 31 | bb: ; preds = %entry |
| 32 | unreachable |
| 33 | |
| 34 | bb20: ; preds = %entry |
| 35 | switch i32 undef, label %bb1287 [ |
| 36 | i32 11, label %bb119 |
| 37 | i32 12, label %bb119 |
| 38 | i32 21, label %bb420 |
| 39 | i32 23, label %bb420 |
| 40 | i32 45, label %bb438 |
| 41 | i32 46, label %bb438 |
| 42 | i32 55, label %bb533 |
| 43 | i32 56, label %bb569 |
| 44 | i32 64, label %bb745 |
| 45 | i32 78, label %bb1098 |
| 46 | ] |
| 47 | |
| 48 | bb119: ; preds = %bb20, %bb20 |
| 49 | unreachable |
| 50 | |
| 51 | bb420: ; preds = %bb20, %bb20 |
| 52 | store %union.rec* null, %union.rec** @zz_hold, align 4 |
| 53 | store %union.rec* null, %union.rec** @zz_res, align 4 |
| 54 | store %union.rec* %x, %union.rec** @zz_hold, align 4 |
| 55 | %0 = call arm_apcscc %union.rec* @Manifest(%union.rec* undef, %union.rec* %env, %struct.STYLE* %style, %union.rec** %bthr, %union.rec** %fthr, %union.rec** %target, %union.rec** %crs, i32 %ok, i32 %need_expand, %union.rec** %enclose, i32 %fcr) nounwind ; <%union.rec*> [#uses=0] |
| 56 | unreachable |
| 57 | |
| 58 | bb438: ; preds = %bb20, %bb20 |
| 59 | unreachable |
| 60 | |
| 61 | bb533: ; preds = %bb20 |
| 62 | ret %union.rec* %x |
| 63 | |
| 64 | bb569: ; preds = %bb20 |
| 65 | unreachable |
| 66 | |
| 67 | bb745: ; preds = %bb20 |
| 68 | unreachable |
| 69 | |
| 70 | bb1098: ; preds = %bb20 |
| 71 | unreachable |
| 72 | |
| 73 | bb1287: ; preds = %bb20 |
| 74 | unreachable |
| 75 | } |