summaryrefslogtreecommitdiffstats
path: root/tests/autodiff/warn-on-prefer-recompute-side-effects.slang
blob: 64aaf766627d6162edfe12cea18393311585d162 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
//TEST:SIMPLE(filecheck=CHECK): -target hlsl -line-directive-mode none
//TEST:SIMPLE(filecheck=CHECK): -target cuda -line-directive-mode none

//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer
RWStructuredBuffer<float> outputBuffer;

groupshared float s_shared;

[BackwardDifferentiable]
[PreferRecompute]
float get_thread_5_value(float v, uint group_thread_id)
{
    if(group_thread_id == 5)
    {
        s_shared = detach(v);
        // CHECK: tests/autodiff/warn-on-prefer-recompute-side-effects.slang([[# @LINE-5]]): warning 42050: get_thread_5_value has [PreferRecompute] and may have side effects. side effects may execute multiple times. use [PreferRecompute(SideEffectBehavior.Allow)], or mark function with [__NoSideEffect]
        // CHECK: float get_thread_5_value(float v, uint group_thread_id)
        // CHECK:       ^~~~~~~~~~~~~~~~~~
    }
    GroupMemoryBarrierWithGroupSync();
    return s_shared;
}

[BackwardDifferentiable]
[PreferRecompute(SideEffectBehavior.Allow)] // Suppress warning here
float get_thread_6_value(float v, uint group_thread_id)
{
    if (group_thread_id == 6)
    {
        s_shared = detach(v);
        // CHECK-NOT: warning 42050

    }
    GroupMemoryBarrierWithGroupSync();
    return s_shared;
}

[shader("compute")]
[numthreads(128, 1, 1)]
void computeMain(uint3 group_thread_id: SV_GroupThreadID, uint3 dispatch_thread_id: SV_DispatchThreadID)
{
    DifferentialPair<float> value = diffPair(3.f, 0.f);

    bwd_diff(get_thread_5_value)(value, group_thread_id.x, 1.0f);
    bwd_diff(get_thread_6_value)(value, group_thread_id.x, 1.0f);

    outputBuffer[dispatch_thread_id.x] = value.d;
}