From caf6f7a03793be3fc74683994414776f3604ad8a Mon Sep 17 00:00:00 2001 From: Yong He Date: Wed, 17 Jan 2018 14:48:07 -0500 Subject: All compiler fixes to get ir branch work with falcor feature demo. - support overloaded generic function. this involves adding a new expression type, `OverloadedExpr2` to hold the candidate expressions for the generic function decl being referenced. - make BitNot a normal IROp instead of an IRPseudoOp - make sure we clone the decorations of parameters when cloning ir functions - propagate geometry shader entry point attributes (`[maxvertexcount]` and `[instance]`) through HLSL emit - IR emit: handle geometry shader entry-point parameter decorations, such as 'triangle'. - IR emit: treat geometry shader stream output typed ir value as `should fold into use`. --- tests/compute/generics-overload.expected.txt | 4 ++++ tests/compute/generics-overload.slang | 32 ++++++++++++++++++++++++++++ 2 files changed, 36 insertions(+) create mode 100644 tests/compute/generics-overload.expected.txt create mode 100644 tests/compute/generics-overload.slang (limited to 'tests') diff --git a/tests/compute/generics-overload.expected.txt b/tests/compute/generics-overload.expected.txt new file mode 100644 index 000000000..98798bd61 --- /dev/null +++ b/tests/compute/generics-overload.expected.txt @@ -0,0 +1,4 @@ +0 +3F800000 +40000000 +40400000 \ No newline at end of file diff --git a/tests/compute/generics-overload.slang b/tests/compute/generics-overload.slang new file mode 100644 index 000000000..e530acb59 --- /dev/null +++ b/tests/compute/generics-overload.slang @@ -0,0 +1,32 @@ +//TEST(smoke,compute):COMPARE_COMPUTE:-xslang -use-ir +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):dxbinding(0),glbinding(0),out +// Confirm that generics syntax can be used in user +// code and generates valid output. + +RWStructuredBuffer outputBuffer; + + +__generic +T test(T val) +{ + return val; +} + +__generic +T test(T val, int a) +{ + return val; +} + + +[numthreads(4, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + uint tid = dispatchThreadID.x; + + float inVal = float(tid); + + float outVal = test(inVal, 0); + + outputBuffer[tid] = outVal; +} \ No newline at end of file -- cgit v1.2.3