51 lines
1.6 KiB
LLVM
51 lines
1.6 KiB
LLVM
; RUN: opt -S --passes="ipsccp<func-spec>" -funcspec-max-clones=1 < %s | FileCheck %s
|
|
define internal i32 @f(i32 noundef %x, ptr nocapture noundef readonly %p, ptr nocapture noundef readonly %q) noinline {
|
|
entry:
|
|
%call = tail call i32 %p(i32 noundef %x)
|
|
%call1 = tail call i32 %q(i32 noundef %x)
|
|
%add = add nsw i32 %call1, %call
|
|
ret i32 %add
|
|
}
|
|
|
|
define internal i32 @g(i32 noundef %x, ptr nocapture noundef readonly %p, ptr nocapture noundef readonly %q) noinline {
|
|
entry:
|
|
%call = tail call i32 %p(i32 noundef %x)
|
|
%call1 = tail call i32 %q(i32 noundef %x)
|
|
%sub = sub nsw i32 %call, %call1
|
|
ret i32 %sub
|
|
}
|
|
|
|
define i32 @h0(i32 noundef %x) {
|
|
entry:
|
|
%call = tail call i32 @f(i32 noundef %x, ptr noundef nonnull @pp, ptr noundef nonnull @qq)
|
|
ret i32 %call
|
|
}
|
|
|
|
define i32 @h1(i32 noundef %x) {
|
|
entry:
|
|
%call = tail call i32 @f(i32 noundef %x, ptr noundef nonnull @qq, ptr noundef nonnull @pp)
|
|
ret i32 %call
|
|
}
|
|
|
|
define i32 @h2(i32 noundef %x, ptr nocapture noundef readonly %p) {
|
|
entry:
|
|
%call = tail call i32 @g(i32 noundef %x, ptr noundef %p, ptr noundef nonnull @pp)
|
|
ret i32 %call
|
|
}
|
|
|
|
define i32 @h3(i32 noundef %x, ptr nocapture noundef readonly %p) {
|
|
entry:
|
|
%call = tail call i32 @g(i32 noundef %x, ptr noundef %p, ptr noundef nonnull @qq)
|
|
ret i32 %call
|
|
}
|
|
|
|
declare i32 @pp(i32 noundef)
|
|
declare i32 @qq(i32 noundef)
|
|
|
|
|
|
; Check that the global ranking causes two specialisations of
|
|
; `f` to be chosen, whereas the old algorithm would choose
|
|
; one specialsation of `f` and one of `g`.
|
|
|
|
; CHECK-DAG: define internal i32 @f.specialized.1
|
|
; CHECK-DAG: define internal i32 @f.specialized.2
|