BsVulkanPrerequisites.h 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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. class VulkanResourceManager;
  39. VkAllocationCallbacks* gVulkanAllocator = nullptr;
  40. /** Vulkan specific types to track resource statistics for. */
  41. enum VulkanRenderStatResourceType
  42. {
  43. RenderStatObject_PipelineState = 100
  44. };
  45. /** Types of GPU queues. */
  46. enum VulkanQueueType
  47. {
  48. /**
  49. * Queue used for rendering. Allows the use of draw commands, but also all commands supported by compute
  50. * or upload buffers.
  51. */
  52. VQT_GRAPHICS,
  53. /** Discrete queue used for compute operations. Allows the use of dispatch and upload commands. */
  54. VQT_COMPUTE,
  55. /** Queue used for memory transfer operations only. No rendering or compute dispatch allowed. */
  56. VQT_UPLOAD,
  57. VQT_COUNT // Keep at end
  58. };
  59. }
  60. /** Macro to get a procedure address based on a Vulkan instance. */
  61. #define GET_INSTANCE_PROC_ADDR(instance, name) \
  62. vk##name = reinterpret_cast<PFN_vk##name>(vkGetInstanceProcAddr(instance, "vk"#name));
  63. /** Macro to get a procedure address based on a Vulkan device. */
  64. #define GET_DEVICE_PROC_ADDR(device, name) \
  65. vk##name = reinterpret_cast<PFN_vk##name>(vkGetDeviceProcAddr(device, "vk"#name));