Files
swift-mirror/test/IRGen/ir_profile_generate.sil
Chirag Ramani 5179bc9609 Add IRPGO and CSIRPGO options to Swift (#84335)
This PR introduces three new instrumentation flags and plumbs them
through to IRGen:

1. `-ir-profile-generate` - enable IR-level instrumentation.
2. `-cs-profile-generate` - enable context-sensitive IR-level
instrumentation.
3. `-ir-profile-use` - IR-level PGO input profdata file to enable
profile-guided optimization (both IRPGO and CSIRPGO)

**Context:**
https://forums.swift.org/t/ir-level-pgo-instrumentation-in-swift/82123

**Swift-driver PR:** https://github.com/swiftlang/swift-driver/pull/1992

**Tests and validation:**
This PR includes ir level verification tests, also checks few edge-cases
when `-ir-profile-use` supplied profile is either missing or is an
invalid IR profile.

However, for argument validation, linking, and generating IR profiles
that can later be consumed by -cs-profile-generate, I’ll need
corresponding swift-driver changes. Those changes are being tracked in
https://github.com/swiftlang/swift-driver/pull/1992
2025-10-09 17:41:47 -07:00

72 lines
2.0 KiB
Plaintext

// Without directory
// RUN: %target-swift-frontend -ir-profile-generate -emit-ir %s | %FileCheck %s
// With directory
// RUN: %empty-directory(%t.dir)
// RUN: %target-swift-frontend -ir-profile-generate=%t.dir -emit-ir %s | %FileCheck %s
// Ensure Passes: PGOInstrumentationGenPass and InstrProfilingLoweringPass are invoked.
// RUN: %target-swift-frontend -ir-profile-generate -emit-ir %s -Xllvm -debug-pass=Structure -Xllvm --time-passes -o /dev/null 2>&1 | %FileCheck -check-prefix=CHECK-PASSES %s
// CHECK-PASSES-DAG: PGOInstrumentationGen
// CHECK-PASSES-DAG: InstrProfilingLoweringPass
sil_stage canonical
import Builtin
import Swift
import SwiftShims
sil @b : $@convention(thin) () -> ()
sil @c : $@convention(thin) () -> ()
// counter array (2 counters for the then/else)
// CHECK: @__profc_a = {{.*}} global {{.*}}
// data record pointing at the counter array and the function
// CHECK: @__profd_a = {{.*}} global {{.*}} ptr @a.local
// CHECK: br i1 {{.*}}, label %[[THEN:[0-9]+]], label %[[ELSE:[0-9]+]]
// THEN: increment counter[0] and call b()
// CHECK: [[THEN]]:
// CHECK: {{.*}}load{{.*}}@__profc_a
// CHECK: {{.*}}store{{.*}}@__profc_a
// CHECK: {{.*}}call{{.*}}@b(
// CHECK: br label %[[MERGE:[0-9]+]]
// ELSE: increment counter[1] and call c()
// CHECK: [[ELSE]]:
/// CHECK: {{.*}} = {{.*}}@__profc_a{{.*}}
// CHECK: store{{.*}}@__profc_a
// CHECK: {{.*}}call{{.*}}@c(
// CHECK: br label %[[MERGE]]
// CHECK: [[MERGE]]:
// CHECK: ret void
// CHECK: declare {{.*}}@c(
// CHECK: declare {{.*}}@b(
// CHECK: declare {{.*}}@llvm.instrprof.increment
sil @a : $@convention(thin) (Bool) -> () {
bb0(%0 : $Bool):
%2 = struct_extract %0, #Bool._value
cond_br %2, bb1, bb2
bb1:
// function_ref b()
%4 = function_ref @b : $@convention(thin) () -> ()
%5 = apply %4() : $@convention(thin) () -> ()
br bb3
bb2:
// function_ref c()
%7 = function_ref @c: $@convention(thin) () -> ()
%8 = apply %7() : $@convention(thin) () -> ()
br bb3
bb3:
%10 = tuple ()
return %10
}