HLSL: Handle "fake" entry points, by undoing their built-in variable declarations.
This commit is contained in:
parent
9e079535a0
commit
07350f3382
107
Test/baseResults/hlsl.multiEntry.vert.out
Executable file
107
Test/baseResults/hlsl.multiEntry.vert.out
Executable file
@ -0,0 +1,107 @@
|
|||||||
|
hlsl.multiEntry.vert
|
||||||
|
Shader version: 450
|
||||||
|
0:? Sequence
|
||||||
|
0:4 Function Definition: FakeEntrypoint(u1; (global 4-component vector of float)
|
||||||
|
0:4 Function Parameters:
|
||||||
|
0:4 'Index' (in uint)
|
||||||
|
0:? Sequence
|
||||||
|
0:5 Branch: Return with expression
|
||||||
|
0:5 textureFetch (global 4-component vector of float)
|
||||||
|
0:5 'Position' (uniform samplerBuffer)
|
||||||
|
0:5 Convert uint to int (temp int)
|
||||||
|
0:5 'Index' (in uint)
|
||||||
|
0:9 Function Definition: RealEntrypoint(u1; (global 4-component vector of float Position)
|
||||||
|
0:9 Function Parameters:
|
||||||
|
0:9 'Index' (in uint VertexIndex)
|
||||||
|
0:? Sequence
|
||||||
|
0:10 Sequence
|
||||||
|
0:10 move second child to first child (temp 4-component vector of float)
|
||||||
|
0:? '@entryPointOutput' (out 4-component vector of float Position)
|
||||||
|
0:10 Function Call: FakeEntrypoint(u1; (global 4-component vector of float)
|
||||||
|
0:10 'Index' (in uint VertexIndex)
|
||||||
|
0:10 Branch: Return
|
||||||
|
0:? Linker Objects
|
||||||
|
0:? 'Position' (uniform samplerBuffer)
|
||||||
|
|
||||||
|
|
||||||
|
Linked vertex stage:
|
||||||
|
|
||||||
|
|
||||||
|
Shader version: 450
|
||||||
|
0:? Sequence
|
||||||
|
0:4 Function Definition: FakeEntrypoint(u1; (global 4-component vector of float)
|
||||||
|
0:4 Function Parameters:
|
||||||
|
0:4 'Index' (in uint)
|
||||||
|
0:? Sequence
|
||||||
|
0:5 Branch: Return with expression
|
||||||
|
0:5 textureFetch (global 4-component vector of float)
|
||||||
|
0:5 'Position' (uniform samplerBuffer)
|
||||||
|
0:5 Convert uint to int (temp int)
|
||||||
|
0:5 'Index' (in uint)
|
||||||
|
0:9 Function Definition: RealEntrypoint(u1; (global 4-component vector of float Position)
|
||||||
|
0:9 Function Parameters:
|
||||||
|
0:9 'Index' (in uint VertexIndex)
|
||||||
|
0:? Sequence
|
||||||
|
0:10 Sequence
|
||||||
|
0:10 move second child to first child (temp 4-component vector of float)
|
||||||
|
0:? '@entryPointOutput' (out 4-component vector of float Position)
|
||||||
|
0:10 Function Call: FakeEntrypoint(u1; (global 4-component vector of float)
|
||||||
|
0:10 'Index' (in uint VertexIndex)
|
||||||
|
0:10 Branch: Return
|
||||||
|
0:? Linker Objects
|
||||||
|
0:? 'Position' (uniform samplerBuffer)
|
||||||
|
|
||||||
|
// Module Version 10000
|
||||||
|
// Generated by (magic number): 80001
|
||||||
|
// Id's are bound by 34
|
||||||
|
|
||||||
|
Capability Shader
|
||||||
|
Capability SampledBuffer
|
||||||
|
1: ExtInstImport "GLSL.std.450"
|
||||||
|
MemoryModel Logical GLSL450
|
||||||
|
EntryPoint Vertex 4 "RealEntrypoint" 27 29
|
||||||
|
Name 4 "RealEntrypoint"
|
||||||
|
Name 12 "FakeEntrypoint(u1;"
|
||||||
|
Name 11 "Index"
|
||||||
|
Name 17 "Position"
|
||||||
|
Name 27 "@entryPointOutput"
|
||||||
|
Name 29 "Index"
|
||||||
|
Name 30 "param"
|
||||||
|
Decorate 17(Position) DescriptorSet 0
|
||||||
|
Decorate 27(@entryPointOutput) BuiltIn Position
|
||||||
|
Decorate 29(Index) BuiltIn VertexIndex
|
||||||
|
2: TypeVoid
|
||||||
|
3: TypeFunction 2
|
||||||
|
6: TypeInt 32 0
|
||||||
|
7: TypePointer Function 6(int)
|
||||||
|
8: TypeFloat 32
|
||||||
|
9: TypeVector 8(float) 4
|
||||||
|
10: TypeFunction 9(fvec4) 7(ptr)
|
||||||
|
14: TypeImage 8(float) Buffer sampled format:Unknown
|
||||||
|
15: TypeSampledImage 14
|
||||||
|
16: TypePointer UniformConstant 15
|
||||||
|
17(Position): 16(ptr) Variable UniformConstant
|
||||||
|
20: TypeInt 32 1
|
||||||
|
26: TypePointer Output 9(fvec4)
|
||||||
|
27(@entryPointOutput): 26(ptr) Variable Output
|
||||||
|
28: TypePointer Input 6(int)
|
||||||
|
29(Index): 28(ptr) Variable Input
|
||||||
|
4(RealEntrypoint): 2 Function None 3
|
||||||
|
5: Label
|
||||||
|
30(param): 7(ptr) Variable Function
|
||||||
|
31: 6(int) Load 29(Index)
|
||||||
|
Store 30(param) 31
|
||||||
|
32: 9(fvec4) FunctionCall 12(FakeEntrypoint(u1;) 30(param)
|
||||||
|
Store 27(@entryPointOutput) 32
|
||||||
|
Return
|
||||||
|
FunctionEnd
|
||||||
|
12(FakeEntrypoint(u1;): 9(fvec4) Function None 10
|
||||||
|
11(Index): 7(ptr) FunctionParameter
|
||||||
|
13: Label
|
||||||
|
18: 15 Load 17(Position)
|
||||||
|
19: 6(int) Load 11(Index)
|
||||||
|
21: 20(int) Bitcast 19
|
||||||
|
22: 14 Image 18
|
||||||
|
23: 9(fvec4) ImageFetch 22 21
|
||||||
|
ReturnValue 23
|
||||||
|
FunctionEnd
|
||||||
11
Test/hlsl.multiEntry.vert
Executable file
11
Test/hlsl.multiEntry.vert
Executable file
@ -0,0 +1,11 @@
|
|||||||
|
Buffer<float4> Position;
|
||||||
|
|
||||||
|
float4 FakeEntrypoint(uint Index : SV_VERTEXID) : SV_POSITION
|
||||||
|
{
|
||||||
|
return Position.Load(Index);
|
||||||
|
}
|
||||||
|
|
||||||
|
float4 RealEntrypoint(uint Index : SV_VERTEXID) : SV_POSITION
|
||||||
|
{
|
||||||
|
return FakeEntrypoint(Index);
|
||||||
|
}
|
||||||
@ -2,5 +2,5 @@
|
|||||||
// For the version, it uses the latest git tag followed by the number of commits.
|
// For the version, it uses the latest git tag followed by the number of commits.
|
||||||
// For the date, it uses the current date (when then script is run).
|
// For the date, it uses the current date (when then script is run).
|
||||||
|
|
||||||
#define GLSLANG_REVISION "Overload400-PrecQual.1463"
|
#define GLSLANG_REVISION "Overload400-PrecQual.1464"
|
||||||
#define GLSLANG_DATE "02-Sep-2016"
|
#define GLSLANG_DATE "02-Sep-2016"
|
||||||
|
|||||||
@ -123,6 +123,7 @@ INSTANTIATE_TEST_CASE_P(
|
|||||||
{"hlsl.load.buffer.dx10.frag", "main"},
|
{"hlsl.load.buffer.dx10.frag", "main"},
|
||||||
{"hlsl.load.offset.dx10.frag", "main"},
|
{"hlsl.load.offset.dx10.frag", "main"},
|
||||||
{"hlsl.load.offsetarray.dx10.frag", "main"},
|
{"hlsl.load.offsetarray.dx10.frag", "main"},
|
||||||
|
{"hlsl.multiEntry.vert", "RealEntrypoint"},
|
||||||
{"hlsl.numericsuffixes.frag", "main"},
|
{"hlsl.numericsuffixes.frag", "main"},
|
||||||
{"hlsl.overload.frag", "PixelShaderFunction"},
|
{"hlsl.overload.frag", "PixelShaderFunction"},
|
||||||
{"hlsl.pp.line.frag", "main"},
|
{"hlsl.pp.line.frag", "main"},
|
||||||
|
|||||||
@ -755,6 +755,8 @@ TIntermAggregate* HlslParseContext::handleFunctionDefinition(const TSourceLoc& l
|
|||||||
inEntrypoint = (function.getName() == intermediate.getEntryPoint().c_str());
|
inEntrypoint = (function.getName() == intermediate.getEntryPoint().c_str());
|
||||||
if (inEntrypoint)
|
if (inEntrypoint)
|
||||||
remapEntrypointIO(function);
|
remapEntrypointIO(function);
|
||||||
|
else
|
||||||
|
remapNonEntrypointIO(function);
|
||||||
|
|
||||||
//
|
//
|
||||||
// New symbol table scope for body of function plus its arguments
|
// New symbol table scope for body of function plus its arguments
|
||||||
@ -864,6 +866,21 @@ void HlslParseContext::remapEntrypointIO(TFunction& function)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// An HLSL function that looks like an entry point, but is not,
|
||||||
|
// declares entry point IO built-ins, but these have to be undone.
|
||||||
|
void HlslParseContext::remapNonEntrypointIO(TFunction& function)
|
||||||
|
{
|
||||||
|
const auto remapBuiltInType = [&](TType& type) { type.getQualifier().builtIn = EbvNone; };
|
||||||
|
|
||||||
|
// return value
|
||||||
|
if (function.getType().getBasicType() != EbtVoid)
|
||||||
|
remapBuiltInType(function.getWritableType());
|
||||||
|
|
||||||
|
// parameters
|
||||||
|
for (int i = 0; i < function.getParamCount(); i++)
|
||||||
|
remapBuiltInType(*function[i].type);
|
||||||
|
}
|
||||||
|
|
||||||
// Handle function returns, including type conversions to the function return type
|
// Handle function returns, including type conversions to the function return type
|
||||||
// if necessary.
|
// if necessary.
|
||||||
TIntermNode* HlslParseContext::handleReturnValue(const TSourceLoc& loc, TIntermTyped* value)
|
TIntermNode* HlslParseContext::handleReturnValue(const TSourceLoc& loc, TIntermTyped* value)
|
||||||
|
|||||||
@ -87,6 +87,7 @@ public:
|
|||||||
TIntermAggregate* handleFunctionDefinition(const TSourceLoc&, TFunction&);
|
TIntermAggregate* handleFunctionDefinition(const TSourceLoc&, TFunction&);
|
||||||
void handleFunctionBody(const TSourceLoc&, TFunction&, TIntermNode* functionBody, TIntermNode*& node);
|
void handleFunctionBody(const TSourceLoc&, TFunction&, TIntermNode* functionBody, TIntermNode*& node);
|
||||||
void remapEntrypointIO(TFunction& function);
|
void remapEntrypointIO(TFunction& function);
|
||||||
|
void remapNonEntrypointIO(TFunction& function);
|
||||||
TIntermNode* handleReturnValue(const TSourceLoc&, TIntermTyped*);
|
TIntermNode* handleReturnValue(const TSourceLoc&, TIntermTyped*);
|
||||||
void handleFunctionArgument(TFunction*, TIntermTyped*& arguments, TIntermTyped* newArg);
|
void handleFunctionArgument(TFunction*, TIntermTyped*& arguments, TIntermTyped* newArg);
|
||||||
TIntermTyped* handleFunctionCall(const TSourceLoc&, TFunction*, TIntermNode*);
|
TIntermTyped* handleFunctionCall(const TSourceLoc&, TFunction*, TIntermNode*);
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user