llvm/bolt/test/X86/ignored-interprocedural-reference.s

## This reproduces a bug with not processing interprocedural references from
## ignored functions.

# REQUIRES: system-linux

# RUN: llvm-mc -filetype=obj -triple x86_64-unknown-unknown %s -o %t.o
# RUN: %clang %cflags %t.o -o %t.exe -nostdlib -Wl,-q
# RUN: llvm-bolt %t.exe -o %t.out --enable-bat -funcs=main
# RUN: link_fdata %s %t.out %t.preagg PREAGG
# RUN: perf2bolt %t.out -p %t.preagg --pa -o %t.fdata -w %t.yaml
# RUN: FileCheck %s --input-file=%t.fdata --check-prefix=CHECK-FDATA
# RUN: FileCheck %s --input-file=%t.yaml --check-prefix=CHECK-YAML

# CHECK-FDATA: 1 main 0 1 foo a 1 1
# CHECK-YAML: name: main
# CHECK-YAML: calls: {{.*}} disc: 1

# PREAGG: B #main# #foo_secondary# 1 1
## main calls foo at valid instruction offset past nops that are to be stripped.
  .globl main
main:
  .cfi_startproc
  call foo_secondary
  ret
  .cfi_endproc
.size main,.-main

## Placeholder cold fragment to force main to be ignored in non-relocation mode.
  .globl main.cold
main.cold:
  .cfi_startproc
  ud2
  .cfi_endproc
.size main.cold,.-main.cold

## foo is set up to contain a valid instruction at called offset, and trapping
## instructions past that.
  .globl foo
foo:
  .cfi_startproc
  .nops 10
  .globl foo_secondary
foo_secondary:
  ret
  .rept 20
  int3
  .endr
  .cfi_endproc
.size foo,.-foo