summaryrefslogtreecommitdiffstats
path: root/tools/gfx/vulkan/vk-util.cpp
diff options
context:
space:
mode:
authorjsmall-nvidia <jsmall@nvidia.com>2019-09-13 15:59:15 -0400
committerGitHub <noreply@github.com>2019-09-13 15:59:15 -0400
commitc2e5d2468ad6a38cdb8a067da0678302f6cc6066 (patch)
tree97c448d28e54068d84c422e9f172996b7a95f1ed /tools/gfx/vulkan/vk-util.cpp
parent0b6321b3f08c48e37e6b8256d420f05d9727fb5a (diff)
Refactor render-test to make cross platform (#1053)
* First pass of render-test refactor. * Make window construction a function that can choose an implementation. * Remove OpenGL as currently has windows dependency. * Disable Vulkan as Renderer impl has dependency on windows. * Pass Window in as parameter of 'update'. * Add win-window.cpp as was missing. * Fix warning on windows about signs during comparison.
Diffstat (limited to 'tools/gfx/vulkan/vk-util.cpp')
-rw-r--r--tools/gfx/vulkan/vk-util.cpp59
1 files changed, 59 insertions, 0 deletions
diff --git a/tools/gfx/vulkan/vk-util.cpp b/tools/gfx/vulkan/vk-util.cpp
new file mode 100644
index 000000000..e8940d1b2
--- /dev/null
+++ b/tools/gfx/vulkan/vk-util.cpp
@@ -0,0 +1,59 @@
+// vk-util.cpp
+#include "vk-util.h"
+
+#include <stdlib.h>
+#include <stdio.h>
+
+namespace gfx {
+
+/* static */VkFormat VulkanUtil::getVkFormat(Format format)
+{
+ switch (format)
+ {
+ case Format::RGBA_Float32: return VK_FORMAT_R32G32B32A32_SFLOAT;
+ case Format::RGB_Float32: return VK_FORMAT_R32G32B32_SFLOAT;
+ case Format::RG_Float32: return VK_FORMAT_R32G32_SFLOAT;
+ case Format::R_Float32: return VK_FORMAT_R32_SFLOAT;
+ case Format::RGBA_Unorm_UInt8: return VK_FORMAT_R8G8B8A8_UNORM;
+ case Format::R_UInt32: return VK_FORMAT_R32_UINT;
+
+ case Format::D_Float32: return VK_FORMAT_D32_SFLOAT;
+ case Format::D_Unorm24_S8: return VK_FORMAT_D24_UNORM_S8_UINT;
+
+ default: return VK_FORMAT_UNDEFINED;
+ }
+}
+
+/* static */SlangResult VulkanUtil::toSlangResult(VkResult res)
+{
+ return (res == VK_SUCCESS) ? SLANG_OK : SLANG_FAIL;
+}
+
+/* static */Slang::Result VulkanUtil::handleFail(VkResult res)
+{
+ if (res != VK_SUCCESS)
+ {
+ assert(!"Vulkan returned a failure");
+ }
+ return toSlangResult(res);
+}
+
+/* static */void VulkanUtil::checkFail(VkResult res)
+{
+ assert(res != VK_SUCCESS);
+ assert(!"Vulkan check failed");
+
+}
+
+/* static */VkPrimitiveTopology VulkanUtil::getVkPrimitiveTopology(PrimitiveTopology topology)
+{
+ switch (topology)
+ {
+ case PrimitiveTopology::TriangleList: return VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST;
+ default: break;
+ }
+ assert(!"Unknown topology");
+ return VK_PRIMITIVE_TOPOLOGY_MAX_ENUM;
+}
+
+} // renderer_test