xref: /llvm-project/llvm/test/CodeGen/Mips/frame-address.ll (revision d8a5fae6913a0f6c7e3c814315c1a11fcfd609a1)
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2; RUN: llc -mtriple=mipsel-elf < %s | FileCheck %s
3
4declare ptr @llvm.frameaddress(i32) nounwind readnone
5
6define ptr @f() nounwind uwtable {
7; CHECK-LABEL: f:
8; CHECK:       # %bb.0: # %entry
9; CHECK-NEXT:    addiu $sp, $sp, -8
10; CHECK-NEXT:    .cfi_def_cfa_offset 8
11; CHECK-NEXT:    sw $ra, 4($sp) # 4-byte Folded Spill
12; CHECK-NEXT:    sw $fp, 0($sp) # 4-byte Folded Spill
13; CHECK-NEXT:    .cfi_offset 31, -4
14; CHECK-NEXT:    .cfi_offset 30, -8
15; CHECK-NEXT:    move $fp, $sp
16; CHECK-NEXT:    .cfi_def_cfa_register 30
17; CHECK-NEXT:    move $2, $fp
18; CHECK-NEXT:    move $sp, $fp
19; CHECK-NEXT:    lw $fp, 0($sp) # 4-byte Folded Reload
20; CHECK-NEXT:    lw $ra, 4($sp) # 4-byte Folded Reload
21; CHECK-NEXT:    jr $ra
22; CHECK-NEXT:    addiu $sp, $sp, 8
23entry:
24  %0 = call ptr @llvm.frameaddress(i32 0)
25  ret ptr %0
26}
27