; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 ; RUN: llc -mtriple=amdgcn -mcpu=gfx90a < %s | FileCheck %s define void @callbr_inline_asm(ptr %src, ptr %dst1, ptr %dst2, i32 %c) { ; CHECK-LABEL: callbr_inline_asm: ; CHECK: ; %bb.0: ; CHECK-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) ; CHECK-NEXT: flat_load_dword v0, v[0:1] ; CHECK-NEXT: ;;#ASMSTART ; CHECK-NEXT: v_cmp_gt_i32 vcc v6, 42; s_cbranch_vccnz .LBB0_2 ; CHECK-NEXT: ;;#ASMEND ; CHECK-NEXT: ; %bb.1: ; %fallthrough ; CHECK-NEXT: s_waitcnt vmcnt(0) lgkmcnt(0) ; CHECK-NEXT: flat_store_dword v[2:3], v0 ; CHECK-NEXT: s_waitcnt vmcnt(0) lgkmcnt(0) ; CHECK-NEXT: s_setpc_b64 s[30:31] ; CHECK-NEXT: .LBB0_2: ; Inline asm indirect target ; CHECK-NEXT: ; %indirect ; CHECK-NEXT: ; Label of block must be emitted ; CHECK-NEXT: s_waitcnt vmcnt(0) lgkmcnt(0) ; CHECK-NEXT: flat_store_dword v[4:5], v0 ; CHECK-NEXT: s_waitcnt vmcnt(0) lgkmcnt(0) ; CHECK-NEXT: s_setpc_b64 s[30:31] %a = load i32, ptr %src, align 4 callbr void asm "v_cmp_gt_i32 vcc $0, 42; s_cbranch_vccnz ${1:l}", "r,!i"(i32 %c) to label %fallthrough [label %indirect] fallthrough: store i32 %a, ptr %dst1, align 4 br label %ret indirect: store i32 %a, ptr %dst2, align 4 br label %ret ret: ret void } define void @callbr_self_loop(i1 %c) { ; CHECK-LABEL: callbr_self_loop: ; CHECK: ; %bb.0: ; CHECK-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) ; CHECK-NEXT: .LBB1_1: ; %callbr ; CHECK-NEXT: ; =>This Inner Loop Header: Depth=1 ; CHECK-NEXT: ;;#ASMSTART ; CHECK-NEXT: ;;#ASMEND ; CHECK-NEXT: s_branch .LBB1_1 ; CHECK-NEXT: .LBB1_2: ; Inline asm indirect target ; CHECK-NEXT: ; %callbr.target.ret ; CHECK-NEXT: ; Label of block must be emitted ; CHECK-NEXT: s_setpc_b64 s[30:31] br label %callbr callbr: callbr void asm "", "!i"() to label %callbr [label %ret] ret: ret void }