blob: d07092230a4daa9b4b49fa38a1b0c87d5124feb5 [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc --mtriple=loongarch32 < %s | FileCheck %s
; RUN: llc --mtriple=loongarch64 < %s | FileCheck %s
; RUN: llc --mtriple=loongarch32 --no-integrated-as < %s | FileCheck %s
; RUN: llc --mtriple=loongarch64 --no-integrated-as < %s | FileCheck %s
;; This regression test is for ensuring the AsmParser does not use the
;; getOrCreateSymbol interface to create blockaddress symbols.
;; Otherwise incorrect symbols will be created:
;; `.Ltmp0` -> `.Ltmp00`.
define void @operand_block_address() nounwind {
; CHECK-LABEL: operand_block_address:
; CHECK: # %bb.0:
; CHECK-NEXT: #APP
; CHECK-NEXT: b .Ltmp0
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: .Ltmp0: # Block address taken
; CHECK-NEXT: # %bb.1: # %bb
; CHECK-NEXT: ret
call void asm sideeffect "b $0", "i"(ptr blockaddress(@operand_block_address, %bb))
br label %bb
bb:
ret void
}