mirror of
https://github.com/libretro/RetroArch
synced 2025-02-01 00:32:46 +00:00
f347c2d192
* Squashed 'deps/SPIRV-Cross/' changes from 2820ab0b51..49e4117c5f 49e4117c5f Updates for main branch rename. 88c6b49959 Merge pull request #2085 from KhronosGroup/fix-2075 a085227395 Merge pull request #2084 from KhronosGroup/fix-2069 1047c13d40 GLSL: Handle textureGatherOffsets properly. f84527346d GLSL: Declare gl_in/gl_out as array more robustly. 38cd214007 Merge pull request #2083 from KhronosGroup/pr-2080 d46c10ebd3 Refactor PHI checks into block_is_noop instead. bcbe33ad11 Also consider NonSemantic ExtInst in block_is_noop. 9d8ef6b36c Update test for updated block_is_noop check. a61a541e1c Merge branch 'accept_noop' of https://github.com/loic-sharma/SPIRV-Cross into pr-2080 457fd3db70 Add tests for loops compiled with debug semantics. 07a629f149 Roll dependencies. d69a2cafe5 Accept no ops cded61dde3 Merge pull request #2076 from billhollings/ios-tier2-writable-images 284ccf5d2d Fixes from code review of adding writable images to iOS Tier2 argument buffers. 0bb28ef88a Merge pull request #2078 from KhronosGroup/fix-2072 549cde7fae Fix GCC5 build. cc2b3b61a6 Merge pull request #2077 from EpicGames/fixes_glsl 6371580f51 Fixed typo in CompilerGLSL::should_dereference() 643b7be196 MSL: Add support for writable images in iOS Tier2 argument buffers. a89dea3c49 Merge pull request #2071 from KhronosGroup/fix-2068 baf38f0593 Merge pull request #2070 from KhronosGroup/fix-2066 68a012a4f2 CFG: Handle implied access to opaque loaded values. 03b1f66ef1 GLSL: Fix row-major workaround wrapper for ES. 3c997e12eb Add C API option for enable row major workaround. c77b09b57c Merge pull request #2063 from KhronosGroup/fix-2060 451ed10e91 Merge pull request #2062 from cdavis5e/msl-spirv-assembly-fixes df76a14056 MSL: Refactor member reference in terms of one boolean. e75c496ec6 Fix MSL Access Chain 540a1e82c6 Merge pull request #2056 from cdavis5e/msl-discarded-frag-checks 061cdd2052 MSL: Don't dereference forwarded copies of `OpVariable` pointers. 5547b25afe Interleave undef values with constants and types. 06ef3de002 GLSL, MSL: Handle `OpUndef` as part of a constant composite. aa5a8c482e MSL: Prevent stores to storage resources in discarded fragments. 51d2dfe02a MSL: Add missing casts to `Op?MulExtended`. c7ce92a95b MSL: Manually update `BuiltInHelperInvocation` when a fragment is discarded. edd66a2fc9 Merge pull request #2055 from KhronosGroup/fix-2053 e8a22a7cf6 Handle ShaderDebugInfo non-semantic extension. abc31207bf Merge pull request #2052 from KhronosGroup/hlsl-mesh-shader-ext b606e4f752 HLSL: Fix test for non-block per-primitive IO. ebf779dcfb HLSL: Do not support ClipCull size > 4 in mesh shaders. 94160e8890 GLSL: Add test for mesh with non-block builtin IO. 3a066cd733 HLSL: Handle case where PerVertex block is not used. f5ef0a74fb HLSL: Make sure to test deeply nested functions in mesh shaders. e418266d25 HLSL: Some cleanups and fixes in analyze_meshlet_writes. 892f65b3a6 HLSL: Fix some warnings from review. a4d5c0c4a5 HLSL: Fix-up some style issues from review. 10f55a11eb HLSL: Add missing reference for mesh shader test. 322f1b9fb3 Fixup glslang reference. 80146a20da HLSL: Implement VK_EXT_mesh_shader 744279ec78 Merge pull request #2050 from cdavis5e/op-spec-constant-op-composite-insert 8cf99e7d44 MSL: Implement `CompositeInsert` `OpSpecConstantOp`. 3cecac74c6 Merge pull request #2051 from KhronosGroup/roll-glslang-dep 605bce39d7 Roll glslang dependency. 677299cc56 Merge pull request #2049 from KhronosGroup/fix-2046 4de9d6c2b6 MSL: Handle implicit integer promotion rules. c813d8d67b Merge pull request #2044 from KhronosGroup/fix-2038 2a49f7e82d MSL: Fix restrict vs __restrict incompatibility. 3ea057a303 Merge pull request #2045 from KhronosGroup/fix-2037 0851baf9ee Merge pull request #2043 from KhronosGroup/fix-2040 47c7fc16eb HLSL: Add option to bind vertex input smemantics by name. 04af769e85 MSL: Handle partial access chains with array-of-UBO/SSBO. 5763919669 Merge pull request #2039 from cdavis5e/raw-buffer-tess-input e698633e22 MSL: Account for composite types when assigning locations. 0b679334e4 MSL: Don't flatten arrayed per-patch output blocks in tessellation shaders. a171087180 MSL: Support "raw" buffer input in tessellation evaluation shaders. f09ba27777 Merge pull request #2035 from KhronosGroup/fix-2032 f15d465a52 Merge pull request #2034 from KhronosGroup/fix-2028 799d8c9e35 Merge pull request #2033 from KhronosGroup/fix-2029 b5386e3ea9 HLSL: Improve support for VertexInfo aux struct. 4ecdb24e59 MSL: Expose way to query if a buffer needs array length. f3b1375b13 Add reflection support for shader record buffers. c821207ae2 Merge pull request #2027 from billhollings/msl-opstore-addr-space-cast 0a1127aa50 MSL: Emit correct address space when casting during OpStore. 81ba8f78f6 Merge pull request #2025 from KhronosGroup/fix-2009 291def0793 MSL: Add more keywords to reserved set. a7f64a8b90 MSL: Report unsupported 64-bit atomics. ddaa2da629 Merge pull request #2024 from KhronosGroup/msl-descriptor-aliasing a915e0bd4b MSL: Do not attempt to alias push constants. adf0995bb9 Merge pull request #2023 from KhronosGroup/msl-descriptor-aliasing 24dc49e692 MSL: Handle descriptor aliasing of raw buffer descriptors. 1ad6006130 Merge pull request #2021 from siegelaaron94/opengles_texture1d_textureSize 7b4c470f16 GLSL: Account for ES sampler1D to sampler2D promotion in textureSize. 6d3518e238 Merge pull request #2018 from atyuwen/master 7afbbb624a Merge pull request #2019 from billhollings/msl-OpPtrEqual-OpPtrNotEqual-OppPtrDiff 5493b3030e MSL: Support OpPtrEqual, OpPtrNotEqual, and OpPtrDiff. 1b9296e1a5 MSL: only fix up gl_FragCoord if really necessary. f6ca617825 Merge pull request #2017 from KhronosGroup/roll-deps a5a7999666 Update mesh/task test references. d7a6861f64 Update glslang/spirv-tools. 1e7e9fc32b Merge pull request #2015 from FrankXie05/vcpkg-instructions 8553588895 Merge pull request #2014 from cdavis5e/msl-shader-output-fixup 064eaebe72 MSL: Add a mechanism to fix up shader outputs. d206e54ece Add vcpkg installation instructions 210a800130 Merge pull request #2012 from KhronosGroup/mesh-shaders 4c345166dc GLSL: Implement task shaders. 5762617729 GLSL: Implement GL_EXT_mesh_shader. 6a73e68d30 Update glslang reference. ec7b9b0ce7 Update SPIR-V headers. 9fcf62784b Merge pull request #2011 from KhronosGroup/roll-deps d24f41f1d5 Update dependencies. c93ee9261e Merge pull request #2005 from atyuwen/master f40dba4919 GLSL: added an option to disable row-major-load workaround. 10f2aa77da Skip remapped vars in 'fixup_reserved_names' 9afa82e7b8 GLSL: disable row major load around on GLES. 33e19e86bf Don't rename remapped variables like 'gl_LastFragDepthARM' 61c603f3ba Merge pull request #1996 from KhronosGroup/fix-1993 bc3987e59a MSL: Fix various bugs with Ptr/U bitcasts. c084973c67 Merge pull request #1995 from KhronosGroup/fix-1992 05bbcc2d09 Do not optimize OpCompositeInsert for hoisted temporaries. a725d8fad1 Fix minor style nit from review. 1bc05ef735 Merge branch 'master' of https://github.com/gpx1000/SPIRV-Cross a9cadd4982 Merged in cts-shared-composite-variables (pull request #1) fc4a12fd4f MSL: Use a wrapper type for matrices in workgroup storage. faea931de3 MSL: Also replace `bool` with `short` in structures. 0cccd0a65a Merge pull request #1986 from KhronosGroup/fix-1975 4dfac510ed Handle multiple breaks out of switches. c24d5a7b90 Merge pull request #1985 from KhronosGroup/fix-1973 8ba0820c9d Merge pull request #1984 from KhronosGroup/fix-1972 095e9e5cee Merge pull request #1982 from RandomShaper/hlsl_subgroup_scan be904dcc1e Handle collapsed loops similar to collapsed selections. f7e98c39db Avoid detection of false loop variables. cb4e310f43 Merge pull request #1983 from KhronosGroup/fix-1979 1fe470b199 HLSL: Implement GroupOperation(Inclusive/Exclusive)Scan. 06ca9accd7 HLSL: Add option to emit entry point name 1:1 instead of main(). d8d051381f Merge pull request #1970 from KhronosGroup/fix-1969 963fdfdf68 Handle PHI in collapsed switch constructs. f46745095d Merge pull request #1965 from billhollings/msl-physical_storage_buffer 064a697b18 MSL: Fix implicit conversion precision build error. 4185acc70d MSL: Fixes from review for SPV_KHR_physical_storage_buffer extension. 78eb5043f9 MSL: Fixes from review for SPV_KHR_physical_storage_buffer extension. e6925974d1 Merge pull request #1966 from fred-wang/macos-snprintf 9c44a97faa address more review comments 1310f5ba4d Keep using sprintf on windows. 99f8613847 Fix compilation errors with deprecated sprintf function ba3e6ffe03 Merge pull request #1964 from sergmister/patch-1 52c7c2dab6 MSL: Add support for SPV_KHR_physical_storage_buffer extension. 1bba4d5137 Fix typo 99b59b3528 Merge pull request #1963 from KhronosGroup/convert-u-to-rtas-fix e08e0cf28d GLSL: Handle forced temporary OpConvertUToAccelerationStructureKHR. 89b1c24bdc Merge pull request #1961 from RandomShaper/hlsl_more_bitcasts d8c5e39436 HLSL: Implement bit casts between Half and UShort. 197a273fd4 Merge pull request #1959 from KhronosGroup/fix-1955-1956 df21a99d1a GLSL: Add more extension ladder fallbacks for unusual integer sizes. a97bbc24c5 Merge pull request #1958 from KhronosGroup/fix-1957 cdafafe93b Merge pull request #1954 from vkaytsanov/patch-1 533aab00b6 GLSL: Add missing KHR barycentric references. 46e4b5a3c8 Fix control flow bug where we missed continue; 612de70b38 Fix missing function in README sample 50b4d5389b Merge pull request #1953 from KhronosGroup/bary-khr e45d01c41f Emit KHR barycentrics if source enables the KHR extension. 0aedc7d128 Roll dependencies. af223101c6 Merge pull request #1952 from KhronosGroup/fix-1944 c8ab790163 Merge pull request #1951 from KhronosGroup/fix-1950 88e583d062 GLSL: Add basic support for GL_EXT_shader_atomic_float. 1c88730e12 GLSL: Implement 1D texture emulation for ES. 3f855646f0 Merge pull request #1948 from iwubcode/gl_layer_hlsl a6976d596a HLSL: fix BuiltInLayer to emit semantic 'SV_RenderTargetArrayIndex' instead of 'SV_RenderTargetIndex' b3ff97d0fe Merge pull request #1946 from KhronosGroup/fix-1943 48d50fa911 Merge pull request #1945 from KhronosGroup/fix-1938 d08ce828f4 Promote Unreachable cases into break to avoid fallthrough. 4b9e60273c Add tests for OpCompositeInsert edge cases. 23662668dd Attempt more optimal codegen for OpCompositeInsert. d0c8dc3045 Merge pull request #1942 from KhronosGroup/no-fetch-grad-workaround a3c4177324 GLSL: Don't apply Grad LOD workarounds for fetch. bfefb5f511 Merge pull request #1941 from KhronosGroup/fix-1934 832d469048 Merge pull request #1940 from KhronosGroup/fix-1935 05206005ca MSL: Potentially cast loaded Input variables. 92164d38d1 GLSL: Do not analyze precision for Undef variables. 940efca099 Merge pull request #1936 from KhronosGroup/rt-stage-cli 0b303aab16 Add --stage handling for ray tracing. 0c8a79b0b5 Merge pull request #1932 from KhronosGroup/fix-1868 7eb5ced2a0 Refactor out query for operation type/result IDs. 7a6c2da9aa GLSL: Handle more proper semantics for RelaxedPrecision. d28136cc7a GLSL: Clean up some ways of querying decoration flags. a9d23d7652 Merge pull request #1931 from EpicGames/fixes_hlsl 65431446f4 HLSL: Add missing BuiltInLayer to HLSL backend. 6ae7ddb92a Merge pull request #1930 from KhronosGroup/fix-1928 960edcd396 Merge pull request #1929 from KhronosGroup/fix-1925 10a7631d50 HLSL: Add more comprehensible reserved identifier list. 40b3053b4c Handle early reads from loop variables with initializers. c52333b984 Merge pull request #1924 from stefalie/master ee4ac5c2ce Merge pull request #1927 from billhollings/msl-interface-block-array-length-1 3bca246ad2 MSL: Emit interface block members of array length 1 as arrays instead of scalars. 089cf27119 remove newline at eof 56fd17f552 add qualifiers to reference reflect json output 05c9a14422 cli: display missing memory qualifiers for reflect and dump-resources d7cae5e7cd Merge pull request #1917 from KhronosGroup/fix-1906 0500f9ed5d Merge pull request #1916 from KhronosGroup/fix-1910 d2a4f9842b GLSL: Support GL_EXT_debug_printf. 5b18fb1bcd MSL: Pass down global RayQuery object to leaf functions. 779138f39f Merge pull request #1914 from RandomShaper/hlsl_view_index 2ea1c9b642 HLSL: Implement ViewIndex. 6a67891418 Merge pull request #1909 from skkkksdkfak/primitive_id 54c00b69a4 Translate gl_PrimitiveID to SV_PrimitiveID. 0d4ce028bf Merge pull request #1903 from KhronosGroup/fix-1900 17c52990d5 MSL: Fix goofy bugs in ray query. a3996eccf3 Merge pull request #1896 from Roy-AMD/fix-condition-issue 749be80389 Use types have same widths in loop condition. 44691aa975 Merge pull request #1899 from billhollings/forward-volatile-vars-except-builtins 85f98eb0c5 Allow volatile vars that are not builtins to be forwarded. d000b9e71c Merge pull request #1898 from KhronosGroup/pr-1859 191c57b6cc Merge pull request #1897 from KhronosGroup/fix-1763 a7eefbc114 HLSL: Disable FXC testing for rayquery shaders. cd209ff46d HLSL: Update test from review. c95338e03e Merge branch 'ray_query' of https://github.com/k-payl/SPIRV-Cross into pr-1859 7b9eaf0b5e MSL: Handle awkward mix and match of Offset / ArrayStride in constants. 251361bd6f VK_KHR_ray_query implementation 565db34cba Merge pull request #1892 from KhronosGroup/meta-lookup-cleanup 39bad2c1f9 Avoid redundant meta lookups in ParsedIR when setting member decorations. d5c3bd8b5e Merge pull request #1890 from KhronosGroup/fix-1889 4ab5bbb4e5 Fixup names of anonymous inner structs. 0b51794f01 Merge pull request #1888 from KhronosGroup/msl-ib-variable-name-alias-fix 1ec9d018fd MSL: Handle aliased variable names for resources placed in IB struct. 213c5f42ea MSL: Fix minor nits. 4ec1fb0aa9 Merge pull request #1887 from billhollings/msl-use-var-name-for-flattened-interface-struct-members 0c0fd98322 MSL: Use var name instead of var-type name for flattened interface members. 3915c37bb1 Merge branch 'fixup_gl_helper_invocation' of https://github.com/RandomShaper/SPIRV-Cross c4f9e4fde9 HLSL: Fix Helper Invocation wrongly allowed in compute. a1803778c2 Merge pull request #1885 from KhronosGroup/helper-invocation-rework b192b8887a MSL: Consider that gl_IsHelperInvocation can be Volatile. 15d29f00e2 Add test for SPIR-V 1.6 Volatile HelperInvocation. 93b0dc7718 Consider Volatile in should_forward(). 476b6541fa Remove forwardable bit in SPIRVariable. 5d9fc2d903 HLSL: Add test for HelperInvocation. 005c14ad6a HLSL: Implement HelperInvocationEXT. 75224c6c7c Merge branch 'gl_helper_invocation' of https://github.com/RandomShaper/SPIRV-Cross 278a4c80ed HLSL: Add support for gl_HelperInvocation 6c7a40822f Merge pull request #1881 from KhronosGroup/relax-nan-checks 31be74a853 Add relax_nan_checks options. b91ecf6077 Merge pull request #1880 from KhronosGroup/fix-1879 2ce1e5c140 Merge pull request #1878 from mysterymath/move dc62cc792b Handle OpTerminateInvocation. 2a7f436135 Merge branch 'msl-add-nested-structs-to-io-blocks-squash' 7b594c125e Fix formatting nits from review. bb4ced0280 MSL: Document clarification of location incrementing. 02d588b7e4 MSL: Fix var names in test shaders to avoid reserved identifiers. 3bb3b22b34 MSL: Non-functional fixes from PR code review. 3d4daab29d MSL: Support input/output blocks containing nested struct arrays 44c3333a1c Qualify std::move. d16183d1d2 Merge pull request #1873 from KhronosGroup/fix-1861 02440e85cf Merge pull request #1872 from KhronosGroup/fix-1867 7af0a5f820 HLSL: Do not emit VPOS fixup unless position is active. 5555f2784b MSL: Refactor and fix use of quadgroup vs simdgroup. a569680406 Merge pull request #1870 from abrachet/master 0eda71c409 Qualify move as std::move c08ee860c8 Merge pull request #1869 from xndcn/msl 1b5c406a3d MSL: append entry point args to local variable names to avoid conflicts 188dc8b13c Merge pull request #1862 from flokart-world/feature/flatten-ubo-for-hlsl 64e058aa9b Merge pull request #1863 from KhronosGroup/various-fixes ed4ded040e HLSL: Make --flatten-ubo work correctly a56b22bf4e Add more scenarios where we can guarantee forward progress. c716a9a5dd Add debug option to modify maximum number of compile iterations. 29cc18988c Fix regression from adding 64-bit switch support. 339e61a0e0 Do not emit hoisted access chain temporaries unless backend supports it. 5d9a95370f GLSL: Ensure correct signed integer type for more texture functions. 131278458e Merge pull request #1860 from KhronosGroup/docs-update a8016a6470 Update documentation for descriptor set support in MSL/HLSL. 1a36968e5d [Spirv_msl] Fix normalize on half3/half2 (#1856) 53d94a982e Merge pull request #1852 from KhronosGroup/fix-1850 5a29181b35 Merge pull request #1851 from KhronosGroup/fix-1835 5b952d2cbf MSL: Rethink how opaque descriptors are passed to leaf functions. ac46140ba3 Test aliased names in declared LUTs. 48b5a9069f Handle aliased names in spec constants. 08d5f5ed18 Merge pull request #1849 from KhronosGroup/fix-1844 9b25581d49 MSL: Handle constant construct of block-like array types. 79b13813c6 Merge pull request #1848 from KhronosGroup/fix-1843 5a5be7f9b9 MSL: Handle signed atomic min/max. 7dd974b9db Merge pull request #1847 from KhronosGroup/fix-1775 e940577fba Merge pull request #1846 from KhronosGroup/fix-1760 1d13a3e36a Rework how loop iteration counts are validated. ef6bde6580 Do not forward expressions which carry a huge amount of dependencies. a1bb29ccbb Merge pull request #1845 from KhronosGroup/pr-1842-fix 017cdfe25b Update references for GL_EXT_texture_buffer. 4407c0dd14 fix: GL_EXT_texture_buffer is more common than GL_OES_texture_buffer fe5a0aa72f Merge pull request #1839 from KhronosGroup/spv1.6 e8b30cc31d Merge pull request #1838 from KhronosGroup/fix-1811 7c12228359 Add sanity test for SPIR-V 1.6 modules. 7c83fc22fa Add support for LocalSizeId. 35bb328443 Test: Add --allow-localsizeid flag for spirv-val. eadca962c8 Merge pull request #1837 from KhronosGroup/roll-deps a10d72e3b1 Merge pull request #1834 from chirsz-ever/chirsz/fix-msl-copy-array fe8848a6f2 Roll dependencies. 9c0b74f73b Merge pull request #1836 from KhronosGroup/pr-1824-fixup be333e0cab MSL: Move float2->3 TessCoord fixup to a better location. 2793d22af5 Merge branch 'master' of git://github.com/cfnptr/SPIRV-Cross e0ae55d5e2 Merge pull request #1822 from etra0/add-diff 55a0291ce5 Merge pull request #1817 from etra0/fix-1784 90c252274d MSL: Allow copy array from UniformConstant storage 2acf0e73dd Fix gl_TessCoord arguments presence. Update reference shaders. a66984072b Fix incorrect MSL gl_TessCoord variable type 2bb051206b test_shaders: Add the option to generate diff instead. 905b8244e7 Clamp vector element access to vector size. e9cc640334 Merge pull request #1815 from etra0/fix-1768 25868923da Merge pull request #1819 from sindney/master 6d8302ef14 MSL: Add 64 bit switch support 4b0584ce70 ESSL: Vertex shader input doesn't support array types. 37dfb3f45f Merge pull request #1794 from etra0/master 5345051a85 Removed tracking of OpConstant and OpPhi. 7c3cb0b12c Merge pull request #1810 from billhollings/early-frag-tests-depth-out 248e9ae9ed MSL: Don't output depth and stencil values with explicit early fragment tests. 75e3752273 Added block.cases_32bit and reworked the cases fix 401296d3b8 Merge pull request #1808 from billhollings/depth-img-vs-depth-cmp 03f678dec4 Cast the switch selector in GLSL to uint32_t fd252b21ff Separate (partially) the tracking of depth images from depth compare ops. 48046646ee Fixed wrong condition and formatting. 2e0fb3a778 Merge pull request #1807 from KhronosGroup/fix-1801 f1b411c9e8 GLSL: Deal with buffer_reference_align. 1adc53b107 Merge pull request #1806 from KhronosGroup/fix-1777 21a15b90e5 Merge pull request #1804 from KhronosGroup/fix-1759 2714f5410c CFG: Handle degenerate selection constructs. e40d19bdbf MSL: Handle non-thread storage class in Modf/Frexp pointer versions. f1d4aff85e Merge pull request #1805 from KhronosGroup/fix-1776 2c53d30664 Merge pull request #1803 from KhronosGroup/fix-1802 4561ecddbd Handle Modf/Frexp in more cases. d295c2a046 Merge pull request #1800 from EddeDev/master 849978653a Merge pull request #1798 from billhollings/tess-output-clip 05e8e5a953 Correctly reflect declared buffer size for out of order members. 4dcf64a99b Fixed potential compilation error in spirv_cross_containers.hpp 250a02967d Removed unnecessary tracking of types. 4ebd56bf9e MSL: Correctly emit user(clip/cullN) for clip/cull builtins in tess output struct. f099d714f3 Removing logic in the parser 04293e03fd Merge pull request #1797 from KhronosGroup/clone-protocol 0d03516382 Always use https protocol when cloning external test deps. 061397e32e Merge pull request #1792 from billhollings/uniform-struct-packing-nested 3eb5532979 Add 64 bit support for OpSwitch be812c45e5 MSL: Remove over-zealous check for struct packing compatibility. 66adba17a8 Merge pull request #1791 from billhollings/msl-out-of-order-struct-offsets 76cb807c19 MSL: Fix type redirection when struct members are reordered to align with offsets. 29632959d2 Merge pull request #1787 from KhronosGroup/fix-1786 edf247fb1c MSL: Workaround compiler crashes when using threadgroup bool. 43eecb2360 SPIRV-Cross contribution needed for `INTEL_fragment_shader_ordering` 94dea2507e Merge pull request #1769 from audulus/spm2 f5219f47c3 Add Package.swift. 2a56c2bc04 Merge pull request #1783 from billhollings/more-unpacked-vectors ab640bc3d3 Merge pull request #1782 from KhronosGroup/fix-1781 974a0818b8 MSL: Support more usecases for unpacked vectors. 2b5e17eca5 MSL: Never used templated array for RayQuery objects. bc338710e1 MSL: Remove some redundant breaks. 5afb3d313f MSL: Fix some trivial bugs not caught by CI when adding ray query. 345a7d171c Merge pull request #1773 from congyue1977/master 2895a43274 Fix unsupported exceptions for ConvertUToAccelerationStructure & BindingTableRecordOffset. d52ec1e196 Fix all requested changes, test_shaders.py supports compiling MSL 2.4 shaders, and the Intersection Query currently only supports MSL 2.4 on the iOS platform. 6d13c99273 Merge pull request #1780 from billhollings/out-of-bounds-swizzle-fix 595eb0c21d Per spec, support undefined behavior for out-of-bounds swizzles. 597f29d09d Support Metal 2.4 Intersection Query, Implement GL_EXT_ray_query. e4243b898c Merge pull request #1766 from KhronosGroup/fix-1765 6382f15470 Test behavior around OpSelect with matrices. 6071df5840 Fix wrong detection of trivial_mix_op. 97a438d214 Merge pull request #1757 from KhronosGroup/fix-1754 f72bb3c6f5 Improve handling of INT_MIN/INT64_MIN literals. 457c00bd07 Merge pull request #1756 from KhronosGroup/fix-1753 91c25e8473 Merge pull request #1755 from KhronosGroup/fix-1751 9b2a8c7622 HLSL: Ensure synthetic NumWorkgroups variable is considered active. bb04156d3c CLI/HLSL: Don't set explicit binding for synthesized NumWorkgroups CBV. 96d95fbb31 MSVC: Workaround crtdbg macroing free(). 9462b90067 Merge pull request #1752 from billhollings/function-constants-opquantize 325f107c5b Merge pull request #1745 from billhollings/location-component-vecsize ec054dad7f MSL: Support synthetic functions in function constants. dee35bf3ce Merge pull request #1749 from billhollings/fastmath-quantize ba66a91402 MSL: Use vec<T, n> in template SpvHalfTypeSelector for function spvQuantizeToF16(). a2671e35b0 MSL: Consolidate spvQuantizeToF16() functions into a single template function. 5742047b24 MSL: Honor infinities in OpQuantizeToF16 when compiling using fast-math. 05ac99ae23 Merge pull request #1748 from billhollings/fastmath-nocontraction fb3defc9ef MSL: Honor DecorationNoContraction when compiling using fast-math. 548a23da34 MSL: Track location component to match vecsize between shader stages. fe1af2ae72 Merge pull request #1747 from KhronosGroup/ci-fix d579444a82 Merge pull request #1744 from billhollings/location-attribute-fix 6628e10fc6 Merge pull request #1746 from billhollings/fast-math-per-vulkan 3ca99bbbcc Remove tests for Ubuntu 16.04. 0f12557695 Remove obsolete Travis CI YML. 40141ffddf MSL: Selectively enable fast-math in MSL code to match Vulkan CTS results. 86dfac12c8 MSL: Fix location and component variable matching between shader stages. b81334a513 Merge pull request #1738 from billhollings/return-value-after-discard-terminator 2a150f5a2f MSL: Add explanatory comment requested in PR review. 35e92e6ffb MSL: Return fragment function value even when last SPIR-V Op is discard (OpKill). c2500e504d Merge pull request #1735 from billhollings/add-const-op-exprs 472f9d4f6d Add tests for OpSpecConstantOp ops OpQuantizeToF16 and OpSRem. 5fb1ca4f0d Add support for additional ops in OpSpecConstantOp. 51d8e7be94 Merge pull request #1734 from KhronosGroup/buffer-reference-uvec2 b8f1e71907 GLSL: Emit GL_EXT_buffer_reference_uvec2 as required. d6fe75df10 Merge pull request #1732 from KhronosGroup/fix-1731 23c4480d8e Fix switch fallthrough case in some cases. 0e2880ab99 Merge pull request #1729 from KhronosGroup/fix-1726 2eea6a579b MSL: Consider that function/private variables can be block-like. 840d4483bc Merge pull request #1728 from KhronosGroup/fix-1727 5b0cafb416 Track temporary access for OpArrayLength result. c062b6b852 Merge pull request #1725 from billhollings/fix-duplicate-glposition fad1590786 Merge pull request #1722 from billhollings/row-maj-mtx-store-from-const 27e7abeab1 Merge pull request #1724 from billhollings/msl-const-expr-casting e76fcf9309 MSL: Add test for fixes to MSL constant expression type down-casting. 3105e82b2e MSL: Fix duplicate gl_Position outputs when gl_Position defined but unused. a75fe07546 MSL: Fix casting in constant expressions with different sizes. 9552ca5473 MSL: Support row-major transpose when storing matrix from constant RHS matrix. bab4e5911b Merge pull request #1716 from KhronosGroup/terminator-access-fix cb613eb675 Handle value access in terminators. 1964799fba Merge pull request #1715 from KhronosGroup/precise-fp16-fp64 ac11a91792 GLSL: Emit precise for fp16/fp64 types as well. cd22336a38 Merge pull request #1712 from cdavis5e/msl-subgroup-ballot-simplify 03ad13bae6 MSL: Simplify spvSubgroupBallot(). 18f3cd6810 GLSL: Ensure ray query object decls are flushed if allocated in Function. e51630595f Merge pull request #1711 from KhronosGroup/fix-1690 5b227cc57c GLSL: Implement GL_EXT_ray_query. 6196e3b029 MSL: Remove redundant path for SampleMask. 2fcbef398c Merge pull request #1709 from billhollings/fix-sample-mask-in fe08bf4af4 Remove EXPERIMENTAL from JSON reflection backend. ebb5098def MSL: Adjust gl_SampleMaskIn for sample-shading and/or fixed sample mask. be3988b13c Merge pull request #1706 from SpaceIm/fix/ios-bundle a70ce5192e Merge pull request #1708 from KhronosGroup/fix-interpolant-access-chain 71b83a18f4 MSL: Add test for scalar access chain pull interpolant. d42c0b2e08 Merge pull request #1707 from billhollings/fix-interpolant-access-chain 3e04eee491 MSL: Fix setting SPIRVCrossDecorationInterpolantComponentExpr decoration. d74eaabde0 fix cross-build to iOS/tvOS/watchOS 1ae2b58f19 Merge pull request #1700 from pkasting/master bf746bd680 Merge pull request #1699 from KhronosGroup/pervertexnv 7cdab07efe Fix -Wunreachable-code-aggressive. 206ee8f171 GLSL: Support pervertexNV in NV barycentric extension. c5b8022e61 Merge pull request #1669 from KhronosGroup/1560-reuse1 54882ad16d Add GLSL.std.450.h to REUSE. 3781d49d7c .gitignore ignored new license text c862f8d22d Actually checkout repo into new reuse job f2a65545b8 Finish adding SPDX tags and setup a reuse checked in Github Actions CI 2ceca64004 Add missing copyright headers. 853e84e8bf Merge pull request #1698 from KhronosGroup/fix-1691 d6b29ab017 HLSL: Rewrite how block IO is emitted. 9338996f3b Merge pull request #1697 from KhronosGroup/fix-1693 3149095585 Merge pull request #1696 from KhronosGroup/fix-1694 d75666b170 GLSL: Emit num_views for OVR_multiview2. 8216e87f02 Handle SPIR-V 1.4 selection constructs. 9cdeefb5e3 Merge pull request #1692 from Kangz/fix_default_copy_dtor 6a85c695cc Fix IVariant -Wdeprecated-copy-with-dtor 2e1b5fb39e Merge pull request #1686 from KhronosGroup/fix-1684 fa42f1ce34 Merge pull request #1685 from KhronosGroup/fix-1683 449f68ef3b Ensure loop control flow hints only appear above loops. d62b3c2b92 GLSL: Implement control flow hints. 165dbff228 Handle odd type for textureGather component. 585fc6f3cb MSL: Always enable support for base vertex/index on iOS. a6ce49ca24 Merge pull request #1680 from xndcn/cc 02fb8f2a24 Add comment after inf/nan float number for clarifying. ff61890722 Merge pull request #1679 from okuoku/fix-c-sample-code 38c6ef1d56 Fix C sample code in README.md faec1a8643 Merge pull request #1678 from KhronosGroup/fix-1674 9ea0e8b859 Merge pull request #1677 from KhronosGroup/fix-1673 c87cb54499 MSL: Add CLI option for sampler suffix. bf3793dd35 MSL: Improve handling of split tessellation access chains. a6c9514856 Merge pull request #1676 from KhronosGroup/fix-1671 0214990e7c Merge pull request #1675 from KhronosGroup/fix-1670 26a4986009 GLSL: Implement noncoherent framebuffer fetch. 99ae0d32e9 MSL: Handle array with component when we cannot rely on user() attrib. a64ddcdd49 MSL: Handle array of IO variable with Component decoration. 418542eaef Merge pull request #1668 from KhronosGroup/fix-1665 b8115ffbe0 HLSL: Implement invariant as precise. e47a30e807 Honor NoContraction qualifier. 0eeaffe048 Merge branch '16-bit-int-types-glsl' 6dbab0df47 Update reference output. 0408c592dd Fixed 16 bit int types 72a2ec4c1b MSL: Fix '--msl-multi-patch-workgroup' out of bounds reads when dispatching more threads than control points (#1662) 995c7981cc Merge pull request #1663 from billhollings/metal-arg-buff-padding-patch 098cdd64f6 MSL: Padding for Metal argument buffers should not double-count SampledImages. c624d5387c Merge pull request #1660 from KhronosGroup/fix-1658 82a77e534e MSL: Use proper array for quad tess levels. b38e3b4a47 Merge pull request #1661 from KhronosGroup/fix-1659 0e963c62b6 HLSL: Support Shuffle wave ops. bbcef69a45 Merge pull request #1657 from KhronosGroup/fix-1607 532f65583e Rewrite how non-uniform qualifiers are handled. d137abeef5 Merge pull request #1655 from KhronosGroup/fix-1640 8e24e0b224 Merge pull request #1654 from KhronosGroup/fix-1641 71eb1754e3 Merge pull request #1653 from KhronosGroup/fix-1638 2cbc7f0f37 Merge pull request #1652 from KhronosGroup/fix-1644 b084f639cb Merge pull request #1651 from KhronosGroup/fix-1645 c89b5a1a3f GLSL: Support shading rate builtins. 3fd148450a GLSL: Implement gl_FragFullyCoveredNV. f93a8fb1fe GLSL: Support GL_EXT_shader_image_load_formatted. 90c70e6605 MSL: Handle variable access in OpSelect. 96ba044f01 HLSL: Fix automatic location assignment in block IO. 3cb8e7c223 Merge pull request #1643 from KhronosGroup/fix-1639 ae9ca7d73c MSL: Fix copy of arrays to/from stage IO variables. 986196030d MSL: Don't use native arrays for tess level inputs. 4a379a00f3 MSL: Don't emit native array for masked clip/cull distance. 406af8ff4d c: Add C API for builtin stage IO reflection. b4a380a04c Support reflecting builtins. 852f2da63c Check SPIR-V 1.4 rules when reflecting resources. 682a227f4b MSL: Make builtin argument type declaration context sensitive. c1edd35d57 MSL: Use spvUnsafeArray for builtin arrays after all. 7b9a591aa7 MSL: Hoist out to_tesc_invocation_id() in more places. 75ed73818c MSL: Handle loading Clip/CullDistance in TESE. a159334895 MSL: Correctly analyze if builtin block is active. cea934c03f MSL: Test that we can capture cull distance to buffer. 5826298697 MSL: Handle CullDistance better. 23da445bd4 MSL: Emit multiple threadgroup slices for multi-patch. b442500204 MSL: Unroll initializations of CullDistance/ClipDistance control points. c9946296dd MSL: Fix initialization of masked threadgroup variables. ee85bb345e Fix print_help comment. faf80b08fc MSL: Don't report fallback location allocations as being "used". adc5fe3615 C: Add C api for stage output masking. 5e9c2d060e MSL: Cleanup fallback IO block emission. e32c474911 MSL: Handle masking of TESC IO block members. dc54f75eec MSL: Fixup gl_PerVertex names if we're emitting masked builtins. 40f628f49c MSL: Add test for complex control point outputs. 46c48ee6b5 MSL: Rewrite how IO blocks are emitted in multi-patch mode. 425e968720 MSL: Handle flattening of patch block outputs as well. 8e2dbe0d38 MSL: Do not declare patch variables on stack. ff3f5bcba5 MSL: Handle masking of builtin control points. 6ecdd64a91 MSL: Emit a masked builtin IO block if necessary. 436b1250da MSL: Do not perform scalar fixups for control-point outputs. 22c9b63e78 MSL: Fix argument_decl check for builtin. c635c35c12 MSL: Temporarily allow empty output struct. a59e25db18 MSL: Small refactors. 74b2acab9b MSL: Always emit block variable for block types. ae7bb41ef4 MSL: Test that we can mask location writes in TESC. 3255d6cef0 MSL: Explicitly only consider masked variables to be thread-group-like. ba93b6518d MSL: Fix masking of vertex block outputs. a393de31e6 MSL: Refactor out variable/block member masking. 857295a9ab MSL: Add tests for masking with --for-tess. 43b6ea2c9a MSL: Remove position mask tests. They will fail compilation. e7b37392bf MSL: Emit correct address space for masked arguments. 65b5ff7ece MSL: Don't emit weird reference type for spvUnsafeArray types. e7824c8b6e MSL: Handle masked outputs in extract_global_variables. 50a6bc058a MSL: Force builtin arrays for builtin array types. 88b54f5dab MSL: Add tests for vertex output masking. 394c038bfd MSL: Do not consider effective storage for any composite. 04988b89b9 MSL: Handle effective storage for masked CP outputs. f2b5fb3f45 MSL: Emit threadgroup storage class for masked control point outputs. ea91579a7f MSL: Do not redirect tess access chains on masked outputs. 9c1cadd440 Add --mask-stage-output-* CLI options. f682e89188 MSL: Correctly emit array type for masked outputs. 2a2d57df13 MSL: Sketch out API to aid LTO-style optimization. 9a144bb2b9 Clean up member sorting. 0997e81118 MSL: Sort builtin IO block members by builtin type. b4aa6dacfa MSVC: Add /bigobj for debug builds. 45818c14e4 Merge pull request #1648 from billhollings/msl-pad-arg-buff-structs b3bfe22eaa MSL: Fixes to support padding Metal argument buffer entries based on argument index. daba0dfba6 MSL: Fixes to support padding Metal argument buffer entries based on argument index. 9060e5a13c MSL: Fixes to support padding Metal argument buffer entries based on argument index. 9866cf4496 MSL: Fixes to support padding Metal argument buffer entries based on argument index. 6c0e11f907 Merge branch 'master' of https://github.com/billhollings/SPIRV-Cross into msl-pad-arg-buff-structs 582749ac68 Merge pull request #1650 from Dredhog/active-builtins-c-api edde535574 c: Remove SPVC_PUBLIC_API prefix from API implementation 215f31b33f c: Add missing API to query active builtins. 17dab614dc MSL: Support padding Metal argument buffer entries based on argument index. d2e1e7ba98 Fix Github CI in PRs. 28ae7b8f35 Merge pull request #1642 from mehmetoguzderin/msl-long-ulong-member e2f7a753d2 Move condition to default block 0a0c9db9be MSL: Support long ulong types in buffers in 2.3+. 84d1f8aa2a Use Github actions CI tag. 2e000a0be4 Add GitHub Actions script. 60aa24566e Merge pull request #1633 from KhronosGroup/fix-1626 ee31e84e30 GLSL: Handle complex load/store scenarios to gl_SampleMask. fb1f295aaf Merge pull request #1635 from KhronosGroup/fix-1627 5d846acee5 Merge pull request #1634 from KhronosGroup/fix-1625 0ac70fa7ca Merge pull request #1632 from KhronosGroup/fix-1629 4ca06c7278 Handle edge cases in OpCopyMemory. aea6d29aa8 MSL: Add test for logical subgroup arith ops. d6c2c1b39a HLSL: Support logical subgroup ops. 5570043af3 GLSL: Add support for Logical subgroup ops. bc4cb1b3c5 Throw if SPIR-V module has no entry points. d57ab68a21 Merge pull request #1630 from KhronosGroup/fix-1628 97796e0609 MSL: Deal with pointer-to-pointer qualifier ordering. 621884d709 Merge pull request #1622 from KhronosGroup/fix-1619 da238e5f12 Merge pull request #1623 from phuang/patch-2 c66a571057 Add two missing source files b1e36a1f78 Merge pull request #1621 from KhronosGroup/fix-1618 85704f70bc MSL: Handle load and store to TessLevel array in TESC. ce552f4f91 MSL: Gracefully assign automatic input locations to builtin attributes. aa271c1460 MSL: Refactor out location consumption count computation. 6f1f6775f3 Add comment where aux image atomic buffers are reflected from. 92d379bab4 Merge pull request #1620 from phuang/patch-1 bc3416a18f Fix build errors on Windows bae17e8204 Merge pull request #1617 from KhronosGroup/fix-1608 5789e3eed9 Merge pull request #1616 from KhronosGroup/fix-1609 daddbd4078 MSL: Fixup type when using tessellation levels in TESC functions. 0ad12a0036 MSL: Always return [[position]] when required. 05a1a07f70 Merge pull request #1615 from KhronosGroup/fix-1612 09dc76f68a c: Add missing IOS_SUPPORT_BASE_VERTEX_INSTANCE option. 8f5ab50fb8 Merge pull request #1614 from KhronosGroup/fix-1610 21a931613e HLSL: Add vector to illegal names list. 4741bbaa64 Merge pull request #1606 from billhollings/position-invariance 8e03cb60a5 Expose position invariance. 84a41cd488 Merge pull request #1603 from KhronosGroup/small-improvements ea02a0c03a Check entry point variables in is_hidden_variables. 4bedad3860 Handle nonuniformEXT qualifier for acceleration structures. 7ab3f3f74e Deal better with CompositeExtract from constant composite. 66fb0bd9df GLSL: Handle tracing against incoming payload/callable. 9acb9ec31f Merge pull request #1594 from KhronosGroup/fix-1591 a5eaf2f44a Merge pull request #1595 from KhronosGroup/copyright-update 4704482bbc meta: Update copyright headers to 2021. 4c866e4662 Fix pathological complexity explosion for certain shaders. 820179bf46 Merge pull request #1590 from KhronosGroup/fix-1584 2097c30985 GLSL: Support both SPV_KHR_ray_tracing and NV_ray_tracing. 702c903f98 Merge pull request #1589 from KhronosGroup/roll-deps ce18d1b8a5 CLI: Fix silly regression with handling of -V. 5d82d32e0f Roll dependencies. 0e5078dc0c Merge pull request #1588 from KhronosGroup/fix-1582 893a011299 MSL: Fix various bugs with framebuffer fetch on macOS and argument buffers. 3136e34215 MSL: Always use input_attachment_index for framebuffer fetch binding. 134a520034 Merge pull request #1587 from KhronosGroup/refactor-active-variable-consideration 03ee71e86c Add test for pure initializer gl_FragDepth. 3776d8978c GLSL: Force block declaration if clip/cull is used in tesc. 014b3bc5ea MSL: Make sure initialized output builtins are considered active. a4a9b53b5b MSL: Always enable Outputs in vertex stages. fa76d01203 MSL: Only consider builtin variables if they are part of IO interface. c8837d7d80 MSL: Very slight refactor. 234c65c0f3 Merge pull request #1585 from KhronosGroup/fix-1569 72e9f619a9 Merge pull request #1583 from KhronosGroup/fix-1567 42ec132357 Merge pull request #1581 from KhronosGroup/fix-1554 c033a93951 GLSL: Fix -Wshadow error. 1a28a04333 GLSL: Update SPIR-V headers for modified ray tracing opcodes. 02b7f9cbe9 CLI: Add stdin support. efed4c9738 MSL: Fix initializer for tess level outputs. ab9200ffdf MSL: Don't flatten builtin arrays unless they're part of IO interface. df4f8ef8fe MSL: Emit correct initializer for tessellation control points. ad3e1584f9 MSL: Handle initializers for tess levels. 39fee93906 GLSL: Refactor out Output variable initialization. 6a3ea0385e GLSL: Add test for initializing tess level output. 175381fe08 GLSL: Handle some extreme edge cases in Output variable initialization. 7b7a21c405 Merge pull request #1578 from KhronosGroup/fix-1568 1a38fec382 Minor redundant nit. a1c784f002 More robust handling of initialized output builtin variables. 9a304fe931 Handle output IO block initializers more robustly. 49ab12919c Merge pull request #1577 from KhronosGroup/fix-1574 3514c9ff33 Merge pull request #1576 from KhronosGroup/fix-1571 3a85d1c80c CMake: Disable compiler extensions explicitly. ddb3c65648 Handle reserved identifiers for functions. c4ff129fe3 MSL: Handle reserved identifiers for entry point. e50f7d1ce8 Merge pull request #1566 from KhronosGroup/subgroup-table-fix c8765a75f2 GLSL: Fix KHR subgroup extension table for subgroups. 762c3082ae Merge pull request #1564 from KhronosGroup/fix-1558 1eb42eb18c Merge pull request #1563 from KhronosGroup/fix-1559 a11c4780d0 GLSL: Emit nonuniformEXT in correct place for late-combined samplers. dc940846d7 GLSL/HLSL: Disallow VariablePointers capability outright. 6d10da0224 Merge pull request #1553 from comex/no-subgroups-in-vertex-shaders f41b59b36e Merge pull request #1557 from KhronosGroup/mit-dual-license-api cf1e9e0643 Add MIT dual license for the SPIRV-Cross API. 0b79db773f Merge branch 'master' of git://github.com/js6i/SPIRV-Cross c09a65c12d MSL: Added fmin3 and fmax3 library functions to the illegal name list. 5a85fa9400 msl: Don't try to use [[thread_index_in_simdgroup]] in vertex shaders. be527632a6 Merge branch 'unused' of git://github.com/comex/SPIRV-Cross c80cbde7aa spirv_msl: Don't add fixup hooks for builtin variables if they're unused. 3d16060c32 Merge pull request #1551 from cdavis5e/msl-subgroup-inactive-ballot-mask 1e67b21ee9 MSL: Don't mask off inactive bits in ballot masks. 1f178be3c9 Merge branch 'msl-sample-rate-position' of git://github.com/cdavis5e/SPIRV-Cross fd738e3387 MSL: Adjust FragCoord for sample-rate shading. 782916a797 Merge pull request #1549 from KhronosGroup/various-fixes e07f0a9df5 GLSL: Fix buffer_reference with aliased names. c5826b4b69 GLSL: Emit storage qualifiers for buffer_reference. 650b5e1b12 HLSL: Fix validation with FXC for test. 6a614cc7f7 Normalize all internal workaround methods to use spv prefix. 35d3b9c3e7 Merge branch 'msl-subgroup-ops-2' of git://github.com/cdavis5e/SPIRV-Cross dabdf4eff6 Merge pull request #1547 from scribam/cmake-minimum-required 1eb4852856 CMake: Set minimum required version to 3.0 68908355a9 MSL: Expand subgroup support. 58291963c6 Merge branch 'glsl-vertex-attrib-64bit' of git://github.com/rdb/SPIRV-Cross df5e3730ca GLSL: Require GL_ARB_vertex_attrib_64bit for double input in pre-4.10 b3c59263a0 Merge pull request #1541 from cdavis5e/msl-ios-features 88e25e60ec MSL: Expose some more features on iOS. 1ee2d13873 MSL: Add missing reference file. ef0256c23e Fix switch fallthrough 0d6fad4ab9 Merge branch 'extract_subgroup_ops' of git://github.com/js6i/SPIRV-Cross 9c2c0a23b9 Merge pull request #1533 from rdb/texture-fetch-size-fallbacks 10fa5f62aa GLSL: Legacy / extension fallbacks for textureSize and texelFetch f0239bce05 MSL: extract global variables from subgroup ballot operations 6fc2a0581a Run format_all.sh. 71fcf0d9e6 Update texture gather test result. 008f3baad7 Merge branch 'arb-texture-gather' of git://github.com/rdb/SPIRV-Cross 46bf1e99d6 Merge pull request #1525 from cdavis5e/msl-interpolation-functions 509908d8db GLSL: Add error checking and extension fallback for textureGather 683c3f5c3f Merge pull request #1530 from rdb/legacy-glsl-round ea334c14bc Merge pull request #1527 from rdb/legacy-transpose 2417010046 Merge pull request #1528 from rdb/fix-legacy-vertex-shader-lod 1648747fa7 Merge pull request #1529 from KhronosGroup/fix-msl-gather-regression b3bd674aa7 GLSL: Remove unused `lod` argument from legacy_tex_op() bf71994dae GLSL: implement transpose() in GLSL 1.10 / ES 1.00 9e6e5d2738 GLSL: Fix round/roundEven for legacy GLSL. e8c500ceef GLSL: Fix support for textureLod in legacy vertex shaders db13762297 MSL: Fix regression in image gather handling. aca9b6879a MSL: Support pull-model interpolation on MSL 2.3+. a20c768698 Merge pull request #1524 from rdb/hlsl-round-even 854f566869 HLSL: Support roundEven() in HLSL SM 4.0 and above 2e1bdeb212 Merge pull request #1520 from rdb/dx9-dref-samplers 135933d59e HLSL: Add regression test for SM3.0 texture samplers 18893ba3b9 HLSL: Support depth comparison texture sampling in SM 2/3. fc644b50e6 Merge pull request #1523 from KhronosGroup/fix-1512 512e851185 Merge pull request #1522 from KhronosGroup/fix-1510 b3344174f7 HLSL: Add option to flatten matrix vertex input semantics. 1f018b0fb8 Parser: Don't assume OpTypePointer will always take a SPIRType. 244839d350 Merge pull request #1516 from billhollings/VK_EXT_descriptor_indexing 4bdd49df3f Syntax and format updates from code review. c5a3f37a1c Merge pull request #1519 from cdavis5e/msl-mac-comparison-bias-grad dcd66c283c Merge pull request #1521 from devshgraphicsprogramming/master 6402586015 Updated ref file for subgroups_basicvoteballot.vk.comp 9a1af25f02 Merge pull request #2 from KhronosGroup/master 6c5f394b09 Fix some bad assumptions about emulating `subgroupBarrier` 7f67abe0fe Minor format and typo updates from code review. 547c29f7bb MSL: Allow Bias and Grad arguments with comparison on Mac in MSL 2.3. 8884b34940 Merge pull request #1517 from atyuwen/master 303f813166 Merge pull request #1518 from KhronosGroup/fix-nonuniform-bracket-handling 439b666829 GLSL: Fix nonuniformEXT injection. 871a023877 fixed compile error with -std=c++20 541a801fed Merge pull request #1514 from cdavis5e/msl-mac-framebuffer-fetch c8a43876c7 added metal keyworld: "level" (#1501) b7b0e804e5 MSL: Support run-time sized image and sampler arrays (GL_EXT_nonuniform_qualifier/SPV_EXT_descriptor_indexing). c20d5945a2 MSL: Allow framebuffer fetch on Mac in MSL 2.3. 78c6d2d628 Merge pull request #1509 from cdavis5e/mac-post-depth-coverage 08e49bfd67 Merge pull request #1508 from KhronosGroup/fix-1507 346b0b6c21 Merge pull request #1493 from KhronosGroup/ubo-row-major-load-workaround d48d2a95c7 MSL: Allow post-depth coverage on Mac in MSL 2.3. 542d460364 Handle case where block is loop header, continue AND break block. e47561a28b GLSL: Support a workaround for loading row-major matrices. 5ae9153a78 Merge pull request #1505 from cdavis5e/msl-vertex-writes 1b6b9705e6 MSL: For 2.1+, don't disable rasterization for vertex writes. 1a95017d11 Merge pull request #1503 from KhronosGroup/travis-python-update b3a74f3a22 Merge pull request #1504 from KhronosGroup/fix-1502 f65f259ab7 MSL: Do not use component::x gather for depth2d textures. 1d68cbfb1b Update TravisCI python reference. dd35821f2f Merge pull request #1499 from cdavis5e/subgroup-fixes 1264e2705e MSL: Cast broadcast booleans to ushort. 065b5bda3c MSL: Mask ballots passed to Ballot bit ops. 781367d083 MSL: Support vectors with OpGroupNonUniformAllEqual. 6ccb902462 MSL: Correct definitions of subgroup ballot mask variables. a57b4b1b2e Merge pull request #1498 from cdavis5e/msl-swizzle-arrayed-nonconstant 064ed448b9 MSL: Don't remove periods from swizzle buffer index exprs. 7b80307a7d Merge pull request #1495 from cdavis5e/1d-2d-offset-grad 5845e009ea MSL: Handle Offset and Grad operands for 1D-as-2D textures. 0db1569e97 Merge pull request #1492 from KhronosGroup/non-native-matrix-fix 9c220a8247 Merge pull request #1490 from KhronosGroup/fix-1488 23a0cfc842 Merge pull request #1494 from cdavis5e/msl-tesc-tess-level-cast 3e6010d8c5 MSL: Don't use a bitcast for tessellation levels in tesc shaders. 120af42616 GLSL: Use need_transpose when checking for non-native matrix. bd1ee4344e MSL: Support querying and modifying generated combined sampler suffix. 7332b44c3c Merge pull request #1489 from cdavis5e/msl-fix-atomic-image-coord 21d38f74ce MSL: Fix calculation of atomic image buffer address. e827a06984 Merge pull request #1487 from cdavis5e/msl-atomic-image-interlock 7a5d0d6b29 MSL: Add missing interlock handling to atomic image buffers. fab6ad234e Merge pull request #1486 from cdavis5e/atomic-image-argument-buffer cc7aabce72 Merge pull request #1485 from cdavis5e/msl23-demote-to-helper 9cafea6cf8 MSL: Support atomic access to images from argument buffers. 2219c4a392 MSL: Support SPV_EXT_demote_to_helper_invocation for MSL 2.3. 401af49326 Merge pull request #1482 from KhronosGroup/gl-subgroup-merge 5619329665 Style nits for GL subgroup implementation. a6f6547cf1 Add missing VK variant of the test file. 28994a3186 Update GL subgroup test file. 819c599ecd Merge branch 'issues1350-2' of git://github.com/devshgraphicsprogramming/SPIRV-Cross into master db52e277b9 Resolved issues 1350, 1351, 1352 5cc2e4f634 Merge pull request #1475 from KhronosGroup/fix-1474 e0c9aad934 GLSL: Add support for transform_feedback3 geometry streams. 7a99d1cb72 GLSL: Use literal array size for cull/clip array sizes. e6f5ce6b89 Merge pull request #1471 from KhronosGroup/fix-1467 6254be910e Merge pull request #1470 from KhronosGroup/fix-1469 34a6a45fba Work around MSVC warning. 5ea576ece2 Allow flip_vert_y in all relevant stages. ea3cd74426 Merge pull request #1468 from dj2/roll-09-22 9880b05572 Roll dependencies. 8891bd3512 Merge pull request #1466 from KhronosGroup/fix-1465 2144274a91 Clean up conditional branch codegen. 54cc0b01f6 Deal with case where a selection construct conditionally merges/breaks. 16d9fea77c Merge pull request #1463 from KhronosGroup/fix-1462 66afe8c499 Implement a simple evaluator of specialization constants. bdbef7b1f3 Merge pull request #1461 from Kangz/fix-warnings bcd71536e2 Fix -Wduplicate-enum and -Wrange-for-analysis. ba2d0e17d3 Merge pull request #1460 from KhronosGroup/fix-1458 446596643a Roll glslang/SPIRV-Tools deps. 18d03b3ea6 Handle OpUndef %void. bad9dab8df Merge pull request #1457 from cdavis5e/msl-layered-subpass-data 4cf840ee7b MSL: Support layered input attachments. c7507e39d4 Merge pull request #1456 from KhronosGroup/fix-1455 3360daa6f3 MSL: Fix OpCompositeInsert and OpVectorInsertDynamic. 9e3dbdc8d6 Merge pull request #1454 from cdavis5e/msl-multiview-non-layered cab7335e64 MSL: Don't set the layer for multiview if the device doesn't support it. 4752a44f9e Merge pull request #1453 from cdavis5e/msl-multiview-base-instance 53080ecca8 MSL: Fix multiview view index calculation with a non-zero base instance. 685f86471e Merge pull request #1452 from KhronosGroup/minor-nits 95993f78af Run format_all.sh. ee1b4e7042 Work around annoying warning on GCC 10.2. eec76b04c7 Merge pull request #1450 from KhronosGroup/fix-1440 a07441568e Overhaul how we deal with reserved identifiers. f0fe4442e3 Merge pull request #1448 from KhronosGroup/fix-1437 4f0f0e5a07 Merge pull request #1449 from KhronosGroup/fix-1443 fdbc80d131 HLSL: Fix FragCoord.w. fad36a6b28 HLSL: Deal with partially filled 16-byte word in cbuffers. dd1f53ff15 HLSL: Fix bug in is_packing_standard for cbuffer. 4c7944bb42 Merge pull request #1446 from kakashidinho/master ab8eb70af1 Fix #1445: MSL: Enclose args when convert distance(a,b) to abs(a-b) 82d1c43e40 Merge pull request #1441 from cdavis5e/msl-tesc-composite-out 3347b1076d MSL: Fix handling of matrices and structs in the output control point array. c333445ada Merge pull request #1436 from KhronosGroup/fix-1408 8a1843ab20 Add some test cases for complex type aliasing scenario. eb580d6656 Ensure that we use primary alias type when emitting flattened members. aac6885950 GLSL: Be more aggressive about using type_alias. 038b0bf238 Only rewrite type aliases for the base type. 7778792aec Merge pull request #1434 from KhronosGroup/glsl-force-flattened-io 57c93d44ac GLSL: Add option to force flattening IO blocks. f5e9f4a172 Merge pull request #1432 from ponitka/hlsl-sample-mask ba58f78395 Adding BuiltInSampleMask in HLSL 0376576d2d Merge pull request #1429 from ponitka/master 18f23c47d9 Enabling setting a fixed sampleMask in Metal fragment shaders. 934825a6a2 Merge pull request #1294 from cdavis5e/msl-multi-patch-workgroup 688c5fcbda MSL: Add support for processing more than one patch per workgroup. 3dcc23a5b3 Merge pull request #1431 from dj2/roll-07-22 ac08a89cf0 Merge pull request #1430 from cdavis5e/msl-refactoring c4f3d4ae29 Roll GLSLang, SPIRV-Headers and SPIRV-Tools. 884bc6df65 MSL: Factor creating a uint type into its own method. 5e13f7fdf2 MSL: Factor a really gnarly condition into its own method. 6575e451f5 Merge pull request #1423 from KhronosGroup/msvc-2013-fix 36c999ae3f MSVC 2013: Fix silently broken builds. 39ce5b46de Merge pull request #1421 from troughton/patch-3 b74a84e4cb MSL: Ensure OpStore source operands are marked for inclusion in function arguments 559b21c6c9 Merge pull request #1420 from dj2/roll-07-06 63fbdaca93 Roll deps. 3b366db7f1 Merge pull request #1416 from KhronosGroup/fix-1415 711300baed MSL: Do not emit swizzled writes in packing fixups. fa5b206d97 MSL: Workaround broken vector -> scalar access chain in MSL. fab75792a9 Merge pull request #1419 from KhronosGroup/msl-input-attachment-index-fallback e1600d4df8 MSL: Use input attachment index directly for resource index fallback. c465cd5004 Merge pull request #1417 from KhronosGroup/fix-351 2ac8f51b06 GLSL: Support I/O flattening with arrays as final type. 2d43103a55 GLSL: Support multi-level struct flattening for I/O. d573a95a9c Run format_all.sh. 8f716947c2 test: Use --hlsl-dx9-compatible when attempting to compile SM 3.0 shaders. 2894b40868 Merge pull request #1412 from KhronosGroup/fix-1411 70f17142de GLSL: Fix nested legacy switch workarounds. b1082c10af Merge pull request #1410 from KhronosGroup/fix-1406 42096ca4a1 Merge pull request #1409 from KhronosGroup/fix-1405 4d79d634f5 GLSL: Implement switch on ESSL 1.0. bae76d7915 GLSL: Use for-loop fallback instead of do/while for legacy ESSL. 3afbfdb090 Implement context-sensitive expression read tracking. 05188aca69 Fix bug with control dependent expression tracking. 2e7a562583 Merge pull request #1404 from KhronosGroup/fix-1402 eb0f0323d3 HLSL: Workaround FXC bugs with degenerate switch blocks. f9ae06512e Merge pull request #1401 from dj2/roll-deps-22 9eb615c63b Merge pull request #1400 from KhronosGroup/fix-1399 0abc017501 Roll deps and update tests. f9da366ae6 MSL: Remove the old VertexAttr API. 7edaea87cf Merge pull request #1398 from Kangz/fix-deprecation 6add77aa97 Merge pull request #1397 from KhronosGroup/fix-1396 8aee532f56 Fix placement of SPIRV_CROSS_DEPRECATED. f141521ebe Fix duplicated initialization for loop variables with initializers. d7976b7b24 Merge pull request #1395 from KhronosGroup/fix-1394 ace4d25222 MSL: Add test case for constructing struct with non-value-type array. 7314f51a32 MSL: Deal with loading non-value-type arrays. 02db4c1f16 MSL: Add tests for array copies in and out of buffers. 03d4bcea68 MSL: Improve handling of array types in buffer objects. 11832b6e14 Clean up some deprecation warnings when building with Makefile. 5e509b159a Remove unused member in MSLShaderInput. a64484f62b Merge pull request #1392 from cdavis5e/msl-frag-input-vecsize 5281d9997e MSL: Fix up input variables' vector lengths in all stages. 7073ed2edb Merge pull request #1393 from KhronosGroup/fix-1391 d13dc0ce47 HLSL: Fix texProj in legacy HLSL. 9e3df69d4e Merge pull request #1390 from rdb/master 031cbaa5a2 GLSL: Require GL_ARB_draw_instanced for gl_InstanceID in GLSL < 1.40 92fcd7d2b0 Merge pull request #1389 from KhronosGroup/sparse-clamp f383cc98f2 GLSL: Handle the rest of GL_ARB_sparse_texture_clamp. bbefea2b02 Merge pull request #1388 from KhronosGroup/uint-sparse-residency-query 857e1c445c GLSL: Support uint code for sparse residency query. 553a7f959b Merge pull request #1385 from KhronosGroup/fix-1237 cbe0cca73b Refactor texture fetch function generation. b73c047faf Merge pull request #1387 from Lichtso/master 1f5875e23e Fix missing switch cases in Y'CbCr conversion 3ce81c0025 Merge pull request #1384 from KhronosGroup/fix-1380 757c10bbe4 Merge pull request #1383 from KhronosGroup/fix-1381 275974e062 GLSL: Implement sparse feedback. 6600793884 MSL: Remove obsolete MSLVertexAttr members. 2d5200650a HLSL: Add native support for 16-bit types. d385bf096f Merge pull request #1378 from bbernhar/issue_410 32bead81c8 Prefer set/binding API 999a7b5256 Merge pull request #1379 from KhronosGroup/fix-1377 165392a2b0 Document all CLI options. d31bc0247e Do not mask writes to remapped variables in all cases. 17bccc9f7e HLSL: Add option to treat certain SSBO bindings as UAV, even with readonly. 61cddd6307 Merge pull request #1376 from KhronosGroup/fix-1374 58dad82fcb Handle physical pointers in reflection API. f992548434 Merge pull request #1372 from KhronosGroup/gl-draw-parameters ef247e75ec GLSL: Improve support for GL_ARB_shader_draw_parameters in desktop GLSL. ec558bc98e Merge pull request #1371 from dj2/roll-deps-21 3d01d1bf50 Roll SPIRV-Tools, SPIRV-Headers and GLSLang. 287e93ff80 Merge pull request #1370 from dj2/roll_deps_20 29ad40e93e Merge pull request #1369 from KhronosGroup/more-rt-tests 8bf916f575 Roll dependencies b4dd0b6fb1 GLSL: Add more test shaders for hit attribute types. 66ec3e3e54 GLSL: Support ray payloads and hit attributes declared as Block. 271ad33380 GLSL: Add some more focused RT test shaders. 3c43f055df Merge pull request #1366 from KhronosGroup/fix-1365 f3a362b1aa HLSL: Implement image queries for UAV images. d638d2df9c Merge pull request #1363 from KhronosGroup/rt-gl-instance-id 86380acf4d Support gl_InstanceID in RT shaders. b7823ec389 Merge pull request #1361 from KhronosGroup/msl-single-element-array-refinement 107ab7c2b7 MSL: Avoid packed arrays in more cases. de3698f0e0 Add missing reference files from PR merge. b8ba89a1ac Merge branch 'master' of git://github.com/kakashidinho/SPIRV-Cross 9ddfe6db6d Fix #1359: MSL: If the packed type is scalar, don't emit "pack_" prefix. 92f7d36c72 Merge pull request #1356 from KhronosGroup/fix-1354 0ebb88cc39 MSL: Redirect member indices when buffer has been sorted by Offset. 137dbeb7f1 Merge pull request #1355 from Kangz/fix-microsoft-enum-value a3a590a82e Fix -Wmicrosoft-enum-value 7e0295abf8 Merge pull request #1353 from zoddicus/updateSPIRVHeaders 76658247ac Update SPIR-V Headers to 1.5 rev 3 471990d4dc Merge pull request #1349 from KhronosGroup/fix-1348 35a9b793d6 Work around odd deadlock in test_shaders.py in --parallel mode. d7d630a0b7 Merge pull request #1347 from KhronosGroup/fix-1343 4330b046be Merge pull request #1346 from KhronosGroup/fix-1340 9b7140e2ba Implement OpAtomicLoad/OpAtomicStore. cbaaa02af9 Merge pull request #1345 from apayen/master 6ef47d6657 MSL: Fix case where subpassInput is passed to leaf functions. 4edfe96739 Fixed recursion in combined_decoration_for_member Members in nested structs were not properly iterated on, and as a result, flags like row major for matrices could be not propagated properly. 7ba0f8f087 Merge pull request #1342 from dj2/roll 171c646474 Roll GLSLang, SPIRV-Tools and SPIRV-Headers. 1ad1662a2b Merge pull request #1339 from KhronosGroup/fix-1338 5e5d1c27ce GLSL: Support f16x2 <-> f32 bitcast. c58839bfd4 Merge pull request #1336 from KhronosGroup/fix-1333 bf289c37a2 Merge pull request #1337 from KhronosGroup/nonuniform-propagation-fix bdb343ea06 Be a bit more careful what nonuniform state is propagated. 6b0e558169 Handle RayQueryKHR type. 78b4d9379b Update SPIR-V headers. b2e934b53f Merge pull request #1328 from devshgraphicsprogramming/patch-1 5cb0f0a640 Merge pull request #1335 from KhronosGroup/fix-1325 127224d816 Fix issue #1327 58548e25a2 Merge pull request #1334 from KhronosGroup/fix-1332 7b9cba7424 HLSL: Add parens in unpackUint2x32 for clarity. e4e4791c4e HLSL: Only allow 64-bit integers in SM 6.0. a396744f89 Ensure unpack/pack2x32 tests are compatible with test suite. 55dfbead2f GLSL/HLSL: Support packUint2x32 and unpackUint2x32 f8592ecdfc MSL: Deal correctly with initializers on Private variables. 3fb86e4385 Merge pull request #1331 from KhronosGroup/fix-1321 17ad62eea4 MSL: Support edge case with DX layout in scalar block layout. f38cbeb814 Merge pull request #1330 from KhronosGroup/fix-1320 ebf463674d MSL: Allow removing clip distance user varyings. aa5fbc004b Merge pull request #1329 from godlikepanos/master b3109b8ad0 Reflection: Add specialization constant name 90198199df Merge pull request #1324 from cdavis5e/msl-disabled-builtin-names 96f7008aa8 MSL: Force disabled fragment builtins to have the right name. fbc560782c Merge pull request #1323 from cdavis5e/msl-disable-frag-only 495e48de44 MSL: Only disable output variables in fragment shaders. 54658d6255 Merge pull request #1319 from cdavis5e/msl-frag-outputs b29f83c383 MSL: Add options to control emission of fragment outputs. fcbc590937 Merge pull request #1316 from Malacath-92/master 4560ee24fd Improve compatibility with clang-cl a1d9b474b5 Merge pull request #1314 from KhronosGroup/fix-1313 c7b75a8fe6 MSL: Do not use base expression with PhysicalTypeID OpCompositeExtract. 6637610b16 Merge pull request #1309 from KhronosGroup/fix-1305 941cceedb4 Expose a query if samplers or images are comparison resources. b691b7d1e3 Do not add NonWritable/NonReadable decorations for regular images. 14f24d71ab Merge pull request #1308 from KhronosGroup/fix-1306 cfcd84319b Merge pull request #1310 from KhronosGroup/msl-force-declare-implicit-builtins d9d3359ffb MSL: Deal with cases where builtin is implicitly needed, declared, but unused. 01cee74b02 Merge pull request #1307 from troughton/patch-1 28bf9057df HLSL: Add support for treating NonWritable UAV texture as SRV instead. 4cf736d753 MSL: mark BuiltInFragCoord as implicitly used for subpass reads e58e8d5dbe Merge pull request #1303 from KhronosGroup/fix-1302 3cb6aeb480 MSL: Fix access chain for deep struct hierarchy on array of buffers. 84ec99c531 Merge pull request #1301 from dj2/roll_deps 32307df73a Roll GLSLang, SPIRV-Tools and SPIRV-Headers 9b3c5e12be Merge pull request #1299 from KhronosGroup/fix-1298 b8905bbd95 Add support for forcefully zero-initialized variables. 871c85d7f0 Merge pull request #1297 from KhronosGroup/fix-1295 04e877df12 GLSL: Implement GL_EXT_shader_framebuffer_fetch. c2655ab291 Run format_all.sh. c3d216c011 Merge pull request #1296 from KhronosGroup/fix-1292 05004a57ea GLSL/HLSL: Fix nonuniform qualifier for SSBO atomics. a3d3c80dd7 GLSL/HLSL: Implement nonuniform qualifier for image atomics. 65aa0c35d6 include/spirv_cross: Fix typo. 7d42fd7f7b Merge pull request #1290 from KhronosGroup/fix-1289 185551bfaf HLSL: Do not emit globallycoherent for SRV ByteAddressBuffer. d19f30a90e Merge pull request #1287 from KhronosGroup/read-write-decoration-tweaks 95cd20f1c7 Add test for disable-storage-image-qualifier-deduction. c27e1efbf1 HLSL: Add option to always treat SSBO as UAV, even with readonly. 01968c4486 Add option to disable storage image qualifier deduction. 3ebc83da46 Remove old hack which forces NonWritable/NonReadable. 9deb6ffbba Merge pull request #1285 from KhronosGroup/vulkan-semantics-shorthand 3f2de0d5d3 Add -V alias for --vulkan-semantics. c5f7b55756 Merge pull request #1284 from KhronosGroup/fix-1282 16796e92be MSL: Add C API for force native arrays. d91e134500 MSL: Add native array test for composite array initialization. 30343f3e95 MSL: Reintroduce workaround for constant arrays being passed by value. 20b28f72fa MSL: Reinstate workaround for returning arrays. c9d4f9cd74 MSL: Add a workaround path to force native arrays for everything. f19fdb94d7 Merge pull request #1283 from dj2/roll 7ec16b64c8 Roll GLSLang, SPIRV-Tools and SPIRV-Headers dffd33dd9d Merge pull request #1280 from KhronosGroup/fix-1278 92a4294c57 Reject SPIR-V modules with garbage ID bound. c53b34765d Merge pull request #1277 from KhronosGroup/fix-1276 e81c1b1d98 HLSL: Declare undef variables as static. 7ac5c38838 Merge pull request #1275 from KhronosGroup/fix-1274 cec0502ba5 Remove old memory_scope flag from iOS barriers. 6b2add8e2c Merge pull request #1272 from KhronosGroup/fix-1271 6f5cb00148 Use GNUInstallDirs for include path as well. cb0aca91ef Merge pull request #1273 from orbea/cmake 8b90526911 cmake: Don't hardcode the pkg-config file. 74544caa16 cmake: Use GNUInstallDirs. d67c3393da CMake: Avoid warning when parent project uses VERSION in project(). 68bf0f824c Merge pull request #1270 from KhronosGroup/fix-1266 dfffbb1cf3 Compile fix on older compilers. 655312cb47 GLSL: Support GL_ARB_enchanced_layouts for XFB. 306cb31bad Merge pull request #1239 from cdavis5e/msl-inline-uniform-blocks ae6c05f6f4 MSL: Move inline uniform blocks to the end of the argument buffer. fedbc35315 MSL: Support inline uniform blocks in argument buffers. f9376058ce Merge pull request #1269 from KhronosGroup/fix-1267 8bbb5fb763 Make SmallVector noexcept. 883de24f79 Merge pull request #1268 from barath121/patch-1 eac76d9473 Typo at line 324 f9818f0804 Update license headers to 2020. 7a411258af Run format_all.sh. af787a8a79 Merge pull request #1264 from KhronosGroup/msl-argument-buffer-persist 4054d650cf Merge pull request #1263 from KhronosGroup/fix-1232 c3bd136df1 MSL: Add support for force-activating IAB resources. f79c1e2fed Deal with illegal names in types as well. 79700d5412 Merge pull request #1262 from KhronosGroup/json-reflection-improvements 57b70225ef Merge pull request #1261 from KhronosGroup/fix-379 762c87a7bb Reflection: Add array stride/matrix stride reflection. 18e24c3ca2 Reflection: Emit reflection information for array size literalness. 55fe6050fe GLSL: Implement geometry shader passthrough extension. 172e39f039 Merge pull request #1257 from KhronosGroup/fix-1236 74107a04d1 Merge pull request #1256 from KhronosGroup/fix-1252 cc153f8d7f HLSL: Add a resource remapping API similar to MSL. 2bbb012e9c MSL: Deal with sign on wave min/max. 88ddeec49a HLSL: Deal with casting for WaveActiveMin/Max. 5253da9e63 GLSL: Deal with sign in subgroup Min/Max operations. 34ba8ea4f2 Merge pull request #1255 from KhronosGroup/fix-1254 c256525c7b Run format_all.sh. 1cbd71b354 HLSL: Fix bug when reading and writing structs from SSBO. 151ff1e870 HLSL: Implement stores for complex composites in ByteAddressBuffers. ca9398c122 HLSL: Su… * Build fix with new SPIRV-Cross * WiiU build fix with new SPIRV-Cross
2778 lines
87 KiB
C++
2778 lines
87 KiB
C++
/*
|
|
* Copyright 2019-2021 Hans-Kristian Arntzen
|
|
* SPDX-License-Identifier: Apache-2.0 OR MIT
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
/*
|
|
* At your option, you may choose to accept this material under either:
|
|
* 1. The Apache License, Version 2.0, found at <http://www.apache.org/licenses/LICENSE-2.0>, or
|
|
* 2. The MIT License, found at <http://opensource.org/licenses/MIT>.
|
|
*/
|
|
|
|
#include "spirv_cross_c.h"
|
|
|
|
#if SPIRV_CROSS_C_API_CPP
|
|
#include "spirv_cpp.hpp"
|
|
#endif
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
#include "spirv_glsl.hpp"
|
|
#else
|
|
#include "spirv_cross.hpp"
|
|
#endif
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
#include "spirv_hlsl.hpp"
|
|
#endif
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
#include "spirv_msl.hpp"
|
|
#endif
|
|
#if SPIRV_CROSS_C_API_REFLECT
|
|
#include "spirv_reflect.hpp"
|
|
#endif
|
|
|
|
#ifdef HAVE_SPIRV_CROSS_GIT_VERSION
|
|
#include "gitversion.h"
|
|
#endif
|
|
|
|
#include "spirv_parser.hpp"
|
|
#include <memory>
|
|
#include <new>
|
|
#include <string.h>
|
|
|
|
// clang-format off
|
|
|
|
#ifdef _MSC_VER
|
|
#pragma warning(push)
|
|
#pragma warning(disable : 4996)
|
|
#endif
|
|
|
|
#ifndef SPIRV_CROSS_EXCEPTIONS_TO_ASSERTIONS
|
|
#define SPVC_BEGIN_SAFE_SCOPE try
|
|
#else
|
|
#define SPVC_BEGIN_SAFE_SCOPE
|
|
#endif
|
|
|
|
#ifndef SPIRV_CROSS_EXCEPTIONS_TO_ASSERTIONS
|
|
#define SPVC_END_SAFE_SCOPE(context, error) \
|
|
catch (const std::exception &e) \
|
|
{ \
|
|
(context)->report_error(e.what()); \
|
|
return (error); \
|
|
}
|
|
#else
|
|
#define SPVC_END_SAFE_SCOPE(context, error)
|
|
#endif
|
|
|
|
using namespace std;
|
|
using namespace SPIRV_CROSS_NAMESPACE;
|
|
|
|
struct ScratchMemoryAllocation
|
|
{
|
|
virtual ~ScratchMemoryAllocation() = default;
|
|
};
|
|
|
|
struct StringAllocation : ScratchMemoryAllocation
|
|
{
|
|
explicit StringAllocation(const char *name)
|
|
: str(name)
|
|
{
|
|
}
|
|
|
|
explicit StringAllocation(std::string name)
|
|
: str(std::move(name))
|
|
{
|
|
}
|
|
|
|
std::string str;
|
|
};
|
|
|
|
template <typename T>
|
|
struct TemporaryBuffer : ScratchMemoryAllocation
|
|
{
|
|
SmallVector<T> buffer;
|
|
};
|
|
|
|
template <typename T, typename... Ts>
|
|
static inline std::unique_ptr<T> spvc_allocate(Ts &&... ts)
|
|
{
|
|
return std::unique_ptr<T>(new T(std::forward<Ts>(ts)...));
|
|
}
|
|
|
|
struct spvc_context_s
|
|
{
|
|
string last_error;
|
|
SmallVector<unique_ptr<ScratchMemoryAllocation>> allocations;
|
|
const char *allocate_name(const std::string &name);
|
|
|
|
spvc_error_callback callback = nullptr;
|
|
void *callback_userdata = nullptr;
|
|
void report_error(std::string msg);
|
|
};
|
|
|
|
void spvc_context_s::report_error(std::string msg)
|
|
{
|
|
last_error = std::move(msg);
|
|
if (callback)
|
|
callback(callback_userdata, last_error.c_str());
|
|
}
|
|
|
|
const char *spvc_context_s::allocate_name(const std::string &name)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
auto alloc = spvc_allocate<StringAllocation>(name);
|
|
auto *ret = alloc->str.c_str();
|
|
allocations.emplace_back(std::move(alloc));
|
|
return ret;
|
|
}
|
|
SPVC_END_SAFE_SCOPE(this, nullptr)
|
|
}
|
|
|
|
struct spvc_parsed_ir_s : ScratchMemoryAllocation
|
|
{
|
|
spvc_context context = nullptr;
|
|
ParsedIR parsed;
|
|
};
|
|
|
|
struct spvc_compiler_s : ScratchMemoryAllocation
|
|
{
|
|
spvc_context context = nullptr;
|
|
unique_ptr<Compiler> compiler;
|
|
spvc_backend backend = SPVC_BACKEND_NONE;
|
|
};
|
|
|
|
struct spvc_compiler_options_s : ScratchMemoryAllocation
|
|
{
|
|
spvc_context context = nullptr;
|
|
uint32_t backend_flags = 0;
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
CompilerGLSL::Options glsl;
|
|
#endif
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
CompilerMSL::Options msl;
|
|
#endif
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
CompilerHLSL::Options hlsl;
|
|
#endif
|
|
};
|
|
|
|
struct spvc_set_s : ScratchMemoryAllocation
|
|
{
|
|
std::unordered_set<VariableID> set;
|
|
};
|
|
|
|
// Dummy-inherit to we can keep our opaque type handle type safe in C-land as well,
|
|
// and avoid just throwing void * around.
|
|
struct spvc_type_s : SPIRType
|
|
{
|
|
};
|
|
|
|
struct spvc_constant_s : SPIRConstant
|
|
{
|
|
};
|
|
|
|
struct spvc_resources_s : ScratchMemoryAllocation
|
|
{
|
|
spvc_context context = nullptr;
|
|
SmallVector<spvc_reflected_resource> uniform_buffers;
|
|
SmallVector<spvc_reflected_resource> storage_buffers;
|
|
SmallVector<spvc_reflected_resource> stage_inputs;
|
|
SmallVector<spvc_reflected_resource> stage_outputs;
|
|
SmallVector<spvc_reflected_resource> subpass_inputs;
|
|
SmallVector<spvc_reflected_resource> storage_images;
|
|
SmallVector<spvc_reflected_resource> sampled_images;
|
|
SmallVector<spvc_reflected_resource> atomic_counters;
|
|
SmallVector<spvc_reflected_resource> push_constant_buffers;
|
|
SmallVector<spvc_reflected_resource> shader_record_buffers;
|
|
SmallVector<spvc_reflected_resource> separate_images;
|
|
SmallVector<spvc_reflected_resource> separate_samplers;
|
|
SmallVector<spvc_reflected_resource> acceleration_structures;
|
|
SmallVector<spvc_reflected_builtin_resource> builtin_inputs;
|
|
SmallVector<spvc_reflected_builtin_resource> builtin_outputs;
|
|
|
|
bool copy_resources(SmallVector<spvc_reflected_resource> &outputs, const SmallVector<Resource> &inputs);
|
|
bool copy_resources(SmallVector<spvc_reflected_builtin_resource> &outputs, const SmallVector<BuiltInResource> &inputs);
|
|
bool copy_resources(const ShaderResources &resources);
|
|
};
|
|
|
|
spvc_result spvc_context_create(spvc_context *context)
|
|
{
|
|
auto *ctx = new (std::nothrow) spvc_context_s;
|
|
if (!ctx)
|
|
return SPVC_ERROR_OUT_OF_MEMORY;
|
|
|
|
*context = ctx;
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
void spvc_context_destroy(spvc_context context)
|
|
{
|
|
delete context;
|
|
}
|
|
|
|
void spvc_context_release_allocations(spvc_context context)
|
|
{
|
|
context->allocations.clear();
|
|
}
|
|
|
|
const char *spvc_context_get_last_error_string(spvc_context context)
|
|
{
|
|
return context->last_error.c_str();
|
|
}
|
|
|
|
SPVC_PUBLIC_API void spvc_context_set_error_callback(spvc_context context, spvc_error_callback cb, void *userdata)
|
|
{
|
|
context->callback = cb;
|
|
context->callback_userdata = userdata;
|
|
}
|
|
|
|
spvc_result spvc_context_parse_spirv(spvc_context context, const SpvId *spirv, size_t word_count,
|
|
spvc_parsed_ir *parsed_ir)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
std::unique_ptr<spvc_parsed_ir_s> pir(new (std::nothrow) spvc_parsed_ir_s);
|
|
if (!pir)
|
|
{
|
|
context->report_error("Out of memory.");
|
|
return SPVC_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
|
|
pir->context = context;
|
|
Parser parser(spirv, word_count);
|
|
parser.parse();
|
|
pir->parsed = std::move(parser.get_parsed_ir());
|
|
*parsed_ir = pir.get();
|
|
context->allocations.push_back(std::move(pir));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(context, SPVC_ERROR_INVALID_SPIRV)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_context_create_compiler(spvc_context context, spvc_backend backend, spvc_parsed_ir parsed_ir,
|
|
spvc_capture_mode mode, spvc_compiler *compiler)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
std::unique_ptr<spvc_compiler_s> comp(new (std::nothrow) spvc_compiler_s);
|
|
if (!comp)
|
|
{
|
|
context->report_error("Out of memory.");
|
|
return SPVC_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
comp->backend = backend;
|
|
comp->context = context;
|
|
|
|
if (mode != SPVC_CAPTURE_MODE_COPY && mode != SPVC_CAPTURE_MODE_TAKE_OWNERSHIP)
|
|
{
|
|
context->report_error("Invalid argument for capture mode.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
switch (backend)
|
|
{
|
|
case SPVC_BACKEND_NONE:
|
|
if (mode == SPVC_CAPTURE_MODE_TAKE_OWNERSHIP)
|
|
comp->compiler.reset(new Compiler(std::move(parsed_ir->parsed)));
|
|
else if (mode == SPVC_CAPTURE_MODE_COPY)
|
|
comp->compiler.reset(new Compiler(parsed_ir->parsed));
|
|
break;
|
|
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
case SPVC_BACKEND_GLSL:
|
|
if (mode == SPVC_CAPTURE_MODE_TAKE_OWNERSHIP)
|
|
comp->compiler.reset(new CompilerGLSL(std::move(parsed_ir->parsed)));
|
|
else if (mode == SPVC_CAPTURE_MODE_COPY)
|
|
comp->compiler.reset(new CompilerGLSL(parsed_ir->parsed));
|
|
break;
|
|
#endif
|
|
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
case SPVC_BACKEND_HLSL:
|
|
if (mode == SPVC_CAPTURE_MODE_TAKE_OWNERSHIP)
|
|
comp->compiler.reset(new CompilerHLSL(std::move(parsed_ir->parsed)));
|
|
else if (mode == SPVC_CAPTURE_MODE_COPY)
|
|
comp->compiler.reset(new CompilerHLSL(parsed_ir->parsed));
|
|
break;
|
|
#endif
|
|
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
case SPVC_BACKEND_MSL:
|
|
if (mode == SPVC_CAPTURE_MODE_TAKE_OWNERSHIP)
|
|
comp->compiler.reset(new CompilerMSL(std::move(parsed_ir->parsed)));
|
|
else if (mode == SPVC_CAPTURE_MODE_COPY)
|
|
comp->compiler.reset(new CompilerMSL(parsed_ir->parsed));
|
|
break;
|
|
#endif
|
|
|
|
#if SPIRV_CROSS_C_API_CPP
|
|
case SPVC_BACKEND_CPP:
|
|
if (mode == SPVC_CAPTURE_MODE_TAKE_OWNERSHIP)
|
|
comp->compiler.reset(new CompilerCPP(std::move(parsed_ir->parsed)));
|
|
else if (mode == SPVC_CAPTURE_MODE_COPY)
|
|
comp->compiler.reset(new CompilerCPP(parsed_ir->parsed));
|
|
break;
|
|
#endif
|
|
|
|
#if SPIRV_CROSS_C_API_REFLECT
|
|
case SPVC_BACKEND_JSON:
|
|
if (mode == SPVC_CAPTURE_MODE_TAKE_OWNERSHIP)
|
|
comp->compiler.reset(new CompilerReflection(std::move(parsed_ir->parsed)));
|
|
else if (mode == SPVC_CAPTURE_MODE_COPY)
|
|
comp->compiler.reset(new CompilerReflection(parsed_ir->parsed));
|
|
break;
|
|
#endif
|
|
|
|
default:
|
|
context->report_error("Invalid backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
*compiler = comp.get();
|
|
context->allocations.push_back(std::move(comp));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(context, SPVC_ERROR_OUT_OF_MEMORY)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_create_compiler_options(spvc_compiler compiler, spvc_compiler_options *options)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
std::unique_ptr<spvc_compiler_options_s> opt(new (std::nothrow) spvc_compiler_options_s);
|
|
if (!opt)
|
|
{
|
|
compiler->context->report_error("Out of memory.");
|
|
return SPVC_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
|
|
opt->context = compiler->context;
|
|
opt->backend_flags = 0;
|
|
switch (compiler->backend)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
case SPVC_BACKEND_MSL:
|
|
opt->backend_flags |= SPVC_COMPILER_OPTION_MSL_BIT | SPVC_COMPILER_OPTION_COMMON_BIT;
|
|
opt->glsl = static_cast<CompilerMSL *>(compiler->compiler.get())->get_common_options();
|
|
opt->msl = static_cast<CompilerMSL *>(compiler->compiler.get())->get_msl_options();
|
|
break;
|
|
#endif
|
|
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
case SPVC_BACKEND_HLSL:
|
|
opt->backend_flags |= SPVC_COMPILER_OPTION_HLSL_BIT | SPVC_COMPILER_OPTION_COMMON_BIT;
|
|
opt->glsl = static_cast<CompilerHLSL *>(compiler->compiler.get())->get_common_options();
|
|
opt->hlsl = static_cast<CompilerHLSL *>(compiler->compiler.get())->get_hlsl_options();
|
|
break;
|
|
#endif
|
|
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
case SPVC_BACKEND_GLSL:
|
|
opt->backend_flags |= SPVC_COMPILER_OPTION_GLSL_BIT | SPVC_COMPILER_OPTION_COMMON_BIT;
|
|
opt->glsl = static_cast<CompilerGLSL *>(compiler->compiler.get())->get_common_options();
|
|
break;
|
|
#endif
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
*options = opt.get();
|
|
compiler->context->allocations.push_back(std::move(opt));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_OUT_OF_MEMORY)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_options_set_bool(spvc_compiler_options options, spvc_compiler_option option,
|
|
spvc_bool value)
|
|
{
|
|
return spvc_compiler_options_set_uint(options, option, value ? 1 : 0);
|
|
}
|
|
|
|
spvc_result spvc_compiler_options_set_uint(spvc_compiler_options options, spvc_compiler_option option, unsigned value)
|
|
{
|
|
(void)value;
|
|
(void)option;
|
|
uint32_t supported_mask = options->backend_flags;
|
|
uint32_t required_mask = option & SPVC_COMPILER_OPTION_LANG_BITS;
|
|
if ((required_mask | supported_mask) != supported_mask)
|
|
{
|
|
options->context->report_error("Option is not supported by current backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
switch (option)
|
|
{
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
case SPVC_COMPILER_OPTION_FORCE_TEMPORARY:
|
|
options->glsl.force_temporary = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_FLATTEN_MULTIDIMENSIONAL_ARRAYS:
|
|
options->glsl.flatten_multidimensional_arrays = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_FIXUP_DEPTH_CONVENTION:
|
|
options->glsl.vertex.fixup_clipspace = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_FLIP_VERTEX_Y:
|
|
options->glsl.vertex.flip_vert_y = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_EMIT_LINE_DIRECTIVES:
|
|
options->glsl.emit_line_directives = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_ENABLE_STORAGE_IMAGE_QUALIFIER_DEDUCTION:
|
|
options->glsl.enable_storage_image_qualifier_deduction = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_FORCE_ZERO_INITIALIZED_VARIABLES:
|
|
options->glsl.force_zero_initialized_variables = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_GLSL_SUPPORT_NONZERO_BASE_INSTANCE:
|
|
options->glsl.vertex.support_nonzero_base_instance = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_SEPARATE_SHADER_OBJECTS:
|
|
options->glsl.separate_shader_objects = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_ENABLE_420PACK_EXTENSION:
|
|
options->glsl.enable_420pack_extension = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_VERSION:
|
|
options->glsl.version = value;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_ES:
|
|
options->glsl.es = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_VULKAN_SEMANTICS:
|
|
options->glsl.vulkan_semantics = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_ES_DEFAULT_FLOAT_PRECISION_HIGHP:
|
|
options->glsl.fragment.default_float_precision =
|
|
value != 0 ? CompilerGLSL::Options::Precision::Highp : CompilerGLSL::Options::Precision::Mediump;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_ES_DEFAULT_INT_PRECISION_HIGHP:
|
|
options->glsl.fragment.default_int_precision =
|
|
value != 0 ? CompilerGLSL::Options::Precision::Highp : CompilerGLSL::Options::Precision::Mediump;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_EMIT_PUSH_CONSTANT_AS_UNIFORM_BUFFER:
|
|
options->glsl.emit_push_constant_as_uniform_buffer = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_EMIT_UNIFORM_BUFFER_AS_PLAIN_UNIFORMS:
|
|
options->glsl.emit_uniform_buffer_as_plain_uniforms = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_FORCE_FLATTENED_IO_BLOCKS:
|
|
options->glsl.force_flattened_io_blocks = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_OVR_MULTIVIEW_VIEW_COUNT:
|
|
options->glsl.ovr_multiview_view_count = value;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_RELAX_NAN_CHECKS:
|
|
options->glsl.relax_nan_checks = value != 0;
|
|
break;
|
|
case SPVC_COMPILER_OPTION_GLSL_ENABLE_ROW_MAJOR_LOAD_WORKAROUND:
|
|
options->glsl.enable_row_major_load_workaround = value != 0;
|
|
break;
|
|
#endif
|
|
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
case SPVC_COMPILER_OPTION_HLSL_SHADER_MODEL:
|
|
options->hlsl.shader_model = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_HLSL_POINT_SIZE_COMPAT:
|
|
options->hlsl.point_size_compat = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_HLSL_POINT_COORD_COMPAT:
|
|
options->hlsl.point_coord_compat = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_HLSL_SUPPORT_NONZERO_BASE_VERTEX_BASE_INSTANCE:
|
|
options->hlsl.support_nonzero_base_vertex_base_instance = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_HLSL_FORCE_STORAGE_BUFFER_AS_UAV:
|
|
options->hlsl.force_storage_buffer_as_uav = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_HLSL_NONWRITABLE_UAV_TEXTURE_AS_SRV:
|
|
options->hlsl.nonwritable_uav_texture_as_srv = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_HLSL_ENABLE_16BIT_TYPES:
|
|
options->hlsl.enable_16bit_types = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_HLSL_FLATTEN_MATRIX_VERTEX_INPUT_SEMANTICS:
|
|
options->hlsl.flatten_matrix_vertex_input_semantics = value != 0;
|
|
break;
|
|
#endif
|
|
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
case SPVC_COMPILER_OPTION_MSL_VERSION:
|
|
options->msl.msl_version = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_TEXEL_BUFFER_TEXTURE_WIDTH:
|
|
options->msl.texel_buffer_texture_width = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_SWIZZLE_BUFFER_INDEX:
|
|
options->msl.swizzle_buffer_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_INDIRECT_PARAMS_BUFFER_INDEX:
|
|
options->msl.indirect_params_buffer_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_SHADER_OUTPUT_BUFFER_INDEX:
|
|
options->msl.shader_output_buffer_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_SHADER_PATCH_OUTPUT_BUFFER_INDEX:
|
|
options->msl.shader_patch_output_buffer_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_SHADER_TESS_FACTOR_OUTPUT_BUFFER_INDEX:
|
|
options->msl.shader_tess_factor_buffer_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_SHADER_INPUT_WORKGROUP_INDEX:
|
|
options->msl.shader_input_wg_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_ENABLE_POINT_SIZE_BUILTIN:
|
|
options->msl.enable_point_size_builtin = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_DISABLE_RASTERIZATION:
|
|
options->msl.disable_rasterization = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_CAPTURE_OUTPUT_TO_BUFFER:
|
|
options->msl.capture_output_to_buffer = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_SWIZZLE_TEXTURE_SAMPLES:
|
|
options->msl.swizzle_texture_samples = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_PAD_FRAGMENT_OUTPUT_COMPONENTS:
|
|
options->msl.pad_fragment_output_components = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_TESS_DOMAIN_ORIGIN_LOWER_LEFT:
|
|
options->msl.tess_domain_origin_lower_left = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_PLATFORM:
|
|
options->msl.platform = static_cast<CompilerMSL::Options::Platform>(value);
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_ARGUMENT_BUFFERS:
|
|
options->msl.argument_buffers = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_TEXTURE_BUFFER_NATIVE:
|
|
options->msl.texture_buffer_native = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_BUFFER_SIZE_BUFFER_INDEX:
|
|
options->msl.buffer_size_buffer_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_MULTIVIEW:
|
|
options->msl.multiview = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_VIEW_MASK_BUFFER_INDEX:
|
|
options->msl.view_mask_buffer_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_DEVICE_INDEX:
|
|
options->msl.device_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_VIEW_INDEX_FROM_DEVICE_INDEX:
|
|
options->msl.view_index_from_device_index = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_DISPATCH_BASE:
|
|
options->msl.dispatch_base = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_DYNAMIC_OFFSETS_BUFFER_INDEX:
|
|
options->msl.dynamic_offsets_buffer_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_TEXTURE_1D_AS_2D:
|
|
options->msl.texture_1D_as_2D = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_ENABLE_BASE_INDEX_ZERO:
|
|
options->msl.enable_base_index_zero = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_FRAMEBUFFER_FETCH_SUBPASS:
|
|
options->msl.use_framebuffer_fetch_subpasses = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_INVARIANT_FP_MATH:
|
|
options->msl.invariant_float_math = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_EMULATE_CUBEMAP_ARRAY:
|
|
options->msl.emulate_cube_array = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_ENABLE_DECORATION_BINDING:
|
|
options->msl.enable_decoration_binding = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_FORCE_ACTIVE_ARGUMENT_BUFFER_RESOURCES:
|
|
options->msl.force_active_argument_buffer_resources = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_FORCE_NATIVE_ARRAYS:
|
|
options->msl.force_native_arrays = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_ENABLE_FRAG_OUTPUT_MASK:
|
|
options->msl.enable_frag_output_mask = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_ENABLE_FRAG_DEPTH_BUILTIN:
|
|
options->msl.enable_frag_depth_builtin = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_ENABLE_FRAG_STENCIL_REF_BUILTIN:
|
|
options->msl.enable_frag_stencil_ref_builtin = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_ENABLE_CLIP_DISTANCE_USER_VARYING:
|
|
options->msl.enable_clip_distance_user_varying = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_MULTI_PATCH_WORKGROUP:
|
|
options->msl.multi_patch_workgroup = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_SHADER_INPUT_BUFFER_INDEX:
|
|
options->msl.shader_input_buffer_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_SHADER_INDEX_BUFFER_INDEX:
|
|
options->msl.shader_index_buffer_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_VERTEX_FOR_TESSELLATION:
|
|
options->msl.vertex_for_tessellation = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_VERTEX_INDEX_TYPE:
|
|
options->msl.vertex_index_type = static_cast<CompilerMSL::Options::IndexType>(value);
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_MULTIVIEW_LAYERED_RENDERING:
|
|
options->msl.multiview_layered_rendering = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_ARRAYED_SUBPASS_INPUT:
|
|
options->msl.arrayed_subpass_input = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_R32UI_LINEAR_TEXTURE_ALIGNMENT:
|
|
options->msl.r32ui_linear_texture_alignment = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_R32UI_ALIGNMENT_CONSTANT_ID:
|
|
options->msl.r32ui_alignment_constant_id = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_IOS_USE_SIMDGROUP_FUNCTIONS:
|
|
options->msl.ios_use_simdgroup_functions = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_EMULATE_SUBGROUPS:
|
|
options->msl.emulate_subgroups = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_FIXED_SUBGROUP_SIZE:
|
|
options->msl.fixed_subgroup_size = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_FORCE_SAMPLE_RATE_SHADING:
|
|
options->msl.force_sample_rate_shading = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_IOS_SUPPORT_BASE_VERTEX_INSTANCE:
|
|
options->msl.ios_support_base_vertex_instance = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_RAW_BUFFER_TESE_INPUT:
|
|
options->msl.raw_buffer_tese_input = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_SHADER_PATCH_INPUT_BUFFER_INDEX:
|
|
options->msl.shader_patch_input_buffer_index = value;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_MANUAL_HELPER_INVOCATION_UPDATES:
|
|
options->msl.manual_helper_invocation_updates = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_CHECK_DISCARDED_FRAG_STORES:
|
|
options->msl.check_discarded_frag_stores = value != 0;
|
|
break;
|
|
|
|
case SPVC_COMPILER_OPTION_MSL_ARGUMENT_BUFFERS_TIER:
|
|
options->msl.argument_buffers_tier = static_cast<CompilerMSL::Options::ArgumentBuffersTier>(value);
|
|
break;
|
|
#endif
|
|
|
|
default:
|
|
options->context->report_error("Unknown option.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_install_compiler_options(spvc_compiler compiler, spvc_compiler_options options)
|
|
{
|
|
(void)options;
|
|
switch (compiler->backend)
|
|
{
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
case SPVC_BACKEND_GLSL:
|
|
static_cast<CompilerGLSL &>(*compiler->compiler).set_common_options(options->glsl);
|
|
break;
|
|
#endif
|
|
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
case SPVC_BACKEND_HLSL:
|
|
static_cast<CompilerHLSL &>(*compiler->compiler).set_common_options(options->glsl);
|
|
static_cast<CompilerHLSL &>(*compiler->compiler).set_hlsl_options(options->hlsl);
|
|
break;
|
|
#endif
|
|
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
case SPVC_BACKEND_MSL:
|
|
static_cast<CompilerMSL &>(*compiler->compiler).set_common_options(options->glsl);
|
|
static_cast<CompilerMSL &>(*compiler->compiler).set_msl_options(options->msl);
|
|
break;
|
|
#endif
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_add_header_line(spvc_compiler compiler, const char *line)
|
|
{
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
if (compiler->backend == SPVC_BACKEND_NONE)
|
|
{
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
static_cast<CompilerGLSL *>(compiler->compiler.get())->add_header_line(line);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)line;
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_require_extension(spvc_compiler compiler, const char *line)
|
|
{
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
if (compiler->backend == SPVC_BACKEND_NONE)
|
|
{
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
static_cast<CompilerGLSL *>(compiler->compiler.get())->require_extension(line);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)line;
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_flatten_buffer_block(spvc_compiler compiler, spvc_variable_id id)
|
|
{
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
if (compiler->backend == SPVC_BACKEND_NONE)
|
|
{
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
static_cast<CompilerGLSL *>(compiler->compiler.get())->flatten_buffer_block(id);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)id;
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_bool spvc_compiler_variable_is_depth_or_compare(spvc_compiler compiler, spvc_variable_id id)
|
|
{
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
if (compiler->backend == SPVC_BACKEND_NONE)
|
|
{
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
return static_cast<CompilerGLSL *>(compiler->compiler.get())->variable_is_depth_or_compare(id) ? SPVC_TRUE : SPVC_FALSE;
|
|
#else
|
|
(void)id;
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_FALSE;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_mask_stage_output_by_location(spvc_compiler compiler,
|
|
unsigned location, unsigned component)
|
|
{
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
if (compiler->backend == SPVC_BACKEND_NONE)
|
|
{
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
static_cast<CompilerGLSL *>(compiler->compiler.get())->mask_stage_output_by_location(location, component);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)location;
|
|
(void)component;
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_mask_stage_output_by_builtin(spvc_compiler compiler, SpvBuiltIn builtin)
|
|
{
|
|
#if SPIRV_CROSS_C_API_GLSL
|
|
if (compiler->backend == SPVC_BACKEND_NONE)
|
|
{
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
static_cast<CompilerGLSL *>(compiler->compiler.get())->mask_stage_output_by_builtin(spv::BuiltIn(builtin));
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)builtin;
|
|
compiler->context->report_error("Cross-compilation related option used on NONE backend which only supports reflection.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_hlsl_set_root_constants_layout(spvc_compiler compiler,
|
|
const spvc_hlsl_root_constants *constant_info,
|
|
size_t count)
|
|
{
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
if (compiler->backend != SPVC_BACKEND_HLSL)
|
|
{
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &hlsl = *static_cast<CompilerHLSL *>(compiler->compiler.get());
|
|
vector<RootConstants> roots;
|
|
roots.reserve(count);
|
|
for (size_t i = 0; i < count; i++)
|
|
{
|
|
RootConstants root;
|
|
root.binding = constant_info[i].binding;
|
|
root.space = constant_info[i].space;
|
|
root.start = constant_info[i].start;
|
|
root.end = constant_info[i].end;
|
|
roots.push_back(root);
|
|
}
|
|
|
|
hlsl.set_root_constant_layouts(std::move(roots));
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)constant_info;
|
|
(void)count;
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_hlsl_add_vertex_attribute_remap(spvc_compiler compiler,
|
|
const spvc_hlsl_vertex_attribute_remap *remap,
|
|
size_t count)
|
|
{
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
if (compiler->backend != SPVC_BACKEND_HLSL)
|
|
{
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
HLSLVertexAttributeRemap re;
|
|
auto &hlsl = *static_cast<CompilerHLSL *>(compiler->compiler.get());
|
|
for (size_t i = 0; i < count; i++)
|
|
{
|
|
re.location = remap[i].location;
|
|
re.semantic = remap[i].semantic;
|
|
hlsl.add_vertex_attribute_remap(re);
|
|
}
|
|
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)remap;
|
|
(void)count;
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_variable_id spvc_compiler_hlsl_remap_num_workgroups_builtin(spvc_compiler compiler)
|
|
{
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
if (compiler->backend != SPVC_BACKEND_HLSL)
|
|
{
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return 0;
|
|
}
|
|
|
|
auto &hlsl = *static_cast<CompilerHLSL *>(compiler->compiler.get());
|
|
return hlsl.remap_num_workgroups_builtin();
|
|
#else
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return 0;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_hlsl_set_resource_binding_flags(spvc_compiler compiler,
|
|
spvc_hlsl_binding_flags flags)
|
|
{
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
if (compiler->backend != SPVC_BACKEND_HLSL)
|
|
{
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &hlsl = *static_cast<CompilerHLSL *>(compiler->compiler.get());
|
|
hlsl.set_resource_binding_flags(flags);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)flags;
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_hlsl_add_resource_binding(spvc_compiler compiler,
|
|
const spvc_hlsl_resource_binding *binding)
|
|
{
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
if (compiler->backend != SPVC_BACKEND_HLSL)
|
|
{
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &hlsl = *static_cast<CompilerHLSL *>(compiler->compiler.get());
|
|
HLSLResourceBinding bind;
|
|
bind.binding = binding->binding;
|
|
bind.desc_set = binding->desc_set;
|
|
bind.stage = static_cast<spv::ExecutionModel>(binding->stage);
|
|
bind.cbv.register_binding = binding->cbv.register_binding;
|
|
bind.cbv.register_space = binding->cbv.register_space;
|
|
bind.uav.register_binding = binding->uav.register_binding;
|
|
bind.uav.register_space = binding->uav.register_space;
|
|
bind.srv.register_binding = binding->srv.register_binding;
|
|
bind.srv.register_space = binding->srv.register_space;
|
|
bind.sampler.register_binding = binding->sampler.register_binding;
|
|
bind.sampler.register_space = binding->sampler.register_space;
|
|
hlsl.add_hlsl_resource_binding(bind);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)binding;
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_bool spvc_compiler_hlsl_is_resource_used(spvc_compiler compiler, SpvExecutionModel model, unsigned set,
|
|
unsigned binding)
|
|
{
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
if (compiler->backend != SPVC_BACKEND_HLSL)
|
|
{
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
auto &hlsl = *static_cast<CompilerHLSL *>(compiler->compiler.get());
|
|
return hlsl.is_hlsl_resource_binding_used(static_cast<spv::ExecutionModel>(model), set, binding) ? SPVC_TRUE :
|
|
SPVC_FALSE;
|
|
#else
|
|
(void)model;
|
|
(void)set;
|
|
(void)binding;
|
|
compiler->context->report_error("HLSL function used on a non-HLSL backend.");
|
|
return SPVC_FALSE;
|
|
#endif
|
|
}
|
|
|
|
spvc_bool spvc_compiler_msl_is_rasterization_disabled(spvc_compiler compiler)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.get_is_rasterization_disabled() ? SPVC_TRUE : SPVC_FALSE;
|
|
#else
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
#endif
|
|
}
|
|
|
|
spvc_bool spvc_compiler_msl_needs_swizzle_buffer(spvc_compiler compiler)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.needs_swizzle_buffer() ? SPVC_TRUE : SPVC_FALSE;
|
|
#else
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
#endif
|
|
}
|
|
|
|
spvc_bool spvc_compiler_msl_needs_buffer_size_buffer(spvc_compiler compiler)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.needs_buffer_size_buffer() ? SPVC_TRUE : SPVC_FALSE;
|
|
#else
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
#endif
|
|
}
|
|
|
|
spvc_bool spvc_compiler_msl_needs_aux_buffer(spvc_compiler compiler)
|
|
{
|
|
return spvc_compiler_msl_needs_swizzle_buffer(compiler);
|
|
}
|
|
|
|
spvc_bool spvc_compiler_msl_needs_output_buffer(spvc_compiler compiler)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.needs_output_buffer() ? SPVC_TRUE : SPVC_FALSE;
|
|
#else
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
#endif
|
|
}
|
|
|
|
spvc_bool spvc_compiler_msl_needs_patch_output_buffer(spvc_compiler compiler)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.needs_patch_output_buffer() ? SPVC_TRUE : SPVC_FALSE;
|
|
#else
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
#endif
|
|
}
|
|
|
|
spvc_bool spvc_compiler_msl_needs_input_threadgroup_mem(spvc_compiler compiler)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.needs_input_threadgroup_mem() ? SPVC_TRUE : SPVC_FALSE;
|
|
#else
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_add_vertex_attribute(spvc_compiler compiler, const spvc_msl_vertex_attribute *va)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
MSLShaderInterfaceVariable attr;
|
|
attr.location = va->location;
|
|
attr.format = static_cast<MSLShaderVariableFormat>(va->format);
|
|
attr.builtin = static_cast<spv::BuiltIn>(va->builtin);
|
|
msl.add_msl_shader_input(attr);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)va;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_add_shader_input(spvc_compiler compiler, const spvc_msl_shader_interface_var *si)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
MSLShaderInterfaceVariable input;
|
|
input.location = si->location;
|
|
input.format = static_cast<MSLShaderVariableFormat>(si->format);
|
|
input.builtin = static_cast<spv::BuiltIn>(si->builtin);
|
|
input.vecsize = si->vecsize;
|
|
msl.add_msl_shader_input(input);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)si;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_add_shader_input_2(spvc_compiler compiler, const spvc_msl_shader_interface_var_2 *si)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
MSLShaderInterfaceVariable input;
|
|
input.location = si->location;
|
|
input.format = static_cast<MSLShaderVariableFormat>(si->format);
|
|
input.builtin = static_cast<spv::BuiltIn>(si->builtin);
|
|
input.vecsize = si->vecsize;
|
|
input.rate = static_cast<MSLShaderVariableRate>(si->rate);
|
|
msl.add_msl_shader_input(input);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)si;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_add_shader_output(spvc_compiler compiler, const spvc_msl_shader_interface_var *so)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
MSLShaderInterfaceVariable output;
|
|
output.location = so->location;
|
|
output.format = static_cast<MSLShaderVariableFormat>(so->format);
|
|
output.builtin = static_cast<spv::BuiltIn>(so->builtin);
|
|
output.vecsize = so->vecsize;
|
|
msl.add_msl_shader_output(output);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)so;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_add_shader_output_2(spvc_compiler compiler, const spvc_msl_shader_interface_var_2 *so)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
MSLShaderInterfaceVariable output;
|
|
output.location = so->location;
|
|
output.format = static_cast<MSLShaderVariableFormat>(so->format);
|
|
output.builtin = static_cast<spv::BuiltIn>(so->builtin);
|
|
output.vecsize = so->vecsize;
|
|
output.rate = static_cast<MSLShaderVariableRate>(so->rate);
|
|
msl.add_msl_shader_output(output);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)so;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_add_resource_binding(spvc_compiler compiler,
|
|
const spvc_msl_resource_binding *binding)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
MSLResourceBinding bind;
|
|
bind.binding = binding->binding;
|
|
bind.desc_set = binding->desc_set;
|
|
bind.stage = static_cast<spv::ExecutionModel>(binding->stage);
|
|
bind.msl_buffer = binding->msl_buffer;
|
|
bind.msl_texture = binding->msl_texture;
|
|
bind.msl_sampler = binding->msl_sampler;
|
|
msl.add_msl_resource_binding(bind);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)binding;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_add_dynamic_buffer(spvc_compiler compiler, unsigned desc_set, unsigned binding, unsigned index)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
msl.add_dynamic_buffer(desc_set, binding, index);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)binding;
|
|
(void)desc_set;
|
|
(void)index;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_add_inline_uniform_block(spvc_compiler compiler, unsigned desc_set, unsigned binding)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
msl.add_inline_uniform_block(desc_set, binding);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)binding;
|
|
(void)desc_set;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_add_discrete_descriptor_set(spvc_compiler compiler, unsigned desc_set)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
msl.add_discrete_descriptor_set(desc_set);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)desc_set;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_set_argument_buffer_device_address_space(spvc_compiler compiler, unsigned desc_set, spvc_bool device_address)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
msl.set_argument_buffer_device_address_space(desc_set, bool(device_address));
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)desc_set;
|
|
(void)device_address;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_bool spvc_compiler_msl_is_shader_input_used(spvc_compiler compiler, unsigned location)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.is_msl_shader_input_used(location) ? SPVC_TRUE : SPVC_FALSE;
|
|
#else
|
|
(void)location;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
#endif
|
|
}
|
|
|
|
spvc_bool spvc_compiler_msl_is_shader_output_used(spvc_compiler compiler, unsigned location)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.is_msl_shader_output_used(location) ? SPVC_TRUE : SPVC_FALSE;
|
|
#else
|
|
(void)location;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
#endif
|
|
}
|
|
|
|
spvc_bool spvc_compiler_msl_is_vertex_attribute_used(spvc_compiler compiler, unsigned location)
|
|
{
|
|
return spvc_compiler_msl_is_shader_input_used(compiler, location);
|
|
}
|
|
|
|
spvc_bool spvc_compiler_msl_is_resource_used(spvc_compiler compiler, SpvExecutionModel model, unsigned set,
|
|
unsigned binding)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.is_msl_resource_binding_used(static_cast<spv::ExecutionModel>(model), set, binding) ? SPVC_TRUE :
|
|
SPVC_FALSE;
|
|
#else
|
|
(void)model;
|
|
(void)set;
|
|
(void)binding;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_FALSE;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_set_combined_sampler_suffix(spvc_compiler compiler, const char *suffix)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
msl.set_combined_sampler_suffix(suffix);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)suffix;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
const char *spvc_compiler_msl_get_combined_sampler_suffix(spvc_compiler compiler)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return "";
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.get_combined_sampler_suffix();
|
|
#else
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return "";
|
|
#endif
|
|
}
|
|
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
static void spvc_convert_msl_sampler(MSLConstexprSampler &samp, const spvc_msl_constexpr_sampler *sampler)
|
|
{
|
|
samp.s_address = static_cast<MSLSamplerAddress>(sampler->s_address);
|
|
samp.t_address = static_cast<MSLSamplerAddress>(sampler->t_address);
|
|
samp.r_address = static_cast<MSLSamplerAddress>(sampler->r_address);
|
|
samp.lod_clamp_min = sampler->lod_clamp_min;
|
|
samp.lod_clamp_max = sampler->lod_clamp_max;
|
|
samp.lod_clamp_enable = sampler->lod_clamp_enable != 0;
|
|
samp.min_filter = static_cast<MSLSamplerFilter>(sampler->min_filter);
|
|
samp.mag_filter = static_cast<MSLSamplerFilter>(sampler->mag_filter);
|
|
samp.mip_filter = static_cast<MSLSamplerMipFilter>(sampler->mip_filter);
|
|
samp.compare_enable = sampler->compare_enable != 0;
|
|
samp.anisotropy_enable = sampler->anisotropy_enable != 0;
|
|
samp.max_anisotropy = sampler->max_anisotropy;
|
|
samp.compare_func = static_cast<MSLSamplerCompareFunc>(sampler->compare_func);
|
|
samp.coord = static_cast<MSLSamplerCoord>(sampler->coord);
|
|
samp.border_color = static_cast<MSLSamplerBorderColor>(sampler->border_color);
|
|
}
|
|
|
|
static void spvc_convert_msl_sampler_ycbcr_conversion(MSLConstexprSampler &samp, const spvc_msl_sampler_ycbcr_conversion *conv)
|
|
{
|
|
samp.ycbcr_conversion_enable = conv != nullptr;
|
|
if (conv == nullptr) return;
|
|
samp.planes = conv->planes;
|
|
samp.resolution = static_cast<MSLFormatResolution>(conv->resolution);
|
|
samp.chroma_filter = static_cast<MSLSamplerFilter>(conv->chroma_filter);
|
|
samp.x_chroma_offset = static_cast<MSLChromaLocation>(conv->x_chroma_offset);
|
|
samp.y_chroma_offset = static_cast<MSLChromaLocation>(conv->y_chroma_offset);
|
|
for (int i = 0; i < 4; i++)
|
|
samp.swizzle[i] = static_cast<MSLComponentSwizzle>(conv->swizzle[i]);
|
|
samp.ycbcr_model = static_cast<MSLSamplerYCbCrModelConversion>(conv->ycbcr_model);
|
|
samp.ycbcr_range = static_cast<MSLSamplerYCbCrRange>(conv->ycbcr_range);
|
|
samp.bpc = conv->bpc;
|
|
}
|
|
#endif
|
|
|
|
spvc_result spvc_compiler_msl_remap_constexpr_sampler(spvc_compiler compiler, spvc_variable_id id,
|
|
const spvc_msl_constexpr_sampler *sampler)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
MSLConstexprSampler samp;
|
|
spvc_convert_msl_sampler(samp, sampler);
|
|
msl.remap_constexpr_sampler(id, samp);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)id;
|
|
(void)sampler;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_remap_constexpr_sampler_by_binding(spvc_compiler compiler,
|
|
unsigned desc_set, unsigned binding,
|
|
const spvc_msl_constexpr_sampler *sampler)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
MSLConstexprSampler samp;
|
|
spvc_convert_msl_sampler(samp, sampler);
|
|
msl.remap_constexpr_sampler_by_binding(desc_set, binding, samp);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)desc_set;
|
|
(void)binding;
|
|
(void)sampler;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_remap_constexpr_sampler_ycbcr(spvc_compiler compiler, spvc_variable_id id,
|
|
const spvc_msl_constexpr_sampler *sampler,
|
|
const spvc_msl_sampler_ycbcr_conversion *conv)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
MSLConstexprSampler samp;
|
|
spvc_convert_msl_sampler(samp, sampler);
|
|
spvc_convert_msl_sampler_ycbcr_conversion(samp, conv);
|
|
msl.remap_constexpr_sampler(id, samp);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)id;
|
|
(void)sampler;
|
|
(void)conv;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_remap_constexpr_sampler_by_binding_ycbcr(spvc_compiler compiler,
|
|
unsigned desc_set, unsigned binding,
|
|
const spvc_msl_constexpr_sampler *sampler,
|
|
const spvc_msl_sampler_ycbcr_conversion *conv)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
MSLConstexprSampler samp;
|
|
spvc_convert_msl_sampler(samp, sampler);
|
|
spvc_convert_msl_sampler_ycbcr_conversion(samp, conv);
|
|
msl.remap_constexpr_sampler_by_binding(desc_set, binding, samp);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)desc_set;
|
|
(void)binding;
|
|
(void)sampler;
|
|
(void)conv;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_msl_set_fragment_output_components(spvc_compiler compiler, unsigned location,
|
|
unsigned components)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
msl.set_fragment_output_components(location, components);
|
|
return SPVC_SUCCESS;
|
|
#else
|
|
(void)location;
|
|
(void)components;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
#endif
|
|
}
|
|
|
|
unsigned spvc_compiler_msl_get_automatic_resource_binding(spvc_compiler compiler, spvc_variable_id id)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return uint32_t(-1);
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.get_automatic_msl_resource_binding(id);
|
|
#else
|
|
(void)id;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return uint32_t(-1);
|
|
#endif
|
|
}
|
|
|
|
unsigned spvc_compiler_msl_get_automatic_resource_binding_secondary(spvc_compiler compiler, spvc_variable_id id)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
if (compiler->backend != SPVC_BACKEND_MSL)
|
|
{
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return uint32_t(-1);
|
|
}
|
|
|
|
auto &msl = *static_cast<CompilerMSL *>(compiler->compiler.get());
|
|
return msl.get_automatic_msl_resource_binding_secondary(id);
|
|
#else
|
|
(void)id;
|
|
compiler->context->report_error("MSL function used on a non-MSL backend.");
|
|
return uint32_t(-1);
|
|
#endif
|
|
}
|
|
|
|
spvc_result spvc_compiler_compile(spvc_compiler compiler, const char **source)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
auto result = compiler->compiler->compile();
|
|
if (result.empty())
|
|
{
|
|
compiler->context->report_error("Unsupported SPIR-V.");
|
|
return SPVC_ERROR_UNSUPPORTED_SPIRV;
|
|
}
|
|
|
|
*source = compiler->context->allocate_name(result);
|
|
if (!*source)
|
|
{
|
|
compiler->context->report_error("Out of memory.");
|
|
return SPVC_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
return SPVC_SUCCESS;
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_UNSUPPORTED_SPIRV)
|
|
}
|
|
|
|
bool spvc_resources_s::copy_resources(SmallVector<spvc_reflected_resource> &outputs,
|
|
const SmallVector<Resource> &inputs)
|
|
{
|
|
for (auto &i : inputs)
|
|
{
|
|
spvc_reflected_resource r;
|
|
r.base_type_id = i.base_type_id;
|
|
r.type_id = i.type_id;
|
|
r.id = i.id;
|
|
r.name = context->allocate_name(i.name);
|
|
if (!r.name)
|
|
return false;
|
|
|
|
outputs.push_back(r);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
bool spvc_resources_s::copy_resources(SmallVector<spvc_reflected_builtin_resource> &outputs,
|
|
const SmallVector<BuiltInResource> &inputs)
|
|
{
|
|
for (auto &i : inputs)
|
|
{
|
|
spvc_reflected_builtin_resource br;
|
|
|
|
br.value_type_id = i.value_type_id;
|
|
br.builtin = SpvBuiltIn(i.builtin);
|
|
|
|
auto &r = br.resource;
|
|
r.base_type_id = i.resource.base_type_id;
|
|
r.type_id = i.resource.type_id;
|
|
r.id = i.resource.id;
|
|
r.name = context->allocate_name(i.resource.name);
|
|
if (!r.name)
|
|
return false;
|
|
|
|
outputs.push_back(br);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
bool spvc_resources_s::copy_resources(const ShaderResources &resources)
|
|
{
|
|
if (!copy_resources(uniform_buffers, resources.uniform_buffers))
|
|
return false;
|
|
if (!copy_resources(storage_buffers, resources.storage_buffers))
|
|
return false;
|
|
if (!copy_resources(stage_inputs, resources.stage_inputs))
|
|
return false;
|
|
if (!copy_resources(stage_outputs, resources.stage_outputs))
|
|
return false;
|
|
if (!copy_resources(subpass_inputs, resources.subpass_inputs))
|
|
return false;
|
|
if (!copy_resources(storage_images, resources.storage_images))
|
|
return false;
|
|
if (!copy_resources(sampled_images, resources.sampled_images))
|
|
return false;
|
|
if (!copy_resources(atomic_counters, resources.atomic_counters))
|
|
return false;
|
|
if (!copy_resources(push_constant_buffers, resources.push_constant_buffers))
|
|
return false;
|
|
if (!copy_resources(shader_record_buffers, resources.shader_record_buffers))
|
|
return false;
|
|
if (!copy_resources(separate_images, resources.separate_images))
|
|
return false;
|
|
if (!copy_resources(separate_samplers, resources.separate_samplers))
|
|
return false;
|
|
if (!copy_resources(acceleration_structures, resources.acceleration_structures))
|
|
return false;
|
|
if (!copy_resources(builtin_inputs, resources.builtin_inputs))
|
|
return false;
|
|
if (!copy_resources(builtin_outputs, resources.builtin_outputs))
|
|
return false;
|
|
|
|
return true;
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_active_interface_variables(spvc_compiler compiler, spvc_set *set)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
std::unique_ptr<spvc_set_s> ptr(new (std::nothrow) spvc_set_s);
|
|
if (!ptr)
|
|
{
|
|
compiler->context->report_error("Out of memory.");
|
|
return SPVC_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
|
|
auto active = compiler->compiler->get_active_interface_variables();
|
|
ptr->set = std::move(active);
|
|
*set = ptr.get();
|
|
compiler->context->allocations.push_back(std::move(ptr));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_INVALID_ARGUMENT)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_set_enabled_interface_variables(spvc_compiler compiler, spvc_set set)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
compiler->compiler->set_enabled_interface_variables(set->set);
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_INVALID_ARGUMENT)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_create_shader_resources_for_active_variables(spvc_compiler compiler, spvc_resources *resources,
|
|
spvc_set set)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
std::unique_ptr<spvc_resources_s> res(new (std::nothrow) spvc_resources_s);
|
|
if (!res)
|
|
{
|
|
compiler->context->report_error("Out of memory.");
|
|
return SPVC_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
|
|
res->context = compiler->context;
|
|
auto accessed_resources = compiler->compiler->get_shader_resources(set->set);
|
|
|
|
if (!res->copy_resources(accessed_resources))
|
|
{
|
|
res->context->report_error("Out of memory.");
|
|
return SPVC_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
*resources = res.get();
|
|
compiler->context->allocations.push_back(std::move(res));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_OUT_OF_MEMORY)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_create_shader_resources(spvc_compiler compiler, spvc_resources *resources)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
std::unique_ptr<spvc_resources_s> res(new (std::nothrow) spvc_resources_s);
|
|
if (!res)
|
|
{
|
|
compiler->context->report_error("Out of memory.");
|
|
return SPVC_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
|
|
res->context = compiler->context;
|
|
auto accessed_resources = compiler->compiler->get_shader_resources();
|
|
|
|
if (!res->copy_resources(accessed_resources))
|
|
{
|
|
res->context->report_error("Out of memory.");
|
|
return SPVC_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
|
|
*resources = res.get();
|
|
compiler->context->allocations.push_back(std::move(res));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_OUT_OF_MEMORY)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_resources_get_resource_list_for_type(spvc_resources resources, spvc_resource_type type,
|
|
const spvc_reflected_resource **resource_list,
|
|
size_t *resource_size)
|
|
{
|
|
const SmallVector<spvc_reflected_resource> *list = nullptr;
|
|
switch (type)
|
|
{
|
|
case SPVC_RESOURCE_TYPE_UNIFORM_BUFFER:
|
|
list = &resources->uniform_buffers;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_STORAGE_BUFFER:
|
|
list = &resources->storage_buffers;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_STAGE_INPUT:
|
|
list = &resources->stage_inputs;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_STAGE_OUTPUT:
|
|
list = &resources->stage_outputs;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_SUBPASS_INPUT:
|
|
list = &resources->subpass_inputs;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_STORAGE_IMAGE:
|
|
list = &resources->storage_images;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_SAMPLED_IMAGE:
|
|
list = &resources->sampled_images;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_ATOMIC_COUNTER:
|
|
list = &resources->atomic_counters;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_PUSH_CONSTANT:
|
|
list = &resources->push_constant_buffers;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_SEPARATE_IMAGE:
|
|
list = &resources->separate_images;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_SEPARATE_SAMPLERS:
|
|
list = &resources->separate_samplers;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_ACCELERATION_STRUCTURE:
|
|
list = &resources->acceleration_structures;
|
|
break;
|
|
|
|
case SPVC_RESOURCE_TYPE_SHADER_RECORD_BUFFER:
|
|
list = &resources->shader_record_buffers;
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
if (!list)
|
|
{
|
|
resources->context->report_error("Invalid argument.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
*resource_size = list->size();
|
|
*resource_list = list->data();
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_resources_get_builtin_resource_list_for_type(
|
|
spvc_resources resources, spvc_builtin_resource_type type,
|
|
const spvc_reflected_builtin_resource **resource_list,
|
|
size_t *resource_size)
|
|
{
|
|
const SmallVector<spvc_reflected_builtin_resource> *list = nullptr;
|
|
switch (type)
|
|
{
|
|
case SPVC_BUILTIN_RESOURCE_TYPE_STAGE_INPUT:
|
|
list = &resources->builtin_inputs;
|
|
break;
|
|
|
|
case SPVC_BUILTIN_RESOURCE_TYPE_STAGE_OUTPUT:
|
|
list = &resources->builtin_outputs;
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
if (!list)
|
|
{
|
|
resources->context->report_error("Invalid argument.");
|
|
return SPVC_ERROR_INVALID_ARGUMENT;
|
|
}
|
|
|
|
*resource_size = list->size();
|
|
*resource_list = list->data();
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
void spvc_compiler_set_decoration(spvc_compiler compiler, SpvId id, SpvDecoration decoration, unsigned argument)
|
|
{
|
|
compiler->compiler->set_decoration(id, static_cast<spv::Decoration>(decoration), argument);
|
|
}
|
|
|
|
void spvc_compiler_set_decoration_string(spvc_compiler compiler, SpvId id, SpvDecoration decoration,
|
|
const char *argument)
|
|
{
|
|
compiler->compiler->set_decoration_string(id, static_cast<spv::Decoration>(decoration), argument);
|
|
}
|
|
|
|
void spvc_compiler_set_name(spvc_compiler compiler, SpvId id, const char *argument)
|
|
{
|
|
compiler->compiler->set_name(id, argument);
|
|
}
|
|
|
|
void spvc_compiler_set_member_decoration(spvc_compiler compiler, spvc_type_id id, unsigned member_index,
|
|
SpvDecoration decoration, unsigned argument)
|
|
{
|
|
compiler->compiler->set_member_decoration(id, member_index, static_cast<spv::Decoration>(decoration), argument);
|
|
}
|
|
|
|
void spvc_compiler_set_member_decoration_string(spvc_compiler compiler, spvc_type_id id, unsigned member_index,
|
|
SpvDecoration decoration, const char *argument)
|
|
{
|
|
compiler->compiler->set_member_decoration_string(id, member_index, static_cast<spv::Decoration>(decoration),
|
|
argument);
|
|
}
|
|
|
|
void spvc_compiler_set_member_name(spvc_compiler compiler, spvc_type_id id, unsigned member_index, const char *argument)
|
|
{
|
|
compiler->compiler->set_member_name(id, member_index, argument);
|
|
}
|
|
|
|
void spvc_compiler_unset_decoration(spvc_compiler compiler, SpvId id, SpvDecoration decoration)
|
|
{
|
|
compiler->compiler->unset_decoration(id, static_cast<spv::Decoration>(decoration));
|
|
}
|
|
|
|
void spvc_compiler_unset_member_decoration(spvc_compiler compiler, spvc_type_id id, unsigned member_index,
|
|
SpvDecoration decoration)
|
|
{
|
|
compiler->compiler->unset_member_decoration(id, member_index, static_cast<spv::Decoration>(decoration));
|
|
}
|
|
|
|
spvc_bool spvc_compiler_has_decoration(spvc_compiler compiler, SpvId id, SpvDecoration decoration)
|
|
{
|
|
return compiler->compiler->has_decoration(id, static_cast<spv::Decoration>(decoration)) ? SPVC_TRUE : SPVC_FALSE;
|
|
}
|
|
|
|
spvc_bool spvc_compiler_has_member_decoration(spvc_compiler compiler, spvc_type_id id, unsigned member_index,
|
|
SpvDecoration decoration)
|
|
{
|
|
return compiler->compiler->has_member_decoration(id, member_index, static_cast<spv::Decoration>(decoration)) ?
|
|
SPVC_TRUE :
|
|
SPVC_FALSE;
|
|
}
|
|
|
|
const char *spvc_compiler_get_name(spvc_compiler compiler, SpvId id)
|
|
{
|
|
return compiler->compiler->get_name(id).c_str();
|
|
}
|
|
|
|
unsigned spvc_compiler_get_decoration(spvc_compiler compiler, SpvId id, SpvDecoration decoration)
|
|
{
|
|
return compiler->compiler->get_decoration(id, static_cast<spv::Decoration>(decoration));
|
|
}
|
|
|
|
const char *spvc_compiler_get_decoration_string(spvc_compiler compiler, SpvId id, SpvDecoration decoration)
|
|
{
|
|
return compiler->compiler->get_decoration_string(id, static_cast<spv::Decoration>(decoration)).c_str();
|
|
}
|
|
|
|
unsigned spvc_compiler_get_member_decoration(spvc_compiler compiler, spvc_type_id id, unsigned member_index,
|
|
SpvDecoration decoration)
|
|
{
|
|
return compiler->compiler->get_member_decoration(id, member_index, static_cast<spv::Decoration>(decoration));
|
|
}
|
|
|
|
const char *spvc_compiler_get_member_decoration_string(spvc_compiler compiler, spvc_type_id id, unsigned member_index,
|
|
SpvDecoration decoration)
|
|
{
|
|
return compiler->compiler->get_member_decoration_string(id, member_index, static_cast<spv::Decoration>(decoration))
|
|
.c_str();
|
|
}
|
|
|
|
const char *spvc_compiler_get_member_name(spvc_compiler compiler, spvc_type_id id, unsigned member_index)
|
|
{
|
|
return compiler->compiler->get_member_name(id, member_index).c_str();
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_entry_points(spvc_compiler compiler, const spvc_entry_point **entry_points,
|
|
size_t *num_entry_points)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
auto entries = compiler->compiler->get_entry_points_and_stages();
|
|
SmallVector<spvc_entry_point> translated;
|
|
translated.reserve(entries.size());
|
|
|
|
for (auto &entry : entries)
|
|
{
|
|
spvc_entry_point new_entry;
|
|
new_entry.execution_model = static_cast<SpvExecutionModel>(entry.execution_model);
|
|
new_entry.name = compiler->context->allocate_name(entry.name);
|
|
if (!new_entry.name)
|
|
{
|
|
compiler->context->report_error("Out of memory.");
|
|
return SPVC_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
translated.push_back(new_entry);
|
|
}
|
|
|
|
auto ptr = spvc_allocate<TemporaryBuffer<spvc_entry_point>>();
|
|
ptr->buffer = std::move(translated);
|
|
*entry_points = ptr->buffer.data();
|
|
*num_entry_points = ptr->buffer.size();
|
|
compiler->context->allocations.push_back(std::move(ptr));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_OUT_OF_MEMORY)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_set_entry_point(spvc_compiler compiler, const char *name, SpvExecutionModel model)
|
|
{
|
|
compiler->compiler->set_entry_point(name, static_cast<spv::ExecutionModel>(model));
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_rename_entry_point(spvc_compiler compiler, const char *old_name, const char *new_name,
|
|
SpvExecutionModel model)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
compiler->compiler->rename_entry_point(old_name, new_name, static_cast<spv::ExecutionModel>(model));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_INVALID_ARGUMENT)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
const char *spvc_compiler_get_cleansed_entry_point_name(spvc_compiler compiler, const char *name,
|
|
SpvExecutionModel model)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
auto cleansed_name =
|
|
compiler->compiler->get_cleansed_entry_point_name(name, static_cast<spv::ExecutionModel>(model));
|
|
return compiler->context->allocate_name(cleansed_name);
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, nullptr)
|
|
}
|
|
|
|
void spvc_compiler_set_execution_mode(spvc_compiler compiler, SpvExecutionMode mode)
|
|
{
|
|
compiler->compiler->set_execution_mode(static_cast<spv::ExecutionMode>(mode));
|
|
}
|
|
|
|
void spvc_compiler_set_execution_mode_with_arguments(spvc_compiler compiler, SpvExecutionMode mode, unsigned arg0,
|
|
unsigned arg1,
|
|
unsigned arg2)
|
|
{
|
|
compiler->compiler->set_execution_mode(static_cast<spv::ExecutionMode>(mode), arg0, arg1, arg2);
|
|
}
|
|
|
|
void spvc_compiler_unset_execution_mode(spvc_compiler compiler, SpvExecutionMode mode)
|
|
{
|
|
compiler->compiler->unset_execution_mode(static_cast<spv::ExecutionMode>(mode));
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_execution_modes(spvc_compiler compiler, const SpvExecutionMode **modes, size_t *num_modes)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
auto ptr = spvc_allocate<TemporaryBuffer<SpvExecutionMode>>();
|
|
|
|
compiler->compiler->get_execution_mode_bitset().for_each_bit(
|
|
[&](uint32_t bit) { ptr->buffer.push_back(static_cast<SpvExecutionMode>(bit)); });
|
|
|
|
*modes = ptr->buffer.data();
|
|
*num_modes = ptr->buffer.size();
|
|
compiler->context->allocations.push_back(std::move(ptr));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_OUT_OF_MEMORY)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
unsigned spvc_compiler_get_execution_mode_argument(spvc_compiler compiler, SpvExecutionMode mode)
|
|
{
|
|
return compiler->compiler->get_execution_mode_argument(static_cast<spv::ExecutionMode>(mode));
|
|
}
|
|
|
|
unsigned spvc_compiler_get_execution_mode_argument_by_index(spvc_compiler compiler, SpvExecutionMode mode,
|
|
unsigned index)
|
|
{
|
|
return compiler->compiler->get_execution_mode_argument(static_cast<spv::ExecutionMode>(mode), index);
|
|
}
|
|
|
|
SpvExecutionModel spvc_compiler_get_execution_model(spvc_compiler compiler)
|
|
{
|
|
return static_cast<SpvExecutionModel>(compiler->compiler->get_execution_model());
|
|
}
|
|
|
|
void spvc_compiler_update_active_builtins(spvc_compiler compiler)
|
|
{
|
|
compiler->compiler->update_active_builtins();
|
|
}
|
|
|
|
spvc_bool spvc_compiler_has_active_builtin(spvc_compiler compiler, SpvBuiltIn builtin, SpvStorageClass storage)
|
|
{
|
|
return compiler->compiler->has_active_builtin(static_cast<spv::BuiltIn>(builtin), static_cast<spv::StorageClass>(storage)) ?
|
|
SPVC_TRUE :
|
|
SPVC_FALSE;
|
|
}
|
|
|
|
spvc_type spvc_compiler_get_type_handle(spvc_compiler compiler, spvc_type_id id)
|
|
{
|
|
// Should only throw if an intentionally garbage ID is passed, but the IDs are not type-safe.
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
return static_cast<spvc_type>(&compiler->compiler->get_type(id));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, nullptr)
|
|
}
|
|
|
|
spvc_type_id spvc_type_get_base_type_id(spvc_type type)
|
|
{
|
|
return type->self;
|
|
}
|
|
|
|
static spvc_basetype convert_basetype(SPIRType::BaseType type)
|
|
{
|
|
// For now the enums match up.
|
|
return static_cast<spvc_basetype>(type);
|
|
}
|
|
|
|
spvc_basetype spvc_type_get_basetype(spvc_type type)
|
|
{
|
|
return convert_basetype(type->basetype);
|
|
}
|
|
|
|
unsigned spvc_type_get_bit_width(spvc_type type)
|
|
{
|
|
return type->width;
|
|
}
|
|
|
|
unsigned spvc_type_get_vector_size(spvc_type type)
|
|
{
|
|
return type->vecsize;
|
|
}
|
|
|
|
unsigned spvc_type_get_columns(spvc_type type)
|
|
{
|
|
return type->columns;
|
|
}
|
|
|
|
unsigned spvc_type_get_num_array_dimensions(spvc_type type)
|
|
{
|
|
return unsigned(type->array.size());
|
|
}
|
|
|
|
spvc_bool spvc_type_array_dimension_is_literal(spvc_type type, unsigned dimension)
|
|
{
|
|
return type->array_size_literal[dimension] ? SPVC_TRUE : SPVC_FALSE;
|
|
}
|
|
|
|
SpvId spvc_type_get_array_dimension(spvc_type type, unsigned dimension)
|
|
{
|
|
return type->array[dimension];
|
|
}
|
|
|
|
unsigned spvc_type_get_num_member_types(spvc_type type)
|
|
{
|
|
return unsigned(type->member_types.size());
|
|
}
|
|
|
|
spvc_type_id spvc_type_get_member_type(spvc_type type, unsigned index)
|
|
{
|
|
return type->member_types[index];
|
|
}
|
|
|
|
SpvStorageClass spvc_type_get_storage_class(spvc_type type)
|
|
{
|
|
return static_cast<SpvStorageClass>(type->storage);
|
|
}
|
|
|
|
// Image type query.
|
|
spvc_type_id spvc_type_get_image_sampled_type(spvc_type type)
|
|
{
|
|
return type->image.type;
|
|
}
|
|
|
|
SpvDim spvc_type_get_image_dimension(spvc_type type)
|
|
{
|
|
return static_cast<SpvDim>(type->image.dim);
|
|
}
|
|
|
|
spvc_bool spvc_type_get_image_is_depth(spvc_type type)
|
|
{
|
|
return type->image.depth ? SPVC_TRUE : SPVC_FALSE;
|
|
}
|
|
|
|
spvc_bool spvc_type_get_image_arrayed(spvc_type type)
|
|
{
|
|
return type->image.arrayed ? SPVC_TRUE : SPVC_FALSE;
|
|
}
|
|
|
|
spvc_bool spvc_type_get_image_multisampled(spvc_type type)
|
|
{
|
|
return type->image.ms ? SPVC_TRUE : SPVC_FALSE;
|
|
}
|
|
|
|
spvc_bool spvc_type_get_image_is_storage(spvc_type type)
|
|
{
|
|
return type->image.sampled == 2 ? SPVC_TRUE : SPVC_FALSE;
|
|
}
|
|
|
|
SpvImageFormat spvc_type_get_image_storage_format(spvc_type type)
|
|
{
|
|
return static_cast<SpvImageFormat>(static_cast<const SPIRType *>(type)->image.format);
|
|
}
|
|
|
|
SpvAccessQualifier spvc_type_get_image_access_qualifier(spvc_type type)
|
|
{
|
|
return static_cast<SpvAccessQualifier>(static_cast<const SPIRType *>(type)->image.access);
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_declared_struct_size(spvc_compiler compiler, spvc_type struct_type, size_t *size)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
*size = compiler->compiler->get_declared_struct_size(*static_cast<const SPIRType *>(struct_type));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_INVALID_ARGUMENT)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_declared_struct_size_runtime_array(spvc_compiler compiler, spvc_type struct_type,
|
|
size_t array_size, size_t *size)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
*size = compiler->compiler->get_declared_struct_size_runtime_array(*static_cast<const SPIRType *>(struct_type),
|
|
array_size);
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_INVALID_ARGUMENT)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_declared_struct_member_size(spvc_compiler compiler, spvc_type struct_type, unsigned index, size_t *size)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
*size = compiler->compiler->get_declared_struct_member_size(*static_cast<const SPIRType *>(struct_type), index);
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_INVALID_ARGUMENT)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_type_struct_member_offset(spvc_compiler compiler, spvc_type type, unsigned index, unsigned *offset)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
*offset = compiler->compiler->type_struct_member_offset(*static_cast<const SPIRType *>(type), index);
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_INVALID_ARGUMENT)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_type_struct_member_array_stride(spvc_compiler compiler, spvc_type type, unsigned index, unsigned *stride)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
*stride = compiler->compiler->type_struct_member_array_stride(*static_cast<const SPIRType *>(type), index);
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_INVALID_ARGUMENT)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_type_struct_member_matrix_stride(spvc_compiler compiler, spvc_type type, unsigned index, unsigned *stride)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
*stride = compiler->compiler->type_struct_member_matrix_stride(*static_cast<const SPIRType *>(type), index);
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_INVALID_ARGUMENT)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_build_dummy_sampler_for_combined_images(spvc_compiler compiler, spvc_variable_id *id)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
*id = compiler->compiler->build_dummy_sampler_for_combined_images();
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_INVALID_ARGUMENT)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_build_combined_image_samplers(spvc_compiler compiler)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
compiler->compiler->build_combined_image_samplers();
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_UNSUPPORTED_SPIRV)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_combined_image_samplers(spvc_compiler compiler,
|
|
const spvc_combined_image_sampler **samplers,
|
|
size_t *num_samplers)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
auto combined = compiler->compiler->get_combined_image_samplers();
|
|
SmallVector<spvc_combined_image_sampler> translated;
|
|
translated.reserve(combined.size());
|
|
for (auto &c : combined)
|
|
{
|
|
spvc_combined_image_sampler trans = { c.combined_id, c.image_id, c.sampler_id };
|
|
translated.push_back(trans);
|
|
}
|
|
|
|
auto ptr = spvc_allocate<TemporaryBuffer<spvc_combined_image_sampler>>();
|
|
ptr->buffer = std::move(translated);
|
|
*samplers = ptr->buffer.data();
|
|
*num_samplers = ptr->buffer.size();
|
|
compiler->context->allocations.push_back(std::move(ptr));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_OUT_OF_MEMORY)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_specialization_constants(spvc_compiler compiler,
|
|
const spvc_specialization_constant **constants,
|
|
size_t *num_constants)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
auto spec_constants = compiler->compiler->get_specialization_constants();
|
|
SmallVector<spvc_specialization_constant> translated;
|
|
translated.reserve(spec_constants.size());
|
|
for (auto &c : spec_constants)
|
|
{
|
|
spvc_specialization_constant trans = { c.id, c.constant_id };
|
|
translated.push_back(trans);
|
|
}
|
|
|
|
auto ptr = spvc_allocate<TemporaryBuffer<spvc_specialization_constant>>();
|
|
ptr->buffer = std::move(translated);
|
|
*constants = ptr->buffer.data();
|
|
*num_constants = ptr->buffer.size();
|
|
compiler->context->allocations.push_back(std::move(ptr));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_OUT_OF_MEMORY)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_constant spvc_compiler_get_constant_handle(spvc_compiler compiler, spvc_variable_id id)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
return static_cast<spvc_constant>(&compiler->compiler->get_constant(id));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, nullptr)
|
|
}
|
|
|
|
spvc_constant_id spvc_compiler_get_work_group_size_specialization_constants(spvc_compiler compiler,
|
|
spvc_specialization_constant *x,
|
|
spvc_specialization_constant *y,
|
|
spvc_specialization_constant *z)
|
|
{
|
|
SpecializationConstant tmpx;
|
|
SpecializationConstant tmpy;
|
|
SpecializationConstant tmpz;
|
|
spvc_constant_id ret = compiler->compiler->get_work_group_size_specialization_constants(tmpx, tmpy, tmpz);
|
|
x->id = tmpx.id;
|
|
x->constant_id = tmpx.constant_id;
|
|
y->id = tmpy.id;
|
|
y->constant_id = tmpy.constant_id;
|
|
z->id = tmpz.id;
|
|
z->constant_id = tmpz.constant_id;
|
|
return ret;
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_active_buffer_ranges(spvc_compiler compiler,
|
|
spvc_variable_id id,
|
|
const spvc_buffer_range **ranges,
|
|
size_t *num_ranges)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
auto active_ranges = compiler->compiler->get_active_buffer_ranges(id);
|
|
SmallVector<spvc_buffer_range> translated;
|
|
translated.reserve(active_ranges.size());
|
|
for (auto &r : active_ranges)
|
|
{
|
|
spvc_buffer_range trans = { r.index, r.offset, r.range };
|
|
translated.push_back(trans);
|
|
}
|
|
|
|
auto ptr = spvc_allocate<TemporaryBuffer<spvc_buffer_range>>();
|
|
ptr->buffer = std::move(translated);
|
|
*ranges = ptr->buffer.data();
|
|
*num_ranges = ptr->buffer.size();
|
|
compiler->context->allocations.push_back(std::move(ptr));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_OUT_OF_MEMORY)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
float spvc_constant_get_scalar_fp16(spvc_constant constant, unsigned column, unsigned row)
|
|
{
|
|
return constant->scalar_f16(column, row);
|
|
}
|
|
|
|
float spvc_constant_get_scalar_fp32(spvc_constant constant, unsigned column, unsigned row)
|
|
{
|
|
return constant->scalar_f32(column, row);
|
|
}
|
|
|
|
double spvc_constant_get_scalar_fp64(spvc_constant constant, unsigned column, unsigned row)
|
|
{
|
|
return constant->scalar_f64(column, row);
|
|
}
|
|
|
|
unsigned spvc_constant_get_scalar_u32(spvc_constant constant, unsigned column, unsigned row)
|
|
{
|
|
return constant->scalar(column, row);
|
|
}
|
|
|
|
int spvc_constant_get_scalar_i32(spvc_constant constant, unsigned column, unsigned row)
|
|
{
|
|
return constant->scalar_i32(column, row);
|
|
}
|
|
|
|
unsigned spvc_constant_get_scalar_u16(spvc_constant constant, unsigned column, unsigned row)
|
|
{
|
|
return constant->scalar_u16(column, row);
|
|
}
|
|
|
|
int spvc_constant_get_scalar_i16(spvc_constant constant, unsigned column, unsigned row)
|
|
{
|
|
return constant->scalar_i16(column, row);
|
|
}
|
|
|
|
unsigned spvc_constant_get_scalar_u8(spvc_constant constant, unsigned column, unsigned row)
|
|
{
|
|
return constant->scalar_u8(column, row);
|
|
}
|
|
|
|
int spvc_constant_get_scalar_i8(spvc_constant constant, unsigned column, unsigned row)
|
|
{
|
|
return constant->scalar_i8(column, row);
|
|
}
|
|
|
|
void spvc_constant_get_subconstants(spvc_constant constant, const spvc_constant_id **constituents, size_t *count)
|
|
{
|
|
static_assert(sizeof(spvc_constant_id) == sizeof(constant->subconstants.front()), "ID size is not consistent.");
|
|
*constituents = reinterpret_cast<spvc_constant_id *>(constant->subconstants.data());
|
|
*count = constant->subconstants.size();
|
|
}
|
|
|
|
spvc_type_id spvc_constant_get_type(spvc_constant constant)
|
|
{
|
|
return constant->constant_type;
|
|
}
|
|
|
|
spvc_bool spvc_compiler_get_binary_offset_for_decoration(spvc_compiler compiler, spvc_variable_id id,
|
|
SpvDecoration decoration,
|
|
unsigned *word_offset)
|
|
{
|
|
uint32_t off = 0;
|
|
bool ret = compiler->compiler->get_binary_offset_for_decoration(id, static_cast<spv::Decoration>(decoration), off);
|
|
if (ret)
|
|
{
|
|
*word_offset = off;
|
|
return SPVC_TRUE;
|
|
}
|
|
else
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
spvc_bool spvc_compiler_buffer_is_hlsl_counter_buffer(spvc_compiler compiler, spvc_variable_id id)
|
|
{
|
|
return compiler->compiler->buffer_is_hlsl_counter_buffer(id) ? SPVC_TRUE : SPVC_FALSE;
|
|
}
|
|
|
|
spvc_bool spvc_compiler_buffer_get_hlsl_counter_buffer(spvc_compiler compiler, spvc_variable_id id,
|
|
spvc_variable_id *counter_id)
|
|
{
|
|
uint32_t buffer;
|
|
bool ret = compiler->compiler->buffer_get_hlsl_counter_buffer(id, buffer);
|
|
if (ret)
|
|
{
|
|
*counter_id = buffer;
|
|
return SPVC_TRUE;
|
|
}
|
|
else
|
|
return SPVC_FALSE;
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_declared_capabilities(spvc_compiler compiler, const SpvCapability **capabilities,
|
|
size_t *num_capabilities)
|
|
{
|
|
auto &caps = compiler->compiler->get_declared_capabilities();
|
|
static_assert(sizeof(SpvCapability) == sizeof(spv::Capability), "Enum size mismatch.");
|
|
*capabilities = reinterpret_cast<const SpvCapability *>(caps.data());
|
|
*num_capabilities = caps.size();
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_declared_extensions(spvc_compiler compiler, const char ***extensions,
|
|
size_t *num_extensions)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
auto &exts = compiler->compiler->get_declared_extensions();
|
|
SmallVector<const char *> duped;
|
|
duped.reserve(exts.size());
|
|
for (auto &ext : exts)
|
|
duped.push_back(compiler->context->allocate_name(ext));
|
|
|
|
auto ptr = spvc_allocate<TemporaryBuffer<const char *>>();
|
|
ptr->buffer = std::move(duped);
|
|
*extensions = ptr->buffer.data();
|
|
*num_extensions = ptr->buffer.size();
|
|
compiler->context->allocations.push_back(std::move(ptr));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_OUT_OF_MEMORY)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
const char *spvc_compiler_get_remapped_declared_block_name(spvc_compiler compiler, spvc_variable_id id)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
auto name = compiler->compiler->get_remapped_declared_block_name(id);
|
|
return compiler->context->allocate_name(name);
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, nullptr)
|
|
}
|
|
|
|
spvc_result spvc_compiler_get_buffer_block_decorations(spvc_compiler compiler, spvc_variable_id id,
|
|
const SpvDecoration **decorations, size_t *num_decorations)
|
|
{
|
|
SPVC_BEGIN_SAFE_SCOPE
|
|
{
|
|
auto flags = compiler->compiler->get_buffer_block_flags(id);
|
|
auto bitset = spvc_allocate<TemporaryBuffer<SpvDecoration>>();
|
|
|
|
flags.for_each_bit([&](uint32_t bit) { bitset->buffer.push_back(static_cast<SpvDecoration>(bit)); });
|
|
|
|
*decorations = bitset->buffer.data();
|
|
*num_decorations = bitset->buffer.size();
|
|
compiler->context->allocations.push_back(std::move(bitset));
|
|
}
|
|
SPVC_END_SAFE_SCOPE(compiler->context, SPVC_ERROR_INVALID_ARGUMENT)
|
|
return SPVC_SUCCESS;
|
|
}
|
|
|
|
unsigned spvc_msl_get_aux_buffer_struct_version(void)
|
|
{
|
|
return SPVC_MSL_AUX_BUFFER_STRUCT_VERSION;
|
|
}
|
|
|
|
void spvc_msl_vertex_attribute_init(spvc_msl_vertex_attribute *attr)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
// Crude, but works.
|
|
MSLShaderInterfaceVariable attr_default;
|
|
attr->location = attr_default.location;
|
|
attr->format = static_cast<spvc_msl_vertex_format>(attr_default.format);
|
|
attr->builtin = static_cast<SpvBuiltIn>(attr_default.builtin);
|
|
#else
|
|
memset(attr, 0, sizeof(*attr));
|
|
#endif
|
|
}
|
|
|
|
void spvc_msl_shader_interface_var_init(spvc_msl_shader_interface_var *var)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
MSLShaderInterfaceVariable var_default;
|
|
var->location = var_default.location;
|
|
var->format = static_cast<spvc_msl_shader_variable_format>(var_default.format);
|
|
var->builtin = static_cast<SpvBuiltIn>(var_default.builtin);
|
|
var->vecsize = var_default.vecsize;
|
|
#else
|
|
memset(var, 0, sizeof(*var));
|
|
#endif
|
|
}
|
|
|
|
void spvc_msl_shader_input_init(spvc_msl_shader_input *input)
|
|
{
|
|
spvc_msl_shader_interface_var_init(input);
|
|
}
|
|
|
|
void spvc_msl_shader_interface_var_init_2(spvc_msl_shader_interface_var_2 *var)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
MSLShaderInterfaceVariable var_default;
|
|
var->location = var_default.location;
|
|
var->format = static_cast<spvc_msl_shader_variable_format>(var_default.format);
|
|
var->builtin = static_cast<SpvBuiltIn>(var_default.builtin);
|
|
var->vecsize = var_default.vecsize;
|
|
var->rate = static_cast<spvc_msl_shader_variable_rate>(var_default.rate);
|
|
#else
|
|
memset(var, 0, sizeof(*var));
|
|
#endif
|
|
}
|
|
|
|
void spvc_msl_resource_binding_init(spvc_msl_resource_binding *binding)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
MSLResourceBinding binding_default;
|
|
binding->desc_set = binding_default.desc_set;
|
|
binding->binding = binding_default.binding;
|
|
binding->msl_buffer = binding_default.msl_buffer;
|
|
binding->msl_texture = binding_default.msl_texture;
|
|
binding->msl_sampler = binding_default.msl_sampler;
|
|
binding->stage = static_cast<SpvExecutionModel>(binding_default.stage);
|
|
#else
|
|
memset(binding, 0, sizeof(*binding));
|
|
#endif
|
|
}
|
|
|
|
void spvc_hlsl_resource_binding_init(spvc_hlsl_resource_binding *binding)
|
|
{
|
|
#if SPIRV_CROSS_C_API_HLSL
|
|
HLSLResourceBinding binding_default;
|
|
binding->desc_set = binding_default.desc_set;
|
|
binding->binding = binding_default.binding;
|
|
binding->cbv.register_binding = binding_default.cbv.register_binding;
|
|
binding->cbv.register_space = binding_default.cbv.register_space;
|
|
binding->srv.register_binding = binding_default.srv.register_binding;
|
|
binding->srv.register_space = binding_default.srv.register_space;
|
|
binding->uav.register_binding = binding_default.uav.register_binding;
|
|
binding->uav.register_space = binding_default.uav.register_space;
|
|
binding->sampler.register_binding = binding_default.sampler.register_binding;
|
|
binding->sampler.register_space = binding_default.sampler.register_space;
|
|
binding->stage = static_cast<SpvExecutionModel>(binding_default.stage);
|
|
#else
|
|
memset(binding, 0, sizeof(*binding));
|
|
#endif
|
|
}
|
|
|
|
void spvc_msl_constexpr_sampler_init(spvc_msl_constexpr_sampler *sampler)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
MSLConstexprSampler defaults;
|
|
sampler->anisotropy_enable = defaults.anisotropy_enable ? SPVC_TRUE : SPVC_FALSE;
|
|
sampler->border_color = static_cast<spvc_msl_sampler_border_color>(defaults.border_color);
|
|
sampler->compare_enable = defaults.compare_enable ? SPVC_TRUE : SPVC_FALSE;
|
|
sampler->coord = static_cast<spvc_msl_sampler_coord>(defaults.coord);
|
|
sampler->compare_func = static_cast<spvc_msl_sampler_compare_func>(defaults.compare_func);
|
|
sampler->lod_clamp_enable = defaults.lod_clamp_enable ? SPVC_TRUE : SPVC_FALSE;
|
|
sampler->lod_clamp_max = defaults.lod_clamp_max;
|
|
sampler->lod_clamp_min = defaults.lod_clamp_min;
|
|
sampler->mag_filter = static_cast<spvc_msl_sampler_filter>(defaults.mag_filter);
|
|
sampler->min_filter = static_cast<spvc_msl_sampler_filter>(defaults.min_filter);
|
|
sampler->mip_filter = static_cast<spvc_msl_sampler_mip_filter>(defaults.mip_filter);
|
|
sampler->max_anisotropy = defaults.max_anisotropy;
|
|
sampler->s_address = static_cast<spvc_msl_sampler_address>(defaults.s_address);
|
|
sampler->t_address = static_cast<spvc_msl_sampler_address>(defaults.t_address);
|
|
sampler->r_address = static_cast<spvc_msl_sampler_address>(defaults.r_address);
|
|
#else
|
|
memset(sampler, 0, sizeof(*sampler));
|
|
#endif
|
|
}
|
|
|
|
void spvc_msl_sampler_ycbcr_conversion_init(spvc_msl_sampler_ycbcr_conversion *conv)
|
|
{
|
|
#if SPIRV_CROSS_C_API_MSL
|
|
MSLConstexprSampler defaults;
|
|
conv->planes = defaults.planes;
|
|
conv->resolution = static_cast<spvc_msl_format_resolution>(defaults.resolution);
|
|
conv->chroma_filter = static_cast<spvc_msl_sampler_filter>(defaults.chroma_filter);
|
|
conv->x_chroma_offset = static_cast<spvc_msl_chroma_location>(defaults.x_chroma_offset);
|
|
conv->y_chroma_offset = static_cast<spvc_msl_chroma_location>(defaults.y_chroma_offset);
|
|
for (int i = 0; i < 4; i++)
|
|
conv->swizzle[i] = static_cast<spvc_msl_component_swizzle>(defaults.swizzle[i]);
|
|
conv->ycbcr_model = static_cast<spvc_msl_sampler_ycbcr_model_conversion>(defaults.ycbcr_model);
|
|
conv->ycbcr_range = static_cast<spvc_msl_sampler_ycbcr_range>(defaults.ycbcr_range);
|
|
#else
|
|
memset(conv, 0, sizeof(*conv));
|
|
#endif
|
|
}
|
|
|
|
unsigned spvc_compiler_get_current_id_bound(spvc_compiler compiler)
|
|
{
|
|
return compiler->compiler->get_current_id_bound();
|
|
}
|
|
|
|
void spvc_get_version(unsigned *major, unsigned *minor, unsigned *patch)
|
|
{
|
|
*major = SPVC_C_API_VERSION_MAJOR;
|
|
*minor = SPVC_C_API_VERSION_MINOR;
|
|
*patch = SPVC_C_API_VERSION_PATCH;
|
|
}
|
|
|
|
const char *spvc_get_commit_revision_and_timestamp(void)
|
|
{
|
|
#ifdef HAVE_SPIRV_CROSS_GIT_VERSION
|
|
return SPIRV_CROSS_GIT_REVISION;
|
|
#else
|
|
return "";
|
|
#endif
|
|
}
|
|
|
|
#ifdef _MSC_VER
|
|
#pragma warning(pop)
|
|
#endif
|