| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| ; RUN: llc -verify-machineinstrs -csky-no-aliases < %s -mtriple=csky | FileCheck %s |
| |
| @p_fun = global ptr @bar, align 8 |
| |
| declare void @bar(i32, i32) |
| |
| define void @foo(i32 %a, ptr %ptr){ |
| ; CHECK-LABEL: foo: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: subi16 sp, sp, 4 |
| ; CHECK-NEXT: .cfi_def_cfa_offset 4 |
| ; CHECK-NEXT: st32.w lr, (sp, 0) # 4-byte Folded Spill |
| ; CHECK-NEXT: .cfi_offset lr, -4 |
| ; CHECK-NEXT: subi16 sp, sp, 4 |
| ; CHECK-NEXT: .cfi_def_cfa_offset 8 |
| ; CHECK-NEXT: ld16.w a1, (a1, 0) |
| ; CHECK-NEXT: lrw32 a2, [.LCPI0_0] |
| ; CHECK-NEXT: jsr16 a2 |
| ; CHECK-NEXT: addi16 sp, sp, 4 |
| ; CHECK-NEXT: ld32.w lr, (sp, 0) # 4-byte Folded Reload |
| ; CHECK-NEXT: addi16 sp, sp, 4 |
| ; CHECK-NEXT: rts16 |
| ; CHECK-NEXT: .p2align 1 |
| ; CHECK-NEXT: # %bb.1: |
| ; CHECK-NEXT: .p2align 2 |
| ; CHECK-NEXT: .LCPI0_0: |
| ; CHECK-NEXT: .long bar |
| ; |
| entry: |
| %0 = load i32, ptr %ptr |
| tail call void (i32, i32) @bar(i32 %a, i32 %0) |
| ret void |
| } |
| |
| define void @foo_indirect(i32 %a, ptr %ptr) { |
| ; CHECK-LABEL: foo_indirect: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: subi16 sp, sp, 4 |
| ; CHECK-NEXT: .cfi_def_cfa_offset 4 |
| ; CHECK-NEXT: st32.w lr, (sp, 0) # 4-byte Folded Spill |
| ; CHECK-NEXT: .cfi_offset lr, -4 |
| ; CHECK-NEXT: subi16 sp, sp, 4 |
| ; CHECK-NEXT: .cfi_def_cfa_offset 8 |
| ; CHECK-NEXT: lrw32 a2, [.LCPI1_0] |
| ; CHECK-NEXT: ld16.w a2, (a2, 0) |
| ; CHECK-NEXT: ld16.w a1, (a1, 0) |
| ; CHECK-NEXT: jsr16 a2 |
| ; CHECK-NEXT: addi16 sp, sp, 4 |
| ; CHECK-NEXT: ld32.w lr, (sp, 0) # 4-byte Folded Reload |
| ; CHECK-NEXT: addi16 sp, sp, 4 |
| ; CHECK-NEXT: rts16 |
| ; CHECK-NEXT: .p2align 1 |
| ; CHECK-NEXT: # %bb.1: |
| ; CHECK-NEXT: .p2align 2 |
| ; CHECK-NEXT: .LCPI1_0: |
| ; CHECK-NEXT: .long p_fun |
| ; |
| entry: |
| %0 = load ptr, ptr @p_fun, align 8 |
| %1 = load i32, ptr %ptr |
| tail call void (i32, i32) %0(i32 %a, i32 %1) |
| ret void |
| } |