blob: fefa5a0a68020fdc1d835ced09ff09c6d166d5c1 [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc %s -o - | FileCheck %s --check-prefix=CHECK
target datalayout = "e-m:o-p:32:32-Fi8-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32"
target triple = "thumbv7-apple-darwin"
; This test checks that even with NEON register induced stack re-alignment, and
; with the frame-pointer=non-leaf option, that we still save fp aka r7 in the
; prolog as required.
define fastcc i32 @test_save_fp() #0 {
; CHECK-LABEL: test_save_fp:
; CHECK: @ %bb.0:
; CHECK-NEXT: push {r4, r7, lr}
; CHECK-NEXT: add r7, sp, #4
; CHECK-NEXT: sub.w r4, sp, #64
; CHECK-NEXT: bfc r4, #0, #4
; CHECK-NEXT: mov sp, r4
; CHECK-NEXT: vst1.64 {d8, d9, d10, d11}, [r4:128]!
; CHECK-NEXT: movs r0, #0
; CHECK-NEXT: vst1.64 {d12, d13, d14, d15}, [r4:128]
; CHECK-NEXT: mov r4, sp
; CHECK-NEXT: @ InlineAsm Start
; CHECK-NEXT: vld1.16 {d0, d1, d2, d3}, [r0]
; CHECK-NEXT: vld1.16 {d4, d5, d6, d7}, [r0]
; CHECK-NEXT: vabdl.s16 q4, d0, d4
; CHECK-EMPTY:
; CHECK-NEXT: @ InlineAsm End
; CHECK-NEXT: vld1.64 {d8, d9, d10, d11}, [r4:128]!
; CHECK-NEXT: vld1.64 {d12, d13, d14, d15}, [r4:128]
; CHECK-NEXT: subs r4, r7, #4
; CHECK-NEXT: mov sp, r4
; CHECK-NEXT: pop {r4, r7, pc}
tail call void asm sideeffect "vld1.i16 {q0,q1}, [$0]\0Avld1.i16 {q2,q3}, [$1]\0Avabdl.s16 q4, d0, d4\0A", "r,r,r,~{q0},~{q1},~{q2},~{q3},~{q4},~{q5},~{q6},~{q7},~{memory}"(ptr null, ptr null, ptr null)
ret i32 0
}
attributes #0 = { "frame-pointer"="non-leaf" }