Skip to content

Commit

Permalink
Merge pull request #168 from tfoleyNV/resources-in-structs-control
Browse files Browse the repository at this point in the history
Add a flag to control type splitting
  • Loading branch information
Tim Foley authored Aug 17, 2017
2 parents 3dd88c2 + d13bd05 commit 5230ad2
Show file tree
Hide file tree
Showing 5 changed files with 82 additions and 1 deletion.
6 changes: 5 additions & 1 deletion slang.h
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,11 @@ extern "C"
typedef unsigned int SlangCompileFlags;
enum
{
SLANG_COMPILE_FLAG_NO_CHECKING = 1 << 0, /**< Disable semantic checking as much as possible. */
/** Disable semantic checking as much as possible. */
SLANG_COMPILE_FLAG_NO_CHECKING = 1 << 0,

/* Split apart types that contain a mix of resource and non-resource data */
SLANG_COMPILE_FLAG_SPLIT_MIXED_TYPES = 1 << 1,
};

/*!
Expand Down
11 changes: 11 additions & 0 deletions source/slang/lower.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2833,6 +2833,17 @@ struct LoweringVisitor
// due to, e.g., bindless textures.
shouldDesugarTupleTypes = true;
}
else if( shared->compileRequest->compileFlags & SLANG_COMPILE_FLAG_SPLIT_MIXED_TYPES )
{
// If the user is directly asking us to do this transformation,
// then obviously we need to do it.
//
// TODO: The way this is defined here means it will even apply to user
// HLSL code (not just code written in Slang). We may want to
// reconsider that choice, and only split things that originated in Slang.
//
shouldDesugarTupleTypes = true;
}

bool isResultATupleType = false;
bool hasAnyNonTupleFields = false;
Expand Down
4 changes: 4 additions & 0 deletions source/slang/options.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -254,6 +254,10 @@ struct OptionsParser
//else
if (argStr == "-no-checking")
flags |= SLANG_COMPILE_FLAG_NO_CHECKING;
else if(argStr == "-split-mixed-types" )
{
flags |= SLANG_COMPILE_FLAG_SPLIT_MIXED_TYPES;
}
else if (argStr == "-backend" || argStr == "-target")
{
String name = tryReadCommandLineArgument(arg, &argCursor, argEnd);
Expand Down
59 changes: 59 additions & 0 deletions tests/rewriter/type-splitting.hlsl
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
//TEST:COMPARE_HLSL: -split-mixed-types -no-checking -target dxbc-assembly -profile ps_4_0 -entry main

// Confirm that the `-split-mixed-types` flag works.

#ifdef __SLANG__

// HLSL input:
//
// - Uses at least one `import` of Slang code
// - Uses an aggregate type that mixes resource and non-resource types
//

__import type_splitting;

struct Foo
{
Texture2D t;
SamplerState s;
float2 u;
};

cbuffer C
{
Foo foo;
}

float4 main() : SV_Target
{
return foo.t.Sample(foo.s, foo.u);
}

#else

// Equivalent raw HLSL:
//
// - Fields of resource type have been stripped from original type definition
// - Fields of resource type get hoisted out of variable declarations
//

struct Foo
{
float2 u;
};

cbuffer C
{
Foo foo;
}

Texture2D SLANG_parameterBlock_C_foo_t;
SamplerState SLANG_parameterBlock_C_foo_s;

float4 main() : SV_Target
{
return SLANG_parameterBlock_C_foo_t.Sample(SLANG_parameterBlock_C_foo_s, foo.u);
}

#endif

3 changes: 3 additions & 0 deletions tests/rewriter/type-splitting.slang
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
//TEST_IGNORE_FILE:

// This file only exists so that `type-splitting.hlsl` officially appears to be using some Slang code.

0 comments on commit 5230ad2

Please sign in to comment.