mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Compiler: - Add `Forward` and `Reverse` to `DifferentiabilityKind`. - Expand `DifferentiabilityMask` in `ExtInfo` to 3 bits so that it now holds all 4 cases of `DifferentiabilityKind`. - Parse `@differentiable(reverse)` and `@differentiable(_forward)` declaration attributes and type attributes. - Emit a warning for `@differentiable` without `reverse`. - Emit an error for `@differentiable(_forward)`. - Rename `@differentiable(linear)` to `@differentiable(_linear)`. - Make `@differentiable(reverse)` type lowering go through today's `@differentiable` code path. We will specialize it to reverse-mode in a follow-up patch. ABI: - Add `Forward` and `Reverse` to `FunctionMetadataDifferentiabilityKind`. - Extend `TargetFunctionTypeFlags` by 1 bit to store the highest bit of differentiability kind (linear). Note that there is a 2-bit gap in `DifferentiabilityMask` which is reserved for `AsyncMask` and `ConcurrentMask`; `AsyncMask` is ABI-stable so we cannot change that. _Differentiation module: - Replace all occurrences of `@differentiable` with `@differentiable(reverse)`. - Delete `_transpose(of:)`. Resolves rdar://69980056.
15 lines
527 B
Swift
15 lines
527 B
Swift
// RUN: %target-swift-frontend -emit-sil -verify %s
|
|
|
|
// Tests that differentiation features interact correctly with non-differentiation SILOptimizer
|
|
// passes.
|
|
|
|
import _Differentiation
|
|
|
|
// - MARK: DiagnoseInvalidEscapingCaptures
|
|
|
|
func nonEscapingUseOfDifferentiableFunction(_ f: @differentiable(reverse) (Float) -> Float) {}
|
|
func testDiagnoseInvalidEscapingCaptures(_ f: @differentiable(reverse) (Float) -> Float) {
|
|
// Should not be diagnosed as invalid escaping capture.
|
|
nonEscapingUseOfDifferentiableFunction { f($0) }
|
|
}
|