summaryrefslogtreecommitdiffstats
path: root/source/slang/slang-options.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'source/slang/slang-options.cpp')
-rw-r--r--source/slang/slang-options.cpp45
1 files changed, 45 insertions, 0 deletions
diff --git a/source/slang/slang-options.cpp b/source/slang/slang-options.cpp
index 3227e2de4..9141188df 100644
--- a/source/slang/slang-options.cpp
+++ b/source/slang/slang-options.cpp
@@ -53,6 +53,7 @@ enum class ValueCategory
Target,
Language,
FloatingPointMode,
+ FloatingPointDenormalMode,
ArchiveType,
Stage,
LineDirectiveMode,
@@ -85,6 +86,7 @@ SLANG_GET_VALUE_CATEGORY(Compiler, SlangPassThrough)
SLANG_GET_VALUE_CATEGORY(ArchiveType, SlangArchiveType)
SLANG_GET_VALUE_CATEGORY(LineDirectiveMode, SlangLineDirectiveMode)
SLANG_GET_VALUE_CATEGORY(FloatingPointMode, FloatingPointMode)
+SLANG_GET_VALUE_CATEGORY(FloatingPointDenormalMode, FloatingPointDenormalMode)
SLANG_GET_VALUE_CATEGORY(FileSystemType, TypeTextUtil::FileSystemType)
SLANG_GET_VALUE_CATEGORY(HelpStyle, CommandOptionsWriter::Style)
SLANG_GET_VALUE_CATEGORY(OptimizationLevel, SlangOptimizationLevel)
@@ -186,6 +188,13 @@ void initCommandOptions(CommandOptions& options)
options.addCategory(
CategoryKind::Value,
+ "fp-denormal-mode",
+ "Floating Point Denormal Handling Mode",
+ UserValue(ValueCategory::FloatingPointDenormalMode));
+ options.addValues(TypeTextUtil::getFpDenormalModeInfos());
+
+ options.addCategory(
+ CategoryKind::Value,
"help-style",
"Help Style",
UserValue(ValueCategory::HelpStyle));
@@ -580,6 +589,21 @@ void initCommandOptions(CommandOptions& options)
"-fp-mode,-floating-point-mode",
"-fp-mode <fp-mode>, -floating-point-mode <fp-mode>",
"Control floating point optimizations"},
+ {OptionKind::DenormalModeFp16,
+ "-denorm-mode-fp16",
+ "-denorm-mode-fp16 <fp-denormal-mode>",
+ "Control handling of 16-bit denormal floating point values in SPIR-V (any, preserve, "
+ "ftz)"},
+ {OptionKind::DenormalModeFp32,
+ "-denorm-mode-fp32",
+ "-denorm-mode-fp32 <fp-denormal-mode>",
+ "Control handling of 32-bit denormal floating point values in SPIR-V and DXIL (any, "
+ "preserve, ftz)"},
+ {OptionKind::DenormalModeFp64,
+ "-denorm-mode-fp64",
+ "-denorm-mode-fp64 <fp-denormal-mode>",
+ "Control handling of 64-bit denormal floating point values in SPIR-V (any, preserve, "
+ "ftz)"},
{OptionKind::DebugInformation,
"-g...",
"-g, -g<debug-info-format>, -g<debug-level>",
@@ -2802,6 +2826,27 @@ SlangResult OptionsParser::_parse(int argc, char const* const* argv)
setFloatingPointMode(getCurrentTarget(), value);
break;
}
+ case OptionKind::DenormalModeFp16:
+ {
+ FloatingPointDenormalMode value;
+ SLANG_RETURN_ON_FAIL(_expectValue(value));
+ linkage->m_optionSet.set(CompilerOptionName::DenormalModeFp16, value);
+ break;
+ }
+ case OptionKind::DenormalModeFp32:
+ {
+ FloatingPointDenormalMode value;
+ SLANG_RETURN_ON_FAIL(_expectValue(value));
+ linkage->m_optionSet.set(CompilerOptionName::DenormalModeFp32, value);
+ break;
+ }
+ case OptionKind::DenormalModeFp64:
+ {
+ FloatingPointDenormalMode value;
+ SLANG_RETURN_ON_FAIL(_expectValue(value));
+ linkage->m_optionSet.set(CompilerOptionName::DenormalModeFp64, value);
+ break;
+ }
case OptionKind::Optimization:
{
UnownedStringSlice levelSlice = argValue.getUnownedSlice().tail(2);