diff options
| author | Dietrich Geisler <dag368@cornell.edu> | 2020-08-12 13:39:08 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-08-12 10:39:08 -0700 |
| commit | e1ea7ed2f9b8cfcf19258a05d270de4db03fec22 (patch) | |
| tree | da87da6f4dd8adb39a44b0bfae342ed1dba04b58 /source/slang/slang-parser.cpp | |
| parent | 12b0fc64103c63c33daaedf8a8c2ee05de35dcc5 (diff) | |
GPU Foreach Parsing and Checking (#1482)
This PR introduces parsing and semantic checking for a GPU foreach loop
for heterogeneouis programming. A GPU foreach loop takes the form:
```
__GPU_FOREACH(renderer, gridDims, LAMBDA(uint3 dispatchThreadID) {
kernelCall(args, ...); });
```
And will allow the host code to call into a kernel with the correct
renderer and grid dimensions. This commit also introduces a hack to
unify types in the heterogeneous hello world file, which will hopefully
be amended in the future.
Co-authored-by: Tim Foley <tfoleyNV@users.noreply.github.com>
Diffstat (limited to 'source/slang/slang-parser.cpp')
| -rw-r--r-- | source/slang/slang-parser.cpp | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/source/slang/slang-parser.cpp b/source/slang/slang-parser.cpp index 460f781fe..179587550 100644 --- a/source/slang/slang-parser.cpp +++ b/source/slang/slang-parser.cpp @@ -3380,6 +3380,56 @@ namespace Slang return stmt; } + GpuForeachStmt* ParseGpuForeachStmt(Parser* parser) + { + // Hard-coding parsing of the following: + // __GPU_FOREACH(renderer, gridDims, LAMBDA(uint3 dispatchThreadID) { + // kernelCall(args, ...); }); + + // Setup the scope so that dispatchThreadID is in scope for kernelCall + ScopeDecl* scopeDecl = parser->astBuilder->create<ScopeDecl>(); + GpuForeachStmt* stmt = parser->astBuilder->create<GpuForeachStmt>(); + stmt->scopeDecl = scopeDecl; + + parser->FillPosition(stmt); + parser->ReadToken("__GPU_FOREACH"); + parser->ReadToken(TokenType::LParent); + stmt->renderer = parser->ParseArgExpr(); + parser->ReadToken(TokenType::Comma); + stmt->gridDims = parser->ParseArgExpr(); + + parser->ReadToken(TokenType::Comma); + parser->ReadToken("LAMBDA"); + parser->ReadToken(TokenType::LParent); + + auto idType = parser->ParseTypeExp(); + NameLoc varNameAndLoc = expectIdentifier(parser); + VarDecl* varDecl = parser->astBuilder->create<VarDecl>(); + varDecl->nameAndLoc = varNameAndLoc; + varDecl->loc = varNameAndLoc.loc; + varDecl->type = idType; + stmt->dispatchThreadID = varDecl; + + parser->ReadToken(TokenType::RParent); + parser->ReadToken(TokenType::LBrace); + + parser->pushScopeAndSetParent(scopeDecl); + AddMember(parser->currentScope, varDecl); + + stmt->kernelCall = parser->ParseExpression(); + + parser->PopScope(); + + parser->ReadToken(TokenType::Semicolon); + parser->ReadToken(TokenType::RBrace); + + parser->ReadToken(TokenType::RParent); + + parser->ReadToken(TokenType::Semicolon); + + return stmt; + } + static bool _isType(Decl* decl) { return decl && (as<AggTypeDecl>(decl) || as<SimpleTypeDecl>(decl)); @@ -3552,6 +3602,8 @@ namespace Slang statement = ParseCaseStmt(this); else if (LookAheadToken("default")) statement = ParseDefaultStmt(this); + else if (LookAheadToken("__GPU_FOREACH")) + statement = ParseGpuForeachStmt(this); else if (LookAheadToken(TokenType::Dollar)) { statement = parseCompileTimeStmt(this); |
