[ARM] More MVE compare vector splat combines for ANDs
[llvm-complete.git] / test / Instrumentation / InstrProfiling / always_inline.ll
blob4be7848c9b6feeef1a1a6f158214bd6ac3bc870b
1 ; Check that '__attribute__((always_inline)) inline' functions are inlined.
3 ; RUN: opt < %s -mtriple=x86_64-apple-macosx10.10.0 -instrprof -inline -S | FileCheck %s 
5 target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
6 target triple = "x86_64-apple-macosx10.13.0"
8 @__profn_foo = linkonce_odr hidden constant [3 x i8] c"foo"
10 ; CHECK-LABEL: @main
11 ; CHECK-NOT: call
12 define i32 @main() {
13 entry:
14   %call = call i32 @foo()
15   ret i32 %call
18 declare void @llvm.instrprof.increment(i8*, i64, i32, i32) #0
20 ; CHECK-NOT: define available_externally i32 @foo
21 define available_externally i32 @foo() #1 {
22 entry:
23   call void @llvm.instrprof.increment(i8* getelementptr inbounds ([3 x i8], [3 x i8]* @__profn_foo, i32 0, i32 0), i64 0, i32 1, i32 0)
24   ret i32 0
27 attributes #0 = { nounwind }
28 attributes #1 = { alwaysinline }