llvm/llvm/test/CodeGen/MIR/X86/expected-block-reference-in-blockaddress.mir

# RUN: not llc -march=x86-64 -run-pass none -o /dev/null %s 2>&1 | FileCheck %s
#

--- |

  @addr = global ptr null

  define void @test() {
  entry:
    store volatile ptr blockaddress(@test, %block), ptr @addr
    %val = load volatile ptr, ptr @addr
    indirectbr ptr %val, [label %block]

  block:
    ret void
  }

...
---
name:            test
body: |
  bb.0.entry:
    successors: %bb.1.block
    ; CHECK: [[@LINE+1]]:51: expected an IR block reference
    $rax = LEA64r $rip, 1, _, blockaddress(@test, _), _
    MOV64mr $rip, 1, _, @addr, _, killed $rax
    JMP64m $rip, 1, _, @addr, _

  bb.1.block (ir-block-address-taken %ir-block.block):
    RET64
...