mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Type annotations for instruction operands are omitted, e.g. ``` %3 = struct $S(%1, %2) ``` Operand types are redundant anyway and were only used for sanity checking in the SIL parser. But: operand types _are_ printed if the definition of the operand value was not printed yet. This happens: * if the block with the definition appears after the block where the operand's instruction is located * if a block or instruction is printed in isolation, e.g. in a debugger The old behavior can be restored with `-Xllvm -sil-print-types`. This option is added to many existing test files which check for operand types in their check-lines.
104 lines
4.6 KiB
Swift
104 lines
4.6 KiB
Swift
|
|
// RUN: %empty-directory(%t)
|
|
// RUN: %target-build-swift %s -profile-generate -Xfrontend -disable-incremental-llvm-codegen -module-name pgo_switchenum -o %t/main
|
|
|
|
// RUN: %target-codesign %t/main
|
|
// RUN: env %env-LLVM_PROFILE_FILE=%t/default.profraw %target-run %t/main
|
|
|
|
// RUN: %llvm-profdata merge %t/default.profraw -o %t/default.profdata
|
|
// need to move counts attached to expr for this
|
|
// RUN: %target-swift-frontend %s -Xllvm -sil-full-demangle -profile-use=%t/default.profdata -emit-sorted-sil -Xllvm -sil-print-types -emit-sil -module-name pgo_switchenum -o - | %FileCheck %s --check-prefix=SIL
|
|
// need to lower switch_enum(addr) into IR for this
|
|
// %target-swift-frontend %s -Xllvm -sil-full-demangle -profile-use=%t/default.profdata -emit-ir -module-name pgo_switchenum -o - | %FileCheck %s --check-prefix=IR
|
|
// need to check Opt support
|
|
// %target-swift-frontend %s -Xllvm -sil-full-demangle -profile-use=%t/default.profdata -O -emit-sorted-sil -emit-sil -module-name pgo_switchenum -o - | %FileCheck %s --check-prefix=SIL-OPT
|
|
// need to lower switch_enum(addr) into IR for this
|
|
// %target-swift-frontend %s -Xllvm -sil-full-demangle -profile-use=%t/default.profdata -O -emit-ir -module-name pgo_switchenum -o - | %FileCheck %s --check-prefix=IR-OPT
|
|
|
|
// REQUIRES: profile_runtime
|
|
// REQUIRES: executable_test
|
|
|
|
public enum MaybePair {
|
|
case Neither
|
|
case Left(Int32)
|
|
case Right(String)
|
|
case Both(Int32, String)
|
|
}
|
|
|
|
// SIL-LABEL: // pgo_switchenum.guess1
|
|
// SIL-LABEL: sil @$s14pgo_switchenum6guess11xs5Int32VAA9MaybePairO_tF : $@convention(thin) (@guaranteed MaybePair) -> Int32 !function_entry_count(5011) {
|
|
// IR-LABEL: define swiftcc i32 @$s9pgo_switchenum6guess1s5Int32VAD1x_tF
|
|
// IR-OPT-LABEL: define swiftcc i32 @$s9pgo_switchenum6guess1s5Int32VAD1x_tF
|
|
|
|
public func guess1(x: MaybePair) -> Int32 {
|
|
// SIL: switch_enum {{.*}} : $MaybePair, case #MaybePair.Neither!enumelt: {{.*}} !case_count(2), case #MaybePair.Left!enumelt: {{.*}} !case_count(5001), case #MaybePair.Right!enumelt: {{.*}} !case_count(3), case #MaybePair.Both!enumelt: {{.*}} !case_count(5)
|
|
// SIL-OPT: switch_enum {{.*}} : $MaybePair, case #MaybePair.Neither!enumelt: {{.*}} !case_count(2), case #MaybePair.Left!enumelt: {{.*}} !case_count(5001), case #MaybePair.Right!enumelt: {{.*}} !case_count(3), case #MaybePair.Both!enumelt: {{.*}} !case_count(5)
|
|
switch x {
|
|
case .Neither:
|
|
return 1
|
|
case let .Left(val):
|
|
return val*2
|
|
case let .Right(val):
|
|
return Int32(val.count)
|
|
case let .Both(valNum, valStr):
|
|
return valNum + Int32(valStr.count)
|
|
}
|
|
}
|
|
|
|
// SIL-LABEL: // pgo_switchenum.guess2
|
|
// SIL-LABEL: sil @$s14pgo_switchenum6guess21xs5Int32VAA9MaybePairO_tF : $@convention(thin) (@guaranteed MaybePair) -> Int32 !function_entry_count(5011) {
|
|
public func guess2(x: MaybePair) -> Int32 {
|
|
// SIL: switch_enum {{.*}} : $MaybePair, case #MaybePair.Neither!enumelt: {{.*}} !case_count(2), case #MaybePair.Left!enumelt: {{.*}} !case_count(5001), default {{.*}} !default_count(8)
|
|
// SIL-OPT: switch_enum {{.*}} : $MaybePair, case #MaybePair.Neither!enumelt: {{.*}} !case_count(2), case #MaybePair.Left!enumelt: {{.*}} !case_count(5001), default {{.*}} !default_count(8)
|
|
switch x {
|
|
case .Neither:
|
|
return 1
|
|
case let .Left(val):
|
|
return val*2
|
|
default:
|
|
return 42;
|
|
}
|
|
}
|
|
|
|
|
|
func main() {
|
|
var guesses : Int32 = 0;
|
|
|
|
guesses += guess1(x: MaybePair.Neither)
|
|
guesses += guess1(x: MaybePair.Neither)
|
|
guesses += guess1(x: MaybePair.Left(42))
|
|
guesses += guess1(x: MaybePair.Right("The Answer"))
|
|
guesses += guess1(x: MaybePair.Right("The Answer"))
|
|
guesses += guess1(x: MaybePair.Right("The Answer"))
|
|
guesses += guess1(x: MaybePair.Both(42, "The Answer"))
|
|
guesses += guess1(x: MaybePair.Both(42, "The Answer"))
|
|
guesses += guess1(x: MaybePair.Both(42, "The Answer"))
|
|
guesses += guess1(x: MaybePair.Both(42, "The Answer"))
|
|
guesses += guess1(x: MaybePair.Both(42, "The Answer"))
|
|
|
|
for _ in 1...5000 {
|
|
guesses += guess1(x: MaybePair.Left(10))
|
|
}
|
|
|
|
guesses += guess2(x: MaybePair.Neither)
|
|
guesses += guess2(x: MaybePair.Neither)
|
|
guesses += guess2(x: MaybePair.Left(42))
|
|
guesses += guess2(x: MaybePair.Right("The Answer"))
|
|
guesses += guess2(x: MaybePair.Right("The Answer"))
|
|
guesses += guess2(x: MaybePair.Right("The Answer"))
|
|
guesses += guess2(x: MaybePair.Both(42, "The Answer"))
|
|
guesses += guess2(x: MaybePair.Both(42, "The Answer"))
|
|
guesses += guess2(x: MaybePair.Both(42, "The Answer"))
|
|
guesses += guess2(x: MaybePair.Both(42, "The Answer"))
|
|
guesses += guess2(x: MaybePair.Both(42, "The Answer"))
|
|
|
|
for _ in 1...5000 {
|
|
guesses += guess2(x: MaybePair.Left(10))
|
|
}
|
|
}
|
|
|
|
main()
|
|
|
|
// IR: !{!"branch_weights", i32 5001, i32 3}
|
|
// IR-OPT: !{!"branch_weights", i32 5001, i32 3}
|