skia2/resources/sksl/runtime
John Stiles f4103618ff Report an error if an out param is never written to.
GLSL ES2 behavior is explicitly undefined if an out-param is never
written to: "If a function does not write to an out parameter, the value
of the actual parameter is undefined when the function returns."

We do see divergence here in practice: SkVM's behavior (the parameter is
left alone) differs from my GPU's behavior (the parameter is zeroed
out).

SkSL will now report an error if an out parameter is never assigned-to.
There is no control flow analysis performed, so we will not report
cases where the out parameter is assigned-to on some paths but not
others. (Technically the return-on-all-paths logic could be adapted
for this, but it would be a fair amount of work.)

Structs are currently exempt from the rule because custom mesh
specifications require an `out` parameter for a Varyings struct, even if
your mesh program doesn't need Varyings.

Bug: skia:12867
Change-Id: Ie828d3ce91c2c67e008ae304fdb163ffa88d744c
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/500440
Auto-Submit: John Stiles <johnstiles@google.com>
Reviewed-by: Brian Osman <brianosman@google.com>
Commit-Queue: Brian Osman <brianosman@google.com>
2022-01-26 21:42:13 +00:00
..
AllowNarrowingConversions.rts Add test for Runtime Effects and narrowing conversions. 2021-08-03 15:58:46 +00:00
ArrayIndexing.rts Add variable slot information to SkVMDebugInfo. 2021-11-15 14:24:08 +00:00
ArrayNarrowingConversions.rts Add tests for array assignment with narrowing conversions. 2021-08-11 12:56:40 +00:00
Blend.rtb Add dest-color support to the Pipeline stage. 2021-06-09 22:09:21 +00:00
Commutative.rts Add a setting to disable SkVM variable traces. 2021-12-01 17:25:59 +00:00
ConstPreservation.rts Remove usage of sqrt() as an optimization barrier in tests. 2021-05-24 17:18:54 +00:00
ConversionConstructors.rts Remove flexible runtime effects entirely 2021-04-29 16:02:27 +00:00
GlobalVariables.rts Fix assertion when debug-tracing a void-return function. 2021-12-10 14:39:05 +00:00
GLSLTypeNames.rts Remove flexible runtime effects entirely 2021-04-29 16:02:27 +00:00
LargeProgram_BlocklessLoops.rts Add program-too-large test using for loops without blocks. 2021-09-15 14:19:00 +00:00
LargeProgram_FlatLoop.rts Enforce an upper bound on Runtime Effect program size. 2021-09-02 14:44:34 +00:00
LargeProgram_Functions.rts Enforce an upper bound on Runtime Effect program size. 2021-09-02 14:44:34 +00:00
LargeProgram_NestedLoops.rts Enforce an upper bound on Runtime Effect program size. 2021-09-02 14:44:34 +00:00
LargeProgram_SplitLoops.rts Enforce an upper bound on Runtime Effect program size. 2021-09-02 14:44:34 +00:00
LargeProgram_StackDepth.rts Reject programs which exceed 50 stack frames during size analysis. 2021-09-03 02:41:34 +00:00
LargeProgram_ZeroIterFor.rts Enforce an upper bound on Runtime Effect program size. 2021-09-02 14:44:34 +00:00
LoopFloat.rts Update LoopFloat/LoopInt tests to reduce hoisting. 2021-11-12 13:45:59 +00:00
LoopInt.rts Update LoopFloat/LoopInt tests to reduce hoisting. 2021-11-12 13:45:59 +00:00
PrecisionQualifiers.rts Add variable slot information to SkVMDebugInfo. 2021-11-15 14:24:08 +00:00
QualifierOrder.rts Report an error if an out param is never written to. 2022-01-26 21:42:13 +00:00
RecursiveComparison_Arrays.rts Adding test files demonstrating type confusion for arrays/structs. 2021-12-03 20:54:36 +00:00
RecursiveComparison_Structs.rts Adding test files demonstrating type confusion for arrays/structs. 2021-12-03 20:54:36 +00:00
RecursiveComparison_Types.rts Adding test files demonstrating type confusion for arrays/structs. 2021-12-03 20:54:36 +00:00
RecursiveComparison_Vectors.rts Adding test files demonstrating type confusion for arrays/structs. 2021-12-03 20:54:36 +00:00
SampleWithExplicitCoord.rts Convert internal SkSL to use .eval() 2021-09-03 15:54:54 +00:00
Switch.rts Reland "Add switch statement support to PipelineStage." 2021-09-21 13:07:50 +00:00
SwitchDefaultOnly.rts Implement switch in SkVM. 2021-09-23 19:58:55 +00:00
SwitchWithFallthrough.rts Implement switch in SkVM. 2021-09-23 19:58:55 +00:00
SwitchWithLoops.rts Implement switch in SkVM. 2021-09-23 19:58:55 +00:00
VectorIndexing.rts Remove flexible runtime effects entirely 2021-04-29 16:02:27 +00:00