File: spv.coopmatKHR_arithmeticError.comp

package info (click to toggle)
glslang 16.2.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 51,720 kB
  • sloc: cpp: 92,305; yacc: 4,320; sh: 603; python: 305; ansic: 94; javascript: 74; makefile: 17
file content (87 lines) | stat: -rw-r--r-- 1,466 bytes parent folder | download | duplicates (7)
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
#version 450 core
#extension GL_KHR_memory_scope_semantics : enable
#extension GL_KHR_cooperative_matrix : enable
#extension GL_EXT_shader_explicit_arithmetic_types : enable

layout (local_size_x = 64, local_size_y = 1, local_size_z = 1) in;


void main()
{
    coopmat<float, gl_ScopeSubgroup, 8, 8, gl_MatrixUseA> f;
    coopmat<float, gl_ScopeSubgroup, 8, 8, gl_MatrixUseB> f2;
    coopmat<float, gl_ScopeSubgroup, 16, 8, gl_MatrixUseA> f3;

    coopmat<float16_t, gl_ScopeSubgroup, 8, 8, gl_MatrixUseA> f16;

    coopmat<uint8_t, gl_ScopeSubgroup, 8, 8, gl_MatrixUseA> u8;
    coopmat<int8_t, gl_ScopeSubgroup, 8, 8, gl_MatrixUseA> i8;
    coopmat<int32_t, gl_ScopeSubgroup, 8, 8, gl_MatrixUseA> i32;

    f+1.0;
    f-1.0;
    f/1.0;
    1.0+f;
    1.0-f;
    1.0/f;
    f+=1.0;
    f-=1.0;
    f/=1.0;

    f+f16;
    f-f16;
    f*f16;
    f/f16;
    f+=f16;
    f-=f16;
    f*=f16;
    f/=f16;

    f+f2;
    f-f2;
    f*f2;
    f/f2;
    f+=f2;
    f-=f2;
    f*=f2;
    f/=f2;

    f+f3;
    f-f3;
    f*f3;
    f/f3;
    f+=f3;
    f-=f3;
    f*=f3;
    f/=f3;

    u8+i8;
    u8-i8;
    u8*i8;
    u8/i8;
    u8+=i8;
    u8-=i8;
    u8*=i8;
    u8/=i8;

    u8+uint8_t(1);
    u8-uint8_t(1);
    u8/uint8_t(1);
    u8+=uint8_t(1);
    u8-=uint8_t(1);
    u8/=uint8_t(1);

    i8+int8_t(1);
    i8-int8_t(1);
    i8/int8_t(1);
    i8+=int8_t(1);
    i8-=int8_t(1);
    i8/=int8_t(1);

    i32+1;
    i32-1;
    i32/1;
    i32+=1;
    i32-=1;
    i32/=1;
}