resolver: Add dependency-graph analysis

Performs a module-scope (global) declaration dependency analysis, so
that out-of-order global declarations can be re-ordered into dependency
order for consumption by the resolver.

The WGSL working group are currently debating whether out-of-order
declarations should be included in WebGPU V1, so this implementation
currently errors if module-scope declarations are declared out-of-order,
and the resolver does not currently use this sorted global list.

The analysis does however provide significantly better error diagnostics
when cyclic dependencies are formed, and when globals are declared
out-of-order.

The DependencyGraph also correctly now detects symbol collisions between
functions and types (tint:1308).

With this change, validation is duplicated between the DependencyGraph
and the Resolver. The now-unreachable validation will be removed from
the Resolver with a followup change.

Fixed: tint:1308
Bug: tint:1266
Change-Id: I809c23a069a86cf429f5ec8ef3ad9a98246766ab
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/69381
Kokoro: Kokoro <noreply+kokoro@google.com>
Commit-Queue: Ben Clayton <bclayton@chromium.org>
Reviewed-by: David Neto <dneto@google.com>
This commit is contained in:
Ben Clayton
2021-11-22 11:44:57 +00:00
committed by Tint LUCI CQ
parent c87dc10ce3
commit 4183051b54
20 changed files with 2007 additions and 253 deletions

View File

@@ -49,5 +49,23 @@ TEST_F(ScopeStackTest, Get_MissingSymbol) {
EXPECT_EQ(s.Get(sym), 0u);
}
TEST_F(ScopeStackTest, Set) {
ScopeStack<uint32_t> s;
Symbol a(1, ID());
Symbol b(2, ID());
EXPECT_EQ(s.Set(a, 5u), 0u);
EXPECT_EQ(s.Get(a), 5u);
EXPECT_EQ(s.Set(b, 10u), 0u);
EXPECT_EQ(s.Get(b), 10u);
EXPECT_EQ(s.Set(a, 20u), 5u);
EXPECT_EQ(s.Get(a), 20u);
EXPECT_EQ(s.Set(b, 25u), 10u);
EXPECT_EQ(s.Get(b), 25u);
}
} // namespace
} // namespace tint