summaryrefslogtreecommitdiffstats
path: root/tools/gfx/d3d
diff options
context:
space:
mode:
Diffstat (limited to 'tools/gfx/d3d')
-rw-r--r--tools/gfx/d3d/d3d-util.cpp25
-rw-r--r--tools/gfx/d3d/d3d-util.h2
2 files changed, 27 insertions, 0 deletions
diff --git a/tools/gfx/d3d/d3d-util.cpp b/tools/gfx/d3d/d3d-util.cpp
index d73b3f519..84b5de844 100644
--- a/tools/gfx/d3d/d3d-util.cpp
+++ b/tools/gfx/d3d/d3d-util.cpp
@@ -609,6 +609,31 @@ bool D3DUtil::isUAVBinding(slang::BindingType bindingType)
}
}
+int D3DUtil::getShaderModelFromProfileName(const char* name)
+{
+ UnownedStringSlice nameSlice(name);
+
+ if (nameSlice.endsWith("5_1"))
+ return D3D_SHADER_MODEL_5_1;
+ if (nameSlice.endsWith("6_0"))
+ return D3D_SHADER_MODEL_6_0;
+ if (nameSlice.endsWith("6_1"))
+ return D3D_SHADER_MODEL_6_1;
+ if (nameSlice.endsWith("6_2"))
+ return D3D_SHADER_MODEL_6_2;
+ if (nameSlice.endsWith("6_3"))
+ return D3D_SHADER_MODEL_6_3;
+ if (nameSlice.endsWith("6_4"))
+ return D3D_SHADER_MODEL_6_4;
+ if (nameSlice.endsWith("6_5"))
+ return D3D_SHADER_MODEL_6_5;
+ if (nameSlice.endsWith("6_6"))
+ return D3D_SHADER_MODEL_6_6;
+ if (nameSlice.endsWith("6_7"))
+ return 0x67;
+ return 0;
+}
+
/* static */SlangResult D3DUtil::findAdapters(DeviceCheckFlags flags, const UnownedStringSlice& adapterName, IDXGIFactory* dxgiFactory, List<ComPtr<IDXGIAdapter>>& outDxgiAdapters)
{
Slang::String lowerAdapterName = Slang::String(adapterName).toLower();
diff --git a/tools/gfx/d3d/d3d-util.h b/tools/gfx/d3d/d3d-util.h
index e570c6ff6..4bca89612 100644
--- a/tools/gfx/d3d/d3d-util.h
+++ b/tools/gfx/d3d/d3d-util.h
@@ -94,6 +94,8 @@ class D3DUtil
static bool isUAVBinding(slang::BindingType bindingType);
+ static int getShaderModelFromProfileName(const char* profile);
+
};
#if SLANG_GFX_HAS_DXR_SUPPORT