diff options
| author | venkataram-nv <vedavamadath@nvidia.com> | 2025-07-31 15:12:21 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-07-31 22:12:21 +0000 |
| commit | 30fd3c63fb4af9ea8d482c75921710df1b40e59e (patch) | |
| tree | cd1001e90f5328f20fa7bc6d030bcfcc4e01979f /source/slang/core.meta.slang | |
| parent | aefd1e3e0dbe4e77f8d7dbbfa04e15c2db615394 (diff) | |
Add matrix select intrinsic (#7566)
* Add matrix select intrinsic
* Fix hlsl test
* Restrict matrix select to HLSL
* Better test for HLSL side
* Select route for GLSL/SPIRV
* Exclude matrices from select legalization
* Exclude CUDA from select test
* Inline and move
* format code
---------
Co-authored-by: slangbot <186143334+slangbot@users.noreply.github.com>
Diffstat (limited to 'source/slang/core.meta.slang')
| -rw-r--r-- | source/slang/core.meta.slang | 28 |
1 files changed, 27 insertions, 1 deletions
diff --git a/source/slang/core.meta.slang b/source/slang/core.meta.slang index f42cd25cf..2c6bf04d1 100644 --- a/source/slang/core.meta.slang +++ b/source/slang/core.meta.slang @@ -958,6 +958,31 @@ __generic<T, let N : int> __intrinsic_op(select) vector<T,N> operator?:(vector<b __generic<T> __intrinsic_op(select) T select(bool condition, T ifTrue, T ifFalse); __generic<T, let N : int> __intrinsic_op(select) vector<T,N> select(vector<bool,N> condition, vector<T,N> ifTrue, vector<T,N> ifFalse); +[require(hlsl)] +__generic<T, let N : int, let M : int> __intrinsic_op(select) matrix<T,N,M> __hlsl_select(matrix<bool,N,M> condition, matrix<T,N,M> ifTrue, matrix<T,N,M> ifFalse); + +__generic<T, let N : int, let M : int> +matrix<T,N,M> select(matrix<bool,N,M> condition, matrix<T,N,M> ifTrue, matrix<T,N,M> ifFalse) +{ + __target_switch + { + case hlsl: + return __hlsl_select(condition, ifTrue, ifFalse); + default: + matrix<T,N,M> result; + [[unroll]] + for (uint32_t i = 0; i < N; i++) + result[i] = select(condition[i], ifTrue[i], ifFalse[i]); + return result; + } +} + +__generic<T, let N : int, let M : int> +matrix<T,N,M> operator?:(matrix<bool,N,M> condition, matrix<T,N,M> ifTrue, matrix<T,N,M> ifFalse) +{ + return select(condition, ifTrue, ifFalse); +} + [ForceInline] __generic<T> Optional<T> select(bool condition, __none_t ifTrue, T ifFalse) { @@ -973,7 +998,8 @@ __generic<T> Optional<T> select(bool condition, T ifTrue, __none_t ifFalse) // Allow real-number types to be cast into each other //@hidden: __intrinsic_op($(kIROp_FloatCast)) - T __realCast<T : __BuiltinRealType, U : __BuiltinRealType>(U val); +T __realCast<T : __BuiltinRealType, U : __BuiltinRealType>(U val); + //@hidden: __intrinsic_op($(kIROp_CastIntToFloat)) T __realCast<T : __BuiltinRealType, U : __BuiltinIntegerType>(U val); |
