blob: 82c0dab1a680a9e4ba483bb85e51f7c3fa3a1b73 [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc --mtriple=xtensa < %s | FileCheck -check-prefixes=CHECK %s
; RUN: llc --mtriple=xtensa --mattr=+windowed < %s | FileCheck -check-prefixes=CHECK-WINDOWED %s
declare ptr @llvm.stacksave()
declare void @llvm.stackrestore(ptr)
declare void @use_addr(ptr)
define void @test_saverestore(i64 %n) {
; CHECK-LABEL: test_saverestore:
; CHECK: .cfi_startproc
; CHECK-NEXT: # %bb.0:
; CHECK-NEXT: addi a8, a1, -16
; CHECK-NEXT: or a1, a8, a8
; CHECK-NEXT: .cfi_def_cfa_offset 16
; CHECK-NEXT: s32i a0, a1, 8 # 4-byte Folded Spill
; CHECK-NEXT: s32i a12, a1, 4 # 4-byte Folded Spill
; CHECK-NEXT: s32i a15, a1, 0 # 4-byte Folded Spill
; CHECK-NEXT: .cfi_offset a0, -4
; CHECK-NEXT: .cfi_offset a12, -8
; CHECK-NEXT: .cfi_offset a15, -12
; CHECK-NEXT: or a15, a1, a1
; CHECK-NEXT: .cfi_def_cfa_register a15
; CHECK-NEXT: addi a8, a2, 3
; CHECK-NEXT: movi a9, -4
; CHECK-NEXT: and a8, a8, a9
; CHECK-NEXT: addi a8, a8, 31
; CHECK-NEXT: movi a9, -32
; CHECK-NEXT: and a8, a8, a9
; CHECK-NEXT: or a12, a1, a1
; CHECK-NEXT: sub a1, a1, a8
; CHECK-NEXT: or a2, a1, a1
; CHECK-NEXT: l32r a8, .LCPI0_0
; CHECK-NEXT: callx0 a8
; CHECK-NEXT: or a1, a12, a12
; CHECK-NEXT: or a1, a15, a15
; CHECK-NEXT: l32i a15, a1, 0 # 4-byte Folded Reload
; CHECK-NEXT: l32i a12, a1, 4 # 4-byte Folded Reload
; CHECK-NEXT: l32i a0, a1, 8 # 4-byte Folded Reload
; CHECK-NEXT: addi a8, a1, 16
; CHECK-NEXT: or a1, a8, a8
; CHECK-NEXT: ret
;
; CHECK-WINDOWED-LABEL: test_saverestore:
; CHECK-WINDOWED: .cfi_startproc
; CHECK-WINDOWED-NEXT: # %bb.0:
; CHECK-WINDOWED-NEXT: entry a1, 32
; CHECK-WINDOWED-NEXT: or a7, a1, a1
; CHECK-WINDOWED-NEXT: .cfi_def_cfa a7, 32
; CHECK-WINDOWED-NEXT: addi a8, a2, 3
; CHECK-WINDOWED-NEXT: movi a9, -4
; CHECK-WINDOWED-NEXT: and a8, a8, a9
; CHECK-WINDOWED-NEXT: addi a8, a8, 31
; CHECK-WINDOWED-NEXT: movi a9, -32
; CHECK-WINDOWED-NEXT: and a8, a8, a9
; CHECK-WINDOWED-NEXT: or a6, a1, a1
; CHECK-WINDOWED-NEXT: sub a8, a1, a8
; CHECK-WINDOWED-NEXT: movsp a1, a8
; CHECK-WINDOWED-NEXT: or a10, a1, a1
; CHECK-WINDOWED-NEXT: l32r a8, .LCPI0_0
; CHECK-WINDOWED-NEXT: callx8 a8
; CHECK-WINDOWED-NEXT: movsp a1, a6
; CHECK-WINDOWED-NEXT: retw
%sp = call ptr @llvm.stacksave.p0()
%addr = alloca i8, i64 %n
call void @use_addr(ptr %addr)
call void @llvm.stackrestore.p0(ptr %sp)
ret void
}