georgeouzou
168e9f2cc9
GLSL: Support KHR_subgroup_arithmetic IMul/FMul
...
Support NV workarounds for IMul/FMul Reduce/InclusiveScan/ExclusiveScan
2023-04-03 19:13:30 +03:00
georgeouzou
ab3a6212b8
GLSL: Checking for inactive threads in non uniform arithmetic ops
...
The last argument of shuffle*NV functions does not return if the
current thread is inactive, but only if it is out of range.
2023-04-03 18:42:08 +03:00
georgeouzou
dbf6218883
GLSL: Support KHR_subgroup_arithmetic FAdd
...
Support NV workarounds for FAdd Reduce/InclusiveScan/ExclusiveScan
2023-04-02 10:45:25 +03:00
georgeouzou
b693d8faec
GLSL: Support KHR_subgroup_arithmetic IAdd
...
Support NV workarounds for IAdd Reduce/InclusiveScan/ExclusiveScan
2023-04-02 01:25:15 +03:00
Hans-Kristian Arntzen
d26c233e1c
Merge pull request #2121 from Keenuts/licenses
...
adds Khronos license to LICENSES folder.
2023-03-13 17:22:12 +01:00
Nathan Gauër
0d8cfdb4f0
revert trailing space fix
2023-03-13 15:41:15 +01:00
Nathan Gauër
ada706403d
applying pr feedback
2023-03-13 14:01:13 +01:00
Nathan Gauër
2d598f29c0
try adding SPDX notice
2023-03-09 18:23:49 +01:00
Nathan Gauër
46a7ce8d72
adds Khronos license to LICENSES folder.
...
This license is in spirv.h, but absent from the LICENSES file.
2023-03-09 17:03:53 +01:00
Hans-Kristian Arntzen
7512345f61
Merge pull request #2110 from EpicGames/fixes_glsl
...
GLSL: Don't create temporaries for sampled image types in GLSL.
2023-02-27 20:36:36 +01:00
Laura Hermanns
83650af3fb
GLSL: Don't create temporaries for sampled image types in GLSL.
...
This fixes a bug that was exposed when targeting GLSL with
Vulkan semantics while 'force_temporary' is enabled.
2023-02-27 11:51:49 -05:00
Hans-Kristian Arntzen
3550a54ae0
Merge pull request #2105 from goki/main
...
add support for OpAtomicFAddEXT atomic add, and also Min, Max
2023-02-21 13:05:31 +01:00
Randall C. O'Reilly
c76111f22e
cleaner version check
2023-02-20 04:41:28 -08:00
Hans-Kristian Arntzen
5e51297118
Merge pull request #2108 from cdavis5e/msl-duplicate-spec-id
...
MSL: Deduplicate function constants.
2023-02-20 12:56:25 +01:00
Randall C. O'Reilly
29f959db67
update msl_compiler_supports_version to work with metal 3.0
2023-02-18 03:10:58 -08:00
Chip Davis
41007cdc7d
MSL: Deduplicate function constants.
...
It is possible in SPIR-V to declare multiple specialization constants
with the same constant ID. The most common cause of this in GLSL is
defining a spec constant, then declaring the workgroup size to use that
spec constant by its ID. But, MSL forbids defining multiple function
constants with the same function constant ID. So, we must only emit one
definition of the actual function constant (with the
`[[function_constant(id)]]` attribute); but we can point the other
variables at this one definition.
Fixes three tests in the Vulkan CTS under
`dEQP-VK.compute.basic.max_local_size_*`.
2023-02-17 10:43:50 -08:00
Randall C. O'Reilly
8e20860b9e
added tests and added msl3 to test_shaders.py
2023-02-15 00:04:44 -08:00
Randall C. O'Reilly
bff7680cc4
revert FMinEXT, FMaxExt
2023-02-14 16:43:50 -08:00
Randall C. O'Reilly
c4b7ec105d
add OpAtomicFMinEXT and Max as well, while we're at it -- I didn't test those but presumably work the same.
2023-02-04 21:52:07 -08:00
Randall C. O'Reilly
a57dba530c
add support for OpAtomicFAddEXT atomic add on float types, now avail in metal 3.0
2023-02-04 21:47:08 -08:00
Hans-Kristian Arntzen
4e2fdb2567
Merge pull request #2104 from Ravbug/fix-int-sm6.7
...
Support integer samplers in Shader Model 6.7
2023-02-03 17:05:31 +01:00
Hans-Kristian Arntzen
388431604a
Merge pull request #2103 from cdavis5e/msl-sample-dref-lod-array-workaround
...
MSL: Add a workaround for broken `level()` arguments.
2023-02-03 16:36:44 +01:00
Chip Davis
e8d419854f
MSL: Add a workaround for broken level()
arguments.
...
Some Metal devices have a bug with depth array textures using comparison
with explicit LoD, where the LoD given will be biased by some amount.
For these devices, we can use a gradient instead, which does not exhibit
this problem. As with the fragment demote workaround, this is only
expected to be needed until the bug is fixed in Metal.
2023-02-02 22:01:46 -08:00
Ravbug
36691f902c
Check for SM < 6.7
2023-02-02 12:42:17 -05:00
Hans-Kristian Arntzen
459fa67937
Merge pull request #2101 from rdb/glsl-fix-missing-qualifier
...
GLSL: Fix missing precision qualifier in spvDeterminant return value
2023-02-02 11:26:06 +01:00
rdb
c356dd6220
GLSL: Fix missing precision qualifier in spvDeterminant return value
...
Follow-up to #2100
2023-01-27 21:44:47 +01:00
Hans-Kristian Arntzen
199d0cb8a9
Merge pull request #2100 from rdb/glsl-matrix-polyfills
...
GLSL: Add matrix inverse/determinant polyfills, outerProduct()
2023-01-27 14:37:45 +01:00
rdb
20981666cc
GLSL: Legacy matrix inverse/determinant polyfills, outerProduct()
...
Also refactors polyfill mechanism in GLSL and fixes transpose() lowering precision.
2023-01-27 13:51:47 +01:00
Hans-Kristian Arntzen
86a985f28c
Merge pull request #2093 from rdb/emulate-unsupported-hyperbolic-funcs
...
GLSL/HLSL: Add emulated fallbacks for hyperbolic math functions
2023-01-27 12:15:28 +01:00
Hans-Kristian Arntzen
cd612e7dde
Merge pull request #2090 from rdb/glsl-legacy-math-funcs
...
GLSL: Add support for trunc, modf, isnan and isinf in legacy GLSL
2023-01-27 12:13:14 +01:00
Hans-Kristian Arntzen
99f130bb95
Merge pull request #2099 from rdb/patch-1
...
GLSL: Drop invariant keyword in GLSL 110
2023-01-27 12:10:02 +01:00
rdb
f8cc03fd1e
GLSL: Drop invariant keyword in GLSL 110
2023-01-27 11:10:47 +01:00
rdb
53974b4fae
GLSL/HLSL: Add emulated fallbacks for sinh/cosh/tanh/asinh/acosh/atanh
...
The inverse hyperbolic functions are not supported in HLSL, and none of them are supported in legacy GLSL.
2023-01-26 19:40:42 +01:00
rdb
d10044b23e
GLSL: Add support for modf, isnan and isinf in legacy GLSL
2023-01-26 19:14:25 +01:00
Hans-Kristian Arntzen
ff7a11dbcb
Merge pull request #2097 from KhronosGroup/shader-clock-tweaks
...
GLSL: Minor fixes for shader clock implementation.
2023-01-26 17:14:38 +01:00
Hans-Kristian Arntzen
9de5abaf78
GLSL: Minor fixes for shader clock implementation.
2023-01-26 15:41:51 +01:00
Hans-Kristian Arntzen
f575b89436
Merge pull request #2091 from LDeakin/shader-clock
...
GLSL: Support OpReadClockKHR
2023-01-26 15:41:40 +01:00
Hans-Kristian Arntzen
9da448c9ff
Merge pull request #2096 from rdb/glsl-extension-checks
...
GLSL: Add various missing extension checks
2023-01-26 15:41:15 +01:00
Hans-Kristian Arntzen
45824ea13c
Merge pull request #2095 from rdb/glsl-matrix-times-scalar-no-transpose
...
GLSL: Multiplying matrix with scalar shouldn't force transpose
2023-01-26 15:38:05 +01:00
Hans-Kristian Arntzen
c98ebc0312
Merge pull request #2092 from rdb/patch-1
...
Add early exit for test_shaders if compilation fails
2023-01-26 15:14:08 +01:00
rdb
d70bfa5f34
GLSL: Allow sample inputs in desktop < 400 with GL_ARB_sample_shading
...
Neither legacy ES nor legacy desktop support these extensions
2023-01-23 14:51:26 +01:00
rdb
2202c2a701
GLSL: Add various additional extension checks.
2023-01-23 11:55:53 +01:00
rdb
dff276989b
GLSL: Multiplying matrix with scalar shouldn't force transpose
2023-01-21 11:42:55 +01:00
Hans-Kristian Arntzen
eb9b273298
Merge pull request #2094 from LibretroAdmin/main
...
(spirv_glsl.cpp) Fix error: no matching function for call to 'max(uint32_t&, unsigned int)'
2023-01-20 18:39:38 +01:00
libretroadmin
5029e30f0a
(spirv_glsl.cpp) Fix error: no matching function for call to 'max(uint32_t&, unsigned int)'
2023-01-20 18:36:11 +01:00
Hans-Kristian Arntzen
f3a75d1d4b
MSL: Fix another warning on potentially uninitialized.
2023-01-20 16:56:11 +01:00
Hans-Kristian Arntzen
85a78324ef
MSL: Fix potentially uninitialized warning.
2023-01-20 16:51:16 +01:00
rdb
e6d1c76e5c
Add early exit for test_shaders if compilation fails
2023-01-19 14:18:01 +01:00
Lachlan Deakin
3335835fad
GLSL: Support OpReadClockKHR
2023-01-19 22:28:38 +11:00
Chip Davis
2a9091ce53
MSL: Use rint()
instead of round()
to round array coordinates.
...
Vulkan specifies round-to-nearest-even mode to round array coordinates.
But we were using `round()`, which is round-to-nearest-away-from-zero.
Instead, use `rint()`, which is specified to perform nearest-even
rounding in MSL.
2023-01-18 19:34:29 -08:00