xref: /llvm-project/llvm/test/CodeGen/PowerPC/aix-relativeref.ll (revision 427fb35192f1f7bb694a5910b05abc5925a798b2)
1; RUN: llc -verify-machineinstrs -mtriple powerpc64-ibm-aix-xcoff  < %s | \
2; RUN:   FileCheck --check-prefix=ASM %s
3
4@__profc_main = private global [1 x i64] zeroinitializer, section "__llvm_prf_cnts", align 8
5@__profd_main = private global { i64, i64, i64, ptr, ptr, i32, [4 x i16] } { i64 -2624081020897602054, i64 742261418966908927, i64 sub (i64 ptrtoint (ptr @__profc_main to i64), i64 ptrtoint (ptr @__profd_main to i64)), ptr @main, ptr null, i32 1, [4 x i16] zeroinitializer }, section "__llvm_prf_data", align 8
6
7; Test fallback of using sub expr for lowerRelativeReference
8define signext i32 @main() {
9; ASM-LABEL: main:
10; ASM:  L..__profd_main:
11; ASM:        .vbyte  8, L..__profc_main-L..__profd_main
12entry:
13  %pgocount = load i64, ptr @__profc_main, align 8
14  %0 = add i64 %pgocount, 1
15  store i64 %0, ptr @__profc_main, align 8
16  %retval = alloca i32, align 4
17  store i32 0, ptr %retval, align 4
18  ret i32 0
19}
20
21