blob: 32709cb2cc03503a6fc9efb8ec1fb305c8e43de0 [file]
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --filter "call i32 @(test_single_bb_resolver|test_multi_bb_resolver|test_caller_feats_not_implied|test_non_fmv_caller|test_priority|test_alternative_names|test_unrelated_callers|test_known_bits|test_priority_override)" --version 4
; REQUIRES: aarch64-registered-target
; RUN: opt --passes=globalopt -o - -S < %s | FileCheck %s
target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
target triple = "aarch64-unknown-linux-gnu"
$test_single_bb_resolver.resolver = comdat any
$test_multi_bb_resolver.resolver = comdat any
$test_caller_feats_not_implied.resolver = comdat any
$test_non_fmv_caller.resolver = comdat any
$test_priority.resolver = comdat any
$test_alternative_names.resolver = comdat any
$test_unrelated_callers.resolver = comdat any
$test_known_bits.resolver = comdat any
$test_priority_override.resolver = comdat any
$caller1.resolver = comdat any
$caller2.resolver = comdat any
$caller3.resolver = comdat any
$caller6.resolver = comdat any
$caller7.resolver = comdat any
$caller8.resolver = comdat any
$caller9.resolver = comdat any
$caller11.resolver = comdat any
$caller12.resolver = comdat any
@__aarch64_cpu_features = external local_unnamed_addr global { i64 }
@test_single_bb_resolver = weak_odr ifunc i32 (), ptr @test_single_bb_resolver.resolver
@test_multi_bb_resolver = weak_odr ifunc i32 (), ptr @test_multi_bb_resolver.resolver
@test_caller_feats_not_implied = weak_odr ifunc i32 (), ptr @test_caller_feats_not_implied.resolver
@test_non_fmv_caller = weak_odr ifunc i32 (), ptr @test_non_fmv_caller.resolver
@test_priority = weak_odr ifunc i32 (), ptr @test_priority.resolver
@test_alternative_names = weak_odr ifunc i32 (), ptr @test_alternative_names.resolver
@test_unrelated_callers = weak_odr ifunc i32 (), ptr @test_unrelated_callers.resolver
@test_known_bits = weak_odr ifunc i32 (), ptr @test_known_bits.resolver
@test_priority_override = weak_odr ifunc i32 (), ptr @test_priority_override.resolver
@caller1 = weak_odr ifunc i32 (), ptr @caller1.resolver
@caller2 = weak_odr ifunc i32 (), ptr @caller2.resolver
@caller3 = weak_odr ifunc i32 (), ptr @caller3.resolver
@caller6 = weak_odr ifunc i32 (), ptr @caller6.resolver
@caller7 = weak_odr ifunc i32 (), ptr @caller7.resolver
@caller8 = weak_odr ifunc i32 (), ptr @caller8.resolver
@caller9 = weak_odr ifunc i32 (), ptr @caller9.resolver
@caller11 = weak_odr ifunc i32 (), ptr @caller11.resolver
@caller12 = weak_odr ifunc i32 (), ptr @caller12.resolver
declare void @__init_cpu_features_resolver() local_unnamed_addr
declare i32 @test_single_bb_resolver.default() #0
declare i32 @test_single_bb_resolver._Msve() #1
declare i32 @test_single_bb_resolver._Msve2() #2
define weak_odr ptr @test_single_bb_resolver.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @test_single_bb_resolver.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 69793284352
%2 = icmp eq i64 %1, 69793284352
%3 = and i64 %0, 1073807616
%4 = icmp eq i64 %3, 1073807616
%test_single_bb_resolver._Msve.test_single_bb_resolver.default = select i1 %4, ptr @test_single_bb_resolver._Msve, ptr @test_single_bb_resolver.default
%common.ret.op = select i1 %2, ptr @test_single_bb_resolver._Msve2, ptr %test_single_bb_resolver._Msve.test_single_bb_resolver.default
ret ptr %common.ret.op
}
define i32 @caller1._Msve() #1 {
; CHECK-LABEL: define i32 @caller1._Msve(
; CHECK-SAME: ) #[[ATTR1:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_single_bb_resolver._Msve()
;
entry:
%call = tail call i32 @test_single_bb_resolver()
ret i32 %call
}
define i32 @caller1._Msve2() #2 {
; CHECK-LABEL: define i32 @caller1._Msve2(
; CHECK-SAME: ) #[[ATTR2:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_single_bb_resolver._Msve2()
;
entry:
%call = tail call i32 @test_single_bb_resolver()
ret i32 %call
}
define i32 @caller1.default() #0 {
; CHECK-LABEL: define i32 @caller1.default(
; CHECK-SAME: ) #[[ATTR0:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_single_bb_resolver.default()
;
entry:
%call = tail call i32 @test_single_bb_resolver()
ret i32 %call
}
define weak_odr ptr @caller1.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @caller1.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 69793284352
%2 = icmp eq i64 %1, 69793284352
%3 = and i64 %0, 1073807616
%4 = icmp eq i64 %3, 1073807616
%caller1._Msve.caller1.default = select i1 %4, ptr @caller1._Msve, ptr @caller1.default
%common.ret.op = select i1 %2, ptr @caller1._Msve2, ptr %caller1._Msve.caller1.default
ret ptr %common.ret.op
}
declare i32 @test_multi_bb_resolver._Mmops() #3
declare i32 @test_multi_bb_resolver._Msve2() #2
declare i32 @test_multi_bb_resolver._Msve() #1
declare i32 @test_multi_bb_resolver.default() #0
define weak_odr ptr @test_multi_bb_resolver.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @test_multi_bb_resolver.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 576460752303423488
%.not = icmp eq i64 %1, 0
br i1 %.not, label %resolver_else, label %common.ret
common.ret: ; preds = %resolver_else2, %resolver_else, %resolver_entry
%common.ret.op = phi ptr [ @test_multi_bb_resolver._Mmops, %resolver_entry ], [ @test_multi_bb_resolver._Msve2, %resolver_else ], [ %test_multi_bb_resolver._Msve.test_multi_bb_resolver.default, %resolver_else2 ]
ret ptr %common.ret.op
resolver_else: ; preds = %resolver_entry
%2 = and i64 %0, 69793284352
%3 = icmp eq i64 %2, 69793284352
br i1 %3, label %common.ret, label %resolver_else2
resolver_else2: ; preds = %resolver_else
%4 = and i64 %0, 1073807616
%5 = icmp eq i64 %4, 1073807616
%test_multi_bb_resolver._Msve.test_multi_bb_resolver.default = select i1 %5, ptr @test_multi_bb_resolver._Msve, ptr @test_multi_bb_resolver.default
br label %common.ret
}
define i32 @caller2._MmopsMsve2() #4 {
; CHECK-LABEL: define i32 @caller2._MmopsMsve2(
; CHECK-SAME: ) #[[ATTR4:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_multi_bb_resolver._Mmops()
;
entry:
%call = tail call i32 @test_multi_bb_resolver()
ret i32 %call
}
define i32 @caller2._Mmops() #3 {
; CHECK-LABEL: define i32 @caller2._Mmops(
; CHECK-SAME: ) #[[ATTR3:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_multi_bb_resolver._Mmops()
;
entry:
%call = tail call i32 @test_multi_bb_resolver()
ret i32 %call
}
define i32 @caller2._Msve() #1 {
; CHECK-LABEL: define i32 @caller2._Msve(
; CHECK-SAME: ) #[[ATTR1]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_multi_bb_resolver()
;
entry:
%call = tail call i32 @test_multi_bb_resolver()
ret i32 %call
}
define i32 @caller2.default() #0 {
; CHECK-LABEL: define i32 @caller2.default(
; CHECK-SAME: ) #[[ATTR0]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_multi_bb_resolver.default()
;
entry:
%call = tail call i32 @test_multi_bb_resolver()
ret i32 %call
}
define weak_odr ptr @caller2.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @caller2.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 576460822096707840
%2 = icmp eq i64 %1, 576460822096707840
br i1 %2, label %common.ret, label %resolver_else
common.ret: ; preds = %resolver_else2, %resolver_else, %resolver_entry
%common.ret.op = phi ptr [ @caller2._MmopsMsve2, %resolver_entry ], [ @caller2._Mmops, %resolver_else ], [ %caller2._Msve.caller2.default, %resolver_else2 ]
ret ptr %common.ret.op
resolver_else: ; preds = %resolver_entry
%3 = and i64 %0, 576460752303423488
%.not = icmp eq i64 %3, 0
br i1 %.not, label %resolver_else2, label %common.ret
resolver_else2: ; preds = %resolver_else
%4 = and i64 %0, 1073807616
%5 = icmp eq i64 %4, 1073807616
%caller2._Msve.caller2.default = select i1 %5, ptr @caller2._Msve, ptr @caller2.default
br label %common.ret
}
declare i32 @test_caller_feats_not_implied._Mmops() #3
declare i32 @test_caller_feats_not_implied._Msme() #5
declare i32 @test_caller_feats_not_implied._Msve() #1
declare i32 @test_caller_feats_not_implied.default() #0
define weak_odr ptr @test_caller_feats_not_implied.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @test_caller_feats_not_implied.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 576460752303423488
%.not = icmp eq i64 %1, 0
br i1 %.not, label %resolver_else, label %common.ret
common.ret: ; preds = %resolver_else2, %resolver_else, %resolver_entry
%common.ret.op = phi ptr [ @test_caller_feats_not_implied._Mmops, %resolver_entry ], [ @test_caller_feats_not_implied._Msme, %resolver_else ], [ %test_caller_feats_not_implied._Msve.test_caller_feats_not_implied.default, %resolver_else2 ]
ret ptr %common.ret.op
resolver_else: ; preds = %resolver_entry
%2 = and i64 %0, 4398180795136
%3 = icmp eq i64 %2, 4398180795136
br i1 %3, label %common.ret, label %resolver_else2
resolver_else2: ; preds = %resolver_else
%4 = and i64 %0, 1073807616
%5 = icmp eq i64 %4, 1073807616
%test_caller_feats_not_implied._Msve.test_caller_feats_not_implied.default = select i1 %5, ptr @test_caller_feats_not_implied._Msve, ptr @test_caller_feats_not_implied.default
br label %common.ret
}
define i32 @caller3._Mmops() #3 {
; CHECK-LABEL: define i32 @caller3._Mmops(
; CHECK-SAME: ) #[[ATTR3]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_caller_feats_not_implied._Mmops()
;
entry:
%call = tail call i32 @test_caller_feats_not_implied()
ret i32 %call
}
define i32 @caller3._Msve() #1 {
; CHECK-LABEL: define i32 @caller3._Msve(
; CHECK-SAME: ) #[[ATTR1]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_caller_feats_not_implied()
;
entry:
%call = tail call i32 @test_caller_feats_not_implied()
ret i32 %call
}
define i32 @caller3.default() #0 {
; CHECK-LABEL: define i32 @caller3.default(
; CHECK-SAME: ) #[[ATTR0]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_caller_feats_not_implied()
;
entry:
%call = tail call i32 @test_caller_feats_not_implied()
ret i32 %call
}
define weak_odr ptr @caller3.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @caller3.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 576460752303423488
%.not = icmp eq i64 %1, 0
%2 = and i64 %0, 1073807616
%3 = icmp eq i64 %2, 1073807616
%caller3._Msve.caller3.default = select i1 %3, ptr @caller3._Msve, ptr @caller3.default
%common.ret.op = select i1 %.not, ptr %caller3._Msve.caller3.default, ptr @caller3._Mmops
ret ptr %common.ret.op
}
declare i32 @test_non_fmv_caller._Maes() #6
declare i32 @test_non_fmv_caller._Msm4() #7
declare i32 @test_non_fmv_caller.default() #0
define weak_odr ptr @test_non_fmv_caller.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @test_non_fmv_caller.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 33536
%2 = icmp eq i64 %1, 33536
%3 = and i64 %0, 800
%4 = icmp eq i64 %3, 800
%test_non_fmv_caller._Msm4.test_non_fmv_caller.default = select i1 %4, ptr @test_non_fmv_caller._Msm4, ptr @test_non_fmv_caller.default
%common.ret.op = select i1 %2, ptr @test_non_fmv_caller._Maes, ptr %test_non_fmv_caller._Msm4.test_non_fmv_caller.default
ret ptr %common.ret.op
}
define i32 @caller4() #8 {
; CHECK-LABEL: define i32 @caller4(
; CHECK-SAME: ) local_unnamed_addr #[[ATTR8:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_non_fmv_caller._Maes()
;
entry:
%call = tail call i32 @test_non_fmv_caller()
ret i32 %call
}
define i32 @caller5() #9 {
; CHECK-LABEL: define i32 @caller5(
; CHECK-SAME: ) local_unnamed_addr #[[ATTR9:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_non_fmv_caller()
;
entry:
%call = tail call i32 @test_non_fmv_caller()
ret i32 %call
}
declare i32 @test_priority._Msve2-sha3() #10
declare i32 @test_priority._McsscMssbs() #11
declare i32 @test_priority._MflagmMlseMrng() #12
declare i32 @test_priority.default() #0
define weak_odr ptr @test_priority.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @test_priority.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 562949953423360
%2 = icmp eq i64 %1, 562949953423360
br i1 %2, label %common.ret, label %resolver_else
common.ret: ; preds = %resolver_else2, %resolver_else, %resolver_entry
%common.ret.op = phi ptr [ @test_priority._McsscMssbs, %resolver_entry ], [ @test_priority._Msve2-sha3, %resolver_else ], [ %test_priority._MflagmMlseMrng.test_priority.default, %resolver_else2 ]
ret ptr %common.ret.op
resolver_else: ; preds = %resolver_entry
%3 = and i64 %0, 1169304924928
%4 = icmp eq i64 %3, 1169304924928
br i1 %4, label %common.ret, label %resolver_else2
resolver_else2: ; preds = %resolver_else
%5 = and i64 %0, 131
%6 = icmp eq i64 %5, 131
%test_priority._MflagmMlseMrng.test_priority.default = select i1 %6, ptr @test_priority._MflagmMlseMrng, ptr @test_priority.default
br label %common.ret
}
define i32 @caller6._McsscMflagmMlseMrngMssbsMsve2-sha3() #13 {
; CHECK-LABEL: define i32 @caller6._McsscMflagmMlseMrngMssbsMsve2-sha3(
; CHECK-SAME: ) #[[ATTR13:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_priority._McsscMssbs()
;
entry:
%call = tail call i32 @test_priority()
ret i32 %call
}
define i32 @caller6.default() #0 {
; CHECK-LABEL: define i32 @caller6.default(
; CHECK-SAME: ) #[[ATTR0]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_priority()
;
entry:
%call = tail call i32 @test_priority()
ret i32 %call
}
define weak_odr ptr @caller6.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @caller6.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 564119258348419
%2 = icmp eq i64 %1, 564119258348419
%caller6._McsscMflagmMlseMrngMssbsMsve2-sha3.caller6.default = select i1 %2, ptr @caller6._McsscMflagmMlseMrngMssbsMsve2-sha3, ptr @caller6.default
ret ptr %caller6._McsscMflagmMlseMrngMssbsMsve2-sha3.caller6.default
}
declare i32 @test_alternative_names._Mdpb2Mfrintts() #14
declare i32 @test_alternative_names._Mflagm2Mfrintts() #15
declare i32 @test_alternative_names._Mrcpc2() #16
declare i32 @test_alternative_names.default() #0
define weak_odr ptr @test_alternative_names.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @test_alternative_names.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 17563904
%2 = icmp eq i64 %1, 17563904
br i1 %2, label %common.ret, label %resolver_else
common.ret: ; preds = %resolver_else2, %resolver_else, %resolver_entry
%common.ret.op = phi ptr [ @test_alternative_names._Mdpb2Mfrintts, %resolver_entry ], [ @test_alternative_names._Mflagm2Mfrintts, %resolver_else ], [ %test_alternative_names._Mrcpc2.test_alternative_names.default, %resolver_else2 ]
ret ptr %common.ret.op
resolver_else: ; preds = %resolver_entry
%3 = and i64 %0, 16777478
%4 = icmp eq i64 %3, 16777478
br i1 %4, label %common.ret, label %resolver_else2
resolver_else2: ; preds = %resolver_else
%5 = and i64 %0, 12582912
%6 = icmp eq i64 %5, 12582912
%test_alternative_names._Mrcpc2.test_alternative_names.default = select i1 %6, ptr @test_alternative_names._Mrcpc2, ptr @test_alternative_names.default
br label %common.ret
}
define i32 @caller7._Mdpb2Mfrintts() #14 {
; CHECK-LABEL: define i32 @caller7._Mdpb2Mfrintts(
; CHECK-SAME: ) #[[ATTR14:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_alternative_names._Mdpb2Mfrintts()
;
entry:
%call = tail call i32 @test_alternative_names()
ret i32 %call
}
define i32 @caller7._Mfrintts() #17 {
; CHECK-LABEL: define i32 @caller7._Mfrintts(
; CHECK-SAME: ) #[[ATTR17:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_alternative_names()
;
entry:
%call = tail call i32 @test_alternative_names()
ret i32 %call
}
define i32 @caller7._Mrcpc2() #16 {
; CHECK-LABEL: define i32 @caller7._Mrcpc2(
; CHECK-SAME: ) #[[ATTR16:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_alternative_names._Mrcpc2()
;
entry:
%call = tail call i32 @test_alternative_names()
ret i32 %call
}
define i32 @caller7.default() #0 {
; CHECK-LABEL: define i32 @caller7.default(
; CHECK-SAME: ) #[[ATTR0]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_alternative_names.default()
;
entry:
%call = tail call i32 @test_alternative_names()
ret i32 %call
}
define weak_odr ptr @caller7.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @caller7.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 17563904
%2 = icmp eq i64 %1, 17563904
br i1 %2, label %common.ret, label %resolver_else
common.ret: ; preds = %resolver_else2, %resolver_else, %resolver_entry
%common.ret.op = phi ptr [ @caller7._Mdpb2Mfrintts, %resolver_entry ], [ @caller7._Mfrintts, %resolver_else ], [ %caller7._Mrcpc2.caller7.default, %resolver_else2 ]
ret ptr %common.ret.op
resolver_else: ; preds = %resolver_entry
%3 = and i64 %0, 16777472
%4 = icmp eq i64 %3, 16777472
br i1 %4, label %common.ret, label %resolver_else2
resolver_else2: ; preds = %resolver_else
%5 = and i64 %0, 12582912
%6 = icmp eq i64 %5, 12582912
%caller7._Mrcpc2.caller7.default = select i1 %6, ptr @caller7._Mrcpc2, ptr @caller7.default
br label %common.ret
}
declare i32 @test_unrelated_callers._Mmops() #3
declare i32 @test_unrelated_callers._Msve2() #2
declare i32 @test_unrelated_callers._Msve() #1
declare i32 @test_unrelated_callers.default() #0
define weak_odr ptr @test_unrelated_callers.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @test_unrelated_callers.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 576460752303423488
%.not = icmp eq i64 %1, 0
br i1 %.not, label %resolver_else, label %common.ret
common.ret: ; preds = %resolver_else2, %resolver_else, %resolver_entry
%common.ret.op = phi ptr [ @test_unrelated_callers._Mmops, %resolver_entry ], [ @test_unrelated_callers._Msve2, %resolver_else ], [ %test_unrelated_callers._Msve.test_unrelated_callers.default, %resolver_else2 ]
ret ptr %common.ret.op
resolver_else: ; preds = %resolver_entry
%2 = and i64 %0, 69793284352
%3 = icmp eq i64 %2, 69793284352
br i1 %3, label %common.ret, label %resolver_else2
resolver_else2: ; preds = %resolver_else
%4 = and i64 %0, 1073807616
%5 = icmp eq i64 %4, 1073807616
%test_unrelated_callers._Msve.test_unrelated_callers.default = select i1 %5, ptr @test_unrelated_callers._Msve, ptr @test_unrelated_callers.default
br label %common.ret
}
define i32 @caller8._MmopsMsve2() #4 {
; CHECK-LABEL: define i32 @caller8._MmopsMsve2(
; CHECK-SAME: ) #[[ATTR4]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_unrelated_callers._Mmops()
;
entry:
%call = tail call i32 @test_unrelated_callers()
ret i32 %call
}
define dso_local i32 @caller8._Msve2() #2 {
; CHECK-LABEL: define dso_local i32 @caller8._Msve2(
; CHECK-SAME: ) #[[ATTR2]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_unrelated_callers._Msve2()
;
entry:
%call = tail call i32 @test_unrelated_callers()
ret i32 %call
}
define i32 @caller8.default() #0 {
; CHECK-LABEL: define i32 @caller8.default(
; CHECK-SAME: ) #[[ATTR0]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_unrelated_callers()
;
entry:
%call = tail call i32 @test_unrelated_callers()
ret i32 %call
}
define weak_odr ptr @caller8.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @caller8.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 576460822096707840
%2 = icmp eq i64 %1, 576460822096707840
%3 = and i64 %0, 69793284352
%4 = icmp eq i64 %3, 69793284352
%caller8._Msve2.caller8.default = select i1 %4, ptr @caller8._Msve2, ptr @caller8.default
%common.ret.op = select i1 %2, ptr @caller8._MmopsMsve2, ptr %caller8._Msve2.caller8.default
ret ptr %common.ret.op
}
define i32 @caller9._Mmops() #3 {
; CHECK-LABEL: define i32 @caller9._Mmops(
; CHECK-SAME: ) #[[ATTR3]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_unrelated_callers._Mmops()
;
entry:
%call = tail call i32 @test_unrelated_callers()
ret i32 %call
}
define i32 @caller9._Msve() #1 {
; CHECK-LABEL: define i32 @caller9._Msve(
; CHECK-SAME: ) #[[ATTR1]] {
entry:
ret i32 1
}
define i32 @caller9.default() #0 {
; CHECK-LABEL: define i32 @caller9.default(
; CHECK-SAME: ) #[[ATTR0]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_unrelated_callers.default()
;
entry:
%call = tail call i32 @test_unrelated_callers()
ret i32 %call
}
define weak_odr ptr @caller9.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @caller9.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 576460752303423488
%.not = icmp eq i64 %1, 0
%2 = and i64 %0, 1073807616
%3 = icmp eq i64 %2, 1073807616
%caller9._Msve.caller9.default = select i1 %3, ptr @caller9._Msve, ptr @caller9.default
%common.ret.op = select i1 %.not, ptr %caller9._Msve.caller9.default, ptr @caller9._Mmops
ret ptr %common.ret.op
}
define i32 @caller10() #18 {
; CHECK-LABEL: define i32 @caller10(
; CHECK-SAME: ) local_unnamed_addr #[[ATTR18:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_unrelated_callers._Mmops()
;
entry:
%call = tail call i32 @test_unrelated_callers()
ret i32 %call
}
declare i32 @test_known_bits._Mmops() #3
declare i32 @test_known_bits._Maes() #6
declare i32 @test_known_bits.default() #0
define weak_odr ptr @test_known_bits.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @test_known_bits.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 576460752303423488
%.not = icmp eq i64 %1, 0
%2 = and i64 %0, 33536
%3 = icmp eq i64 %2, 33536
%test_known_bits._Maes.test_known_bits.default = select i1 %3, ptr @test_known_bits._Maes, ptr @test_known_bits.default
%common.ret.op = select i1 %.not, ptr %test_known_bits._Maes.test_known_bits.default, ptr @test_known_bits._Mmops
ret ptr %common.ret.op
}
define i32 @caller11._MmopsMsve2() #4 {
; CHECK-LABEL: define i32 @caller11._MmopsMsve2(
; CHECK-SAME: ) #[[ATTR4]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_known_bits._Mmops()
;
entry:
%call = tail call i32 @test_known_bits()
ret i32 %call
}
define i32 @caller11._Msme() #5 {
; CHECK-LABEL: define i32 @caller11._Msme(
; CHECK-SAME: ) #[[ATTR5:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_known_bits()
;
entry:
%call = tail call i32 @test_known_bits()
ret i32 %call
}
define noundef i32 @caller11._MaesMsve2() #19 {
; CHECK-LABEL: define noundef i32 @caller11._MaesMsve2(
; CHECK-SAME: ) #[[ATTR19:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_known_bits._Maes()
;
entry:
%call = tail call i32 @test_known_bits()
ret i32 %call
}
define i32 @caller11.default() #0 {
; CHECK-LABEL: define i32 @caller11.default(
; CHECK-SAME: ) #[[ATTR0]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_known_bits()
;
entry:
%call = tail call i32 @test_known_bits()
ret i32 %call
}
define weak_odr ptr @caller11.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @caller11.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 576460822096707840
%2 = icmp eq i64 %1, 576460822096707840
br i1 %2, label %common.ret, label %resolver_else
common.ret: ; preds = %resolver_else2, %resolver_else, %resolver_entry
%common.ret.op = phi ptr [ @caller11._MmopsMsve2, %resolver_entry ], [ @caller11._Msme, %resolver_else ], [ %caller11._MaesMsve2.caller11.default, %resolver_else2 ]
ret ptr %common.ret.op
resolver_else: ; preds = %resolver_entry
%3 = and i64 %0, 4398180795136
%4 = icmp eq i64 %3, 4398180795136
br i1 %4, label %common.ret, label %resolver_else2
resolver_else2: ; preds = %resolver_else
%5 = and i64 %0, 69793317632
%6 = icmp eq i64 %5, 69793317632
%caller11._MaesMsve2.caller11.default = select i1 %6, ptr @caller11._MaesMsve2, ptr @caller11.default
br label %common.ret
}
declare i32 @test_priority_override._Maes() #20
declare i32 @test_priority_override._Msme() #21
declare i32 @test_priority_override.default() #0
define weak_odr ptr @test_priority_override.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @test_priority_override.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 33536
%2 = icmp eq i64 %1, 33536
%3 = and i64 %0, 4398180795136
%4 = icmp eq i64 %3, 4398180795136
%test_priority_override._Msme.test_priority_override.default = select i1 %4, ptr @test_priority_override._Msme, ptr @test_priority_override.default
%common.ret.op = select i1 %2, ptr @test_priority_override._Maes, ptr %test_priority_override._Msme.test_priority_override.default
ret ptr %common.ret.op
}
define i32 @caller12._Maes() #22 {
; CHECK-LABEL: define i32 @caller12._Maes(
; CHECK-SAME: ) #[[ATTR6:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_priority_override._Maes()
;
entry:
%call = tail call i32 @test_priority_override()
ret i32 %call
}
define i32 @caller12._Mbf16() #23 {
; CHECK-LABEL: define i32 @caller12._Mbf16(
; CHECK-SAME: ) #[[ATTR19:[0-9]+]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_priority_override()
;
entry:
%call = tail call i32 @test_priority_override()
ret i32 %call
}
define noundef i32 @caller12.default() #0 {
; CHECK-LABEL: define noundef i32 @caller12.default(
; CHECK-SAME: ) #[[ATTR0]] {
; CHECK: [[CALL:%.*]] = tail call i32 @test_priority_override.default()
;
entry:
%call = tail call i32 @test_priority_override()
ret i32 %call
}
define weak_odr ptr @caller12.resolver() comdat {
; CHECK-LABEL: define weak_odr ptr @caller12.resolver() comdat {
resolver_entry:
tail call void @__init_cpu_features_resolver()
%0 = load i64, ptr @__aarch64_cpu_features, align 8
%1 = and i64 %0, 33536
%2 = icmp eq i64 %1, 33536
%3 = and i64 %0, 134218496
%4 = icmp eq i64 %3, 134218496
%caller12._Mbf16.caller12.default = select i1 %4, ptr @caller12._Mbf16, ptr @caller12.default
%common.ret.op = select i1 %2, ptr @caller12._Maes, ptr %caller12._Mbf16.caller12.default
ret ptr %common.ret.op
}
attributes #0 = { "fmv-features" }
attributes #1 = { "fmv-features"="sve" }
attributes #2 = { "fmv-features"="sve2" }
attributes #3 = { "fmv-features"="mops" }
attributes #4 = { "fmv-features"="mops,sve2" }
attributes #5 = { "fmv-features"="sme" }
attributes #6 = { "fmv-features"="aes" }
attributes #7 = { "fmv-features"="sm4" }
attributes #8 = { "target-features"="+aes,+fp-armv8,+neon,+outline-atomics,+v8a" }
attributes #9 = { "target-features"="+fp-armv8,+neon,+outline-atomics,+v8a,+sm4" }
attributes #10 = { "fmv-features"="sve2-sha3" }
attributes #11 = { "fmv-features"="cssc,ssbs" }
attributes #12 = { "fmv-features"="flagm,lse,rng" }
attributes #13 = { "fmv-features"="cssc,flagm,lse,rng,ssbs,sve2-sha3" }
attributes #14 = { "fmv-features"="dpb2,frintts" }
attributes #15 = { "fmv-features"="flagm2,frintts" }
attributes #16 = { "fmv-features"="rcpc2" }
attributes #17 = { "fmv-features"="frintts" }
attributes #18 = { "target-features"="+fp-armv8,+mops,+neon,+outline-atomics,+sve,+v8a" }
attributes #19 = { "fmv-features"="aes,sve2" }
attributes #20 = { "fmv-features"="P1,P4,P5,aes" } ; priority=50
attributes #21 = { "fmv-features"="P1,P2,P3,P4,sme" } ; priority=30
attributes #22 = { "fmv-features"="P3,P6,P7,aes" } ; priority=200
attributes #23 = { "fmv-features"="P2,P5,P6,bf16" } ; priority=100