mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
This allows the usage of the whole remark infrastructure developed in LLVM, which includes a new binary format, metadata in object files, etc. This gets rid of the YAMLTraits-based remark serialization and does the plumbing for hooking to LLVM's main remark streamer. For more about the idea behind LLVM's main remark streamer, see the docs/Remarks.rst changes in https://reviews.llvm.org/D73676. The flags are now: * -save-optimization-record: enable remarks, defaults to YAML * -save-optimization-record=<format>: enable remarks, use <format> for serialization * -save-optimization-record-passes <regex>: only serialize passes that match <regex>. The YAMLTraits in swift had a different `flow` setting for the debug location, resulting in some test changes.
52 lines
2.4 KiB
Swift
52 lines
2.4 KiB
Swift
// RUN: %empty-directory(%t)
|
|
// RUN: %target-swiftc_driver -O -wmo -save-optimization-record %s -module-name optrecordmod -o %t/opt-record 2>&1 | %FileCheck -allow-empty %s
|
|
// RUN: %FileCheck -check-prefix=YAML %s < %t/optrecordmod.opt.yaml
|
|
// RUN: %target-swiftc_driver -O -wmo -save-optimization-record-path %t/specified.opt.yaml %s -module-name optrecordmod -o %t/opt-record 2>&1 | %FileCheck -allow-empty %s
|
|
// RUN: %FileCheck -check-prefix=YAML %s < %t/specified.opt.yaml
|
|
// RUN: %target-swiftc_driver -O -wmo -save-optimization-record -save-optimization-record-passes sil-inliner %s -module-name optrecordmod -o %t/opt-record 2>&1 | %FileCheck -allow-empty %s
|
|
// RUN: %FileCheck -check-prefix=YAML %s < %t/optrecordmod.opt.yaml
|
|
// RUN: %target-swiftc_driver -O -wmo -save-optimization-record -save-optimization-record-passes unknown -save-optimization-record-path %t/optrecordmod-filtered.opt.yaml %s -module-name optrecordmod -o %t/opt-record 2>&1 | %FileCheck -allow-empty %s
|
|
// RUN: %FileCheck -allow-empty -check-prefix=YAML-FILTERED %s < %t/optrecordmod-filtered.opt.yaml
|
|
|
|
// CHECK-NOT: remark
|
|
|
|
var a: Int = 1
|
|
|
|
#sourceLocation(file: "custom.swift", line: 2000)
|
|
func foo() {
|
|
a = 2
|
|
}
|
|
#sourceLocation() // reset
|
|
|
|
public func bar() {
|
|
foo()
|
|
// YAML: --- !Passed
|
|
// YAML-NEXT: Pass: sil-inliner
|
|
// YAML-NEXT: Name: sil.Inlined
|
|
// YAML-NEXT: DebugLoc:
|
|
// YAML: File: {{.*}}opt-record.swift
|
|
// YAML: Line: [[@LINE-6]]
|
|
// YAML: Column: 3
|
|
// YAML-NEXT: Function: 'bar()'
|
|
// YAML-NEXT: Args:
|
|
// YAML-NEXT: - Callee: '"optrecordmod.foo()"'
|
|
// YAML-NEXT: DebugLoc:
|
|
// YAML: File: custom.swift
|
|
// YAML: Line: 2000
|
|
// YAML: Column: 6
|
|
// YAML-NEXT: - String: ' inlined into '
|
|
// YAML-NEXT: - Caller: '"optrecordmod.bar()"'
|
|
// YAML-NEXT: DebugLoc:
|
|
// YAML: File: {{.*}}opt-record.swift
|
|
// YAML: Line: [[@LINE-20]]
|
|
// YAML: Column: 13
|
|
// YAML-NEXT: - String: ' (cost = '
|
|
// YAML-NEXT: - Cost: '{{.*}}'
|
|
// YAML-NEXT: - String: ', benefit = '
|
|
// YAML-NEXT: - Benefit: '{{.*}}'
|
|
// YAML-NEXT: - String: ')'
|
|
// YAML-NEXT: ...
|
|
}
|
|
|
|
// YAML-FILTERED-NOT: sil-inliner
|