From c5c1a25ab6d0e509e893d737a679ac47949df2f6 Mon Sep 17 00:00:00 2001 From: Yong He Date: Thu, 18 Jan 2024 16:46:00 -0800 Subject: Capability def parsing & codegen + disjoint sets (#3451) * Capability def parsing & codegen + disjoint sets This change adds a capability definition file, and a code generator to produce C++ code that defines the capability enums and necessary data structures around the capabilities. Extends the existing CapabilitySet class to support expressing disjoint sets of capabilities. This sets up for the next change that will enhance our type checking with reasoning of capability requirements. * Fix cmake. * Fix warning. * Fix. * Fix isBetterForTarget to prefer less specialized option. * Fix. * Fix premake. * Fix intrinsic. * Fix vs sln file. --------- Co-authored-by: Yong He --- build/visual-studio/compiler-core/compiler-core.vcxproj | 2 ++ .../compiler-core/compiler-core.vcxproj.filters | 6 ++++++ .../visual-studio/run-generators/run-generators.vcxproj | 17 +++++++++++++++++ .../run-generators/run-generators.vcxproj.filters | 9 +++++++++ build/visual-studio/slang/slang.vcxproj | 4 +++- build/visual-studio/slang/slang.vcxproj.filters | 12 +++++++++--- 6 files changed, 46 insertions(+), 4 deletions(-) (limited to 'build/visual-studio') diff --git a/build/visual-studio/compiler-core/compiler-core.vcxproj b/build/visual-studio/compiler-core/compiler-core.vcxproj index e2202aaca..22a19abb9 100644 --- a/build/visual-studio/compiler-core/compiler-core.vcxproj +++ b/build/visual-studio/compiler-core/compiler-core.vcxproj @@ -306,6 +306,7 @@ + @@ -354,6 +355,7 @@ + diff --git a/build/visual-studio/compiler-core/compiler-core.vcxproj.filters b/build/visual-studio/compiler-core/compiler-core.vcxproj.filters index 2d4e3663d..eb1d52dfb 100644 --- a/build/visual-studio/compiler-core/compiler-core.vcxproj.filters +++ b/build/visual-studio/compiler-core/compiler-core.vcxproj.filters @@ -132,6 +132,9 @@ Header Files + + Header Files + Header Files @@ -272,6 +275,9 @@ Source Files + + Source Files + Source Files diff --git a/build/visual-studio/run-generators/run-generators.vcxproj b/build/visual-studio/run-generators/run-generators.vcxproj index 8a143c391..dbd3a3947 100644 --- a/build/visual-studio/run-generators/run-generators.vcxproj +++ b/build/visual-studio/run-generators/run-generators.vcxproj @@ -319,6 +319,23 @@ ../../../bin/windows-x64/release/slang-cpp-extractor.exe;../../../source/slang/slang-ast-support-types.h;../../../source/slang/slang-ast-base.h;../../../source/slang/slang-ast-decl.h;../../../source/slang/slang-ast-expr.h;../../../source/slang/slang-ast-modifier.h;../../../source/slang/slang-ast-stmt.h;../../../source/slang/slang-ast-type.h;../../../source/slang/slang-ast-val.h ../../../bin/windows-aarch64/release/slang-cpp-extractor.exe;../../../source/slang/slang-ast-support-types.h;../../../source/slang/slang-ast-base.h;../../../source/slang/slang-ast-decl.h;../../../source/slang/slang-ast-expr.h;../../../source/slang/slang-ast-modifier.h;../../../source/slang/slang-ast-stmt.h;../../../source/slang/slang-ast-type.h;../../../source/slang/slang-ast-val.h + + Document + "../../../bin/windows-x86/debug/slang-capability-generator" "%(FullPath)" + "../../../bin/windows-x64/debug/slang-capability-generator" "%(FullPath)" + "../../../bin/windows-aarch64/debug/slang-capability-generator" "%(FullPath)" + "../../../bin/windows-x86/release/slang-capability-generator" "%(FullPath)" + "../../../bin/windows-x64/release/slang-capability-generator" "%(FullPath)" + "../../../bin/windows-aarch64/release/slang-capability-generator" "%(FullPath)" + ../../../source/slang/slang-generated-capability-defs.h + slang-capability-generator %(Identity) + ../../../source/slang/slang-capabilities.capdef;../../../bin/windows-x86/debug/slang-capability-generator.exe + ../../../source/slang/slang-capabilities.capdef;../../../bin/windows-x64/debug/slang-capability-generator.exe + ../../../source/slang/slang-capabilities.capdef;../../../bin/windows-aarch64/debug/slang-capability-generator.exe + ../../../source/slang/slang-capabilities.capdef;../../../bin/windows-x86/release/slang-capability-generator.exe + ../../../source/slang/slang-capabilities.capdef;../../../bin/windows-x64/release/slang-capability-generator.exe + ../../../source/slang/slang-capabilities.capdef;../../../bin/windows-aarch64/release/slang-capability-generator.exe + diff --git a/build/visual-studio/run-generators/run-generators.vcxproj.filters b/build/visual-studio/run-generators/run-generators.vcxproj.filters index 12c02fd18..c3c8330a8 100644 --- a/build/visual-studio/run-generators/run-generators.vcxproj.filters +++ b/build/visual-studio/run-generators/run-generators.vcxproj.filters @@ -7,6 +7,12 @@ {E9C7FDCE-D52A-8D73-7EB0-C5296AF258F6} + + {76FF3A1C-62A1-65F2-4B5C-7946379DEC42} + + + {9A9B9613-86FE-25B8-2F84-5E6E1BC6F13A} + @@ -58,5 +64,8 @@ Header Files + + source\slang + \ No newline at end of file diff --git a/build/visual-studio/slang/slang.vcxproj b/build/visual-studio/slang/slang.vcxproj index 30fe5d1bb..123bc734d 100644 --- a/build/visual-studio/slang/slang.vcxproj +++ b/build/visual-studio/slang/slang.vcxproj @@ -325,7 +325,6 @@ IF EXIST ..\..\..\external\slang-glslang\bin\windows-aarch64\release\slang-glsla - @@ -347,6 +346,8 @@ IF EXIST ..\..\..\external\slang-glslang\bin\windows-aarch64\release\slang-glsla + + @@ -698,6 +699,7 @@ IF EXIST ..\..\..\external\slang-glslang\bin\windows-aarch64\release\slang-glsla + diff --git a/build/visual-studio/slang/slang.vcxproj.filters b/build/visual-studio/slang/slang.vcxproj.filters index 320886c18..9f91b13f1 100644 --- a/build/visual-studio/slang/slang.vcxproj.filters +++ b/build/visual-studio/slang/slang.vcxproj.filters @@ -63,9 +63,6 @@ Header Files - - Header Files - Header Files @@ -129,6 +126,12 @@ Header Files + + Header Files + + + Header Files + Header Files @@ -1178,6 +1181,9 @@ Source Files + + Source Files + Source Files -- cgit v1.2.3