BsVulkanPrerequisites.h 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. //********************************** Banshee Engine (www.banshee3d.com) **************************************************//
  2. //**************** Copyright (c) 2016 Marko Pintera ([email protected]). All rights reserved. **********************//
  3. #pragma once
  4. #include "BsCorePrerequisites.h"
  5. #define WIN32_LEAN_AND_MEAN
  6. #if !defined(NOMINMAX) && defined(_MSC_VER)
  7. # define NOMINMAX // Required to stop windows.h messing up std::min
  8. #endif
  9. #if BS_PLATFORM == BS_PLATFORM_WIN32
  10. #define VK_USE_PLATFORM_WIN32_KHR
  11. #endif
  12. #include "vulkan/vulkan.h"
  13. /** @addtogroup Plugins
  14. * @{
  15. */
  16. /** @defgroup Vulkan BansheeVulkanRenderAPI
  17. * Wrapper around the Vulkan render API.
  18. */
  19. /** @} */
  20. namespace BansheeEngine
  21. {
  22. class VulkanRenderAPI;
  23. class Win32RenderWindow;
  24. class VulkanTexture;
  25. class Win32VideoMode;
  26. class VulkanIndexBuffer;
  27. class VulkanVertexDeclaration;
  28. class VulkanHardwareBuffer;
  29. class VulkanDevice;
  30. class VulkanGLSLProgramFactory;
  31. class VulkanSwapChain;
  32. class VulkanDescriptorLayout;
  33. class VulkanDescriptorManager;
  34. class VulkanCmdBufferPool;
  35. class VulkanCmdBuffer;
  36. class VulkanCommandBuffer;
  37. class VulkanQueue;
  38. VkAllocationCallbacks* gVulkanAllocator = nullptr;
  39. /** Vulkan specific types to track resource statistics for. */
  40. enum VulkanRenderStatResourceType
  41. {
  42. RenderStatObject_PipelineState = 100
  43. };
  44. /** Types of GPU queues. */
  45. enum VulkanQueueType
  46. {
  47. /**
  48. * Queue used for rendering. Allows the use of draw commands, but also all commands supported by compute
  49. * or upload buffers.
  50. */
  51. VQT_GRAPHICS,
  52. /** Discrete queue used for compute operations. Allows the use of dispatch and upload commands. */
  53. VQT_COMPUTE,
  54. /** Queue used for memory transfer operations only. No rendering or compute dispatch allowed. */
  55. VQT_UPLOAD,
  56. VQT_COUNT // Keep at end
  57. };
  58. }
  59. /** Macro to get a procedure address based on a Vulkan instance. */
  60. #define GET_INSTANCE_PROC_ADDR(instance, name) \
  61. vk##name = reinterpret_cast<PFN_vk##name>(vkGetInstanceProcAddr(instance, "vk"#name));
  62. /** Macro to get a procedure address based on a Vulkan device. */
  63. #define GET_DEVICE_PROC_ADDR(device, name) \
  64. vk##name = reinterpret_cast<PFN_vk##name>(vkGetDeviceProcAddr(device, "vk"#name));