|  | ; 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 | 
|  | } |