system.d 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372
  1. /*
  2. Boost Software License - Version 1.0 - August 17th, 2003
  3. Permission is hereby granted, free of charge, to any person or organization
  4. obtaining a copy of the software and accompanying documentation covered by
  5. this license (the "Software") to use, reproduce, display, distribute,
  6. execute, and transmit the Software, and to prepare derivative works of the
  7. Software, and to permit third-parties to whom the Software is furnished to
  8. do so, all subject to the following:
  9. The copyright notices in the Software and this entire statement, including
  10. the above license grant, this restriction and the following disclaimer,
  11. must be included in all copies of the Software, in whole or in part, and
  12. all derivative works of the Software, unless such copies or derivative
  13. works are solely in the form of machine-executable object code generated by
  14. a source language processor.
  15. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  17. FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
  18. SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
  19. FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
  20. ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  21. DEALINGS IN THE SOFTWARE.
  22. */
  23. module derelict.vulkan.system;
  24. public import derelict.vulkan.base;
  25. public import derelict.vulkan.types;
  26. import derelict.util.system;
  27. enum VKSystem {
  28. Other = 0,
  29. Windows = 1 << 0,
  30. Android = 1 << 1,
  31. Posix = 1 << 2
  32. }
  33. mixin SystemFunctionality;
  34. private:
  35. import std.conv;
  36. auto derelictVulkanSystem() {
  37. static if (Derelict_OS_Posix) {
  38. return VKSystem.Posix;
  39. } else static if (Derelict_OS_Windows) {
  40. return VKSystem.Windows;
  41. } else static if (Derelict_OS_Android) {
  42. return VKSystem.Android;
  43. } else {
  44. pragma(msg, "Non of currently supported systems is fit to yours. "
  45. , "If required functionality is missed, feel free to extend and share on GitHub.");
  46. return VKSystem.Other;
  47. }
  48. }
  49. mixin template DummyFunctions() {
  50. pragma(inline, true)
  51. void bindFunctions(alias bind)() {}
  52. }
  53. mixin template SystemFunctionality() {
  54. extern(System):
  55. enum currentSystem = derelictVulkanSystem();
  56. pragma(msg, "DerelictVulkanSystem: ", to!string(currentSystem));
  57. static if (currentSystem == VKSystem.Windows) {
  58. mixin WindowsSys;
  59. } else static if (currentSystem == VKSystem.Android) {
  60. mixin AndroidSys;
  61. } else static if (currentSystem == VKSystem.Posix) {
  62. mixin PosixSys;
  63. } else {
  64. enum libNames = "";
  65. package alias Functions = DummyFunctions;
  66. }
  67. }
  68. mixin template WindowsSys() {
  69. import core.sys.windows.windows;
  70. enum libNames = "vulkan-1.dll";
  71. enum VK_KHR_win32_surface = 1;
  72. enum VK_KHR_WIN32_SURFACE_SPEC_VERSION = 5;
  73. enum VK_KHR_WIN32_SURFACE_EXTENSION_NAME = "VK_KHR_win32_surface";
  74. alias VkWin32SurfaceCreateFlagsKHR = VkFlags;
  75. struct VkWin32SurfaceCreateInfoKHR {
  76. VkStructureType sType ;
  77. const(void)* pNext ;
  78. VkWin32SurfaceCreateFlagsKHR flags ;
  79. HINSTANCE hinstance;
  80. HWND hwnd ;
  81. }
  82. alias PFN_vkCreateWin32SurfaceKHR = nothrow
  83. VkResult function( VkInstance instance
  84. , const(VkWin32SurfaceCreateInfoKHR)* pCreateInfo
  85. , const(VkAllocationCallbacks)* pAllocator
  86. , VkSurfaceKHR* pSurface );
  87. alias PFN_vkGetPhysicalDeviceWin32PresentationSupportKHR = nothrow
  88. VkBool32 function( VkPhysicalDevice physicalDevice, uint queueFamilyIndex );
  89. mixin template Functions() {
  90. PFN_vkCreateWin32SurfaceKHR vkCreateWin32SurfaceKHR;
  91. PFN_vkGetPhysicalDeviceWin32PresentationSupportKHR vkGetPhysicalDeviceWin32PresentationSupportKHR;
  92. pragma(inline, true)
  93. void bindFunctions(alias bind)() {
  94. bind(cast(void**)&vkCreateWin32SurfaceKHR, "vkCreateWin32SurfaceKHR");
  95. bind( cast(void**)&vkGetPhysicalDeviceWin32PresentationSupportKHR
  96. , "vkGetPhysicalDeviceWin32PresentationSupportKHR");
  97. }
  98. }
  99. version (none) {
  100. VkResult vkCreateWin32SurfaceKHR( VkInstance instance
  101. , const(VkWin32SurfaceCreateInfoKHR)* pCreateInfo
  102. , const(VkAllocationCallbacks)* pAllocator
  103. , VkSurfaceKHR* pSurface );
  104. VkBool32 vkGetPhysicalDeviceWin32PresentationSupportKHR( VkPhysicalDevice physicalDevice, uint queueFamilyIndex );
  105. }
  106. }
  107. mixin template AndroidSys() {
  108. enum libNames = "";
  109. // #include <android/native_window.h>
  110. enum VK_KHR_android_surface = 1;
  111. enum VK_KHR_ANDROID_SURFACE_SPEC_VERSION = 6;
  112. enum VK_KHR_ANDROID_SURFACE_EXTENSION_NAME = "VK_KHR_android_surface";
  113. alias VkAndroidSurfaceCreateFlagsKHR = VkFlags;
  114. struct VkAndroidSurfaceCreateInfoKHR {
  115. VkStructureType sType ;
  116. const(void)* pNext ;
  117. VkAndroidSurfaceCreateFlagsKHR flags ;
  118. ANativeWindow* window;
  119. }
  120. alias PFN_vkCreateAndroidSurfaceKHR = nothrow
  121. VkResult function( VkInstance instance
  122. , const(VkAndroidSurfaceCreateInfoKHR)* pCreateInfo
  123. , const(VkAllocationCallbacks)* pAllocator
  124. , VkSurfaceKHR* pSurface );
  125. mixin template Functions() {
  126. PFN_vkCreateAndroidSurfaceKHR vkCreateAndroidSurfaceKHR;
  127. pragma(inline, true)
  128. void bindFunctions(alias bind)() {
  129. bind(cast(void**)&vkCreateAndroidSurfaceKHR, "vkCreateAndroidSurfaceKHR");
  130. }
  131. }
  132. version (none) {
  133. VkResult vkCreateAndroidSurfaceKHR( VkInstance instance
  134. , const(VkAndroidSurfaceCreateInfoKHR)* pCreateInfo
  135. , const(VkAllocationCallbacks)* pAllocator
  136. , VkSurfaceKHR* pSurface);
  137. }
  138. }
  139. mixin template PosixSys() {
  140. enum libNames = "libvulkan.so,libvulkan.so.1";
  141. version (VK_USE_PLATFORM_XCB_KHR) mixin XCBProtocol ;
  142. version (VK_USE_PLATFORM_XLIB_KHR) mixin XLibProtocol ;
  143. version (VK_USE_PLATFORM_MIR_KHR) mixin MirProtocol ;
  144. version (VK_USE_PLATFORM_WAYLAND_KHR) mixin WaylandProtocol;
  145. else {
  146. pragma(msg, "Non protocol been selected for Posix system.");
  147. package alias Functions = DummyFunctions;
  148. }
  149. }
  150. mixin template XCBProtocol() {
  151. import xcb.xcb;
  152. enum VK_KHR_xcb_surface = 1;
  153. enum VK_KHR_XCB_SURFACE_SPEC_VERSION = 6;
  154. enum VK_KHR_XCB_SURFACE_EXTENSION_NAME = "VK_KHR_xcb_surface";
  155. alias VkXcbSurfaceCreateFlagsKHR = VkFlags;
  156. struct VkXcbSurfaceCreateInfoKHR {
  157. VkStructureType sType ;
  158. const(void)* pNext ;
  159. VkXcbSurfaceCreateFlagsKHR flags ;
  160. xcb_connection_t* connection;
  161. xcb_window_t window ;
  162. }
  163. alias PFN_vkCreateXcbSurfaceKHR = nothrow
  164. VkResult function( VkInstance instance
  165. , const(VkXcbSurfaceCreateInfoKHR)* pCreateInfo
  166. , const(VkAllocationCallbacks)* pAllocator
  167. , VkSurfaceKHR* pSurface );
  168. alias PFN_vkGetPhysicalDeviceXcbPresentationSupportKHR = nothrow
  169. VkBool32 function( VkPhysicalDevice physicalDevice
  170. , uint queueFamilyIndex
  171. , xcb_connection_t* connection
  172. , xcb_visualid_t visual_id );
  173. mixin template Functions() {
  174. PFN_vkCreateXcbSurfaceKHR vkCreateXcbSurfaceKHR;
  175. PFN_vkGetPhysicalDeviceXcbPresentationSupportKHR vkGetPhysicalDeviceXcbPresentationSupportKHR;
  176. pragma(inline, true)
  177. void bindFunctions(alias bind)() {
  178. bind(cast(void**)&vkCreateXcbSurfaceKHR, "vkCreateXcbSurfaceKHR");
  179. bind( cast(void**)&vkGetPhysicalDeviceXcbPresentationSupportKHR
  180. , "vkGetPhysicalDeviceXcbPresentationSupportKHR" );
  181. }
  182. }
  183. version (none) {
  184. VkResult vkCreateXcbSurfaceKHR( VkInstance instance
  185. , const(VkXcbSurfaceCreateInfoKHR)* pCreateInfo
  186. , const(VkAllocationCallbacks)* pAllocator
  187. , VkSurfaceKHR* pSurface );
  188. VkBool32 vkGetPhysicalDeviceXcbPresentationSupportKHR( VkPhysicalDevice physicalDevice
  189. , uint queueFamilyIndex
  190. , xcb_connection_t* connection
  191. , xcb_visualid_t visual_id);
  192. }
  193. }
  194. mixin template XLibProtocol() {
  195. import X11.Xlib;
  196. enum VK_KHR_xlib_surface = 1;
  197. enum VK_KHR_XLIB_SURFACE_SPEC_VERSION = 6;
  198. enum VK_KHR_XLIB_SURFACE_EXTENSION_NAME = "VK_KHR_xlib_surface";
  199. alias VkXlibSurfaceCreateFlagsKHR = VkFlags;
  200. struct VkXlibSurfaceCreateInfoKHR {
  201. VkStructureType sType ;
  202. const(void)* pNext ;
  203. VkXlibSurfaceCreateFlagsKHR flags ;
  204. Display* dpy ;
  205. Window window;
  206. }
  207. alias PFN_vkCreateXlibSurfaceKHR = nothrow
  208. VkResult function( VkInstance instance
  209. , const(VkXlibSurfaceCreateInfoKHR)* pCreateInfo
  210. , const(VkAllocationCallbacks)* pAllocator
  211. , VkSurfaceKHR* pSurface );
  212. alias PFN_vkGetPhysicalDeviceXlibPresentationSupportKHR = nothrow
  213. VkBool32 function( VkPhysicalDevice physicalDevice
  214. , uint queueFamilyIndex
  215. , Display* dpy
  216. , VisualID visualID);
  217. mixin template Functions() {
  218. PFN_vkCreateXlibSurfaceKHR vkCreateXlibSurfaceKHR;
  219. PFN_vkGetPhysicalDeviceXlibPresentationSupportKHR vkGetPhysicalDeviceXlibPresentationSupportKHR;
  220. pragma(inline, true)
  221. void bindFunctions(alias bind)() {
  222. bind(cast(void**)&vkCreateXlibSurfaceKHR, "vkCreateXlibSurfaceKHR");
  223. bind( cast(void**)&vkGetPhysicalDeviceXlibPresentationSupportKHR
  224. , "vkGetPhysicalDeviceXlibPresentationSupportKHR" );
  225. }
  226. }
  227. version (none) {
  228. VkResult vkCreateXlibSurfaceKHR( VkInstance instance
  229. , const(VkXlibSurfaceCreateInfoKHR)* pCreateInfo
  230. , const(VkAllocationCallbacks)* pAllocator
  231. , VkSurfaceKHR* pSurface );
  232. VkBool32 vkGetPhysicalDeviceXlibPresentationSupportKHR( VkPhysicalDevice physicalDevice
  233. , uint queueFamilyIndex
  234. , Display* dpy
  235. , VisualID visualID );
  236. }
  237. }
  238. mixin template MirProtocol() {
  239. //TODO: add import of data related to Mir protocol
  240. // #include <mir_toolkit/client_types.h>
  241. enum VK_KHR_mir_surface = 1;
  242. enum VK_KHR_MIR_SURFACE_SPEC_VERSION = 4;
  243. enum VK_KHR_MIR_SURFACE_EXTENSION_NAME = "VK_KHR_mir_surface";
  244. alias VkMirSurfaceCreateFlagsKHR = VkFlags;
  245. struct VkMirSurfaceCreateInfoKHR {
  246. VkStructureType sType ;
  247. const(void)* pNext ;
  248. VkMirSurfaceCreateFlagsKHR flags ;
  249. MirConnection* connection;
  250. MirSurface* mirSurface;
  251. }
  252. alias PFN_vkCreateMirSurfaceKHR = nothrow
  253. VkResult function( VkInstance instance
  254. , const(VkMirSurfaceCreateInfoKHR)* pCreateInfo
  255. , const(VkAllocationCallbacks)* pAllocator
  256. , VkSurfaceKHR* pSurface );
  257. alias PFN_vkGetPhysicalDeviceMirPresentationSupportKHR = nothrow
  258. VkBool32 function( VkPhysicalDevice physicalDevice
  259. , uint queueFamilyIndex
  260. , MirConnection* connection);
  261. mixin template Functions() {
  262. PFN_vkCreateMirSurfaceKHR vkCreateMirSurfaceKHR;
  263. PFN_vkGetPhysicalDeviceMirPresentationSupportKHR vkGetPhysicalDeviceMirPresentationSupportKHR;
  264. pragma(inline, true)
  265. void bindFunctions(alias bind)() {
  266. bind(cast(void**)&vkCreateMirSurfaceKHR, "vkCreateMirSurfaceKHR");
  267. bind( cast(void**)&vkGetPhysicalDeviceMirPresentationSupportKHR
  268. , "vkGetPhysicalDeviceMirPresentationSupportKHR");
  269. }
  270. }
  271. version (none) {
  272. VkResult vkCreateMirSurfaceKHR( VkInstance instance
  273. , const(VkMirSurfaceCreateInfoKHR)* pCreateInfo
  274. , const(VkAllocationCallbacks)* pAllocator
  275. , VkSurfaceKHR* pSurface );
  276. VkBool32 vkGetPhysicalDeviceMirPresentationSupportKHR( VkPhysicalDevice physicalDevice
  277. , uint queueFamilyIndex
  278. , MirConnection* connection );
  279. }
  280. }
  281. mixin template WaylandProtocol() {
  282. //TODO: add import of data related to Wayland protocol
  283. // #include <wayland-client.h>
  284. enum VK_KHR_wayland_surface = 1;
  285. enum VK_KHR_WAYLAND_SURFACE_SPEC_VERSION = 5;
  286. enum VK_KHR_WAYLAND_SURFACE_EXTENSION_NAME = "VK_KHR_wayland_surface";
  287. alias VkWaylandSurfaceCreateFlagsKHR = VkFlags;
  288. struct VkWaylandSurfaceCreateInfoKHR {
  289. VkStructureType sType ;
  290. const(void)* pNext ;
  291. VkWaylandSurfaceCreateFlagsKHR flags ;
  292. wl_display* display;
  293. wl_surface* surface;
  294. }
  295. alias PFN_vkCreateWaylandSurfaceKHR = nothrow
  296. VkResult function( VkInstance instance
  297. , const(VkWaylandSurfaceCreateInfoKHR)* pCreateInfo
  298. , const(VkAllocationCallbacks)* pAllocator
  299. , VkSurfaceKHR* pSurface );
  300. alias PFN_vkGetPhysicalDeviceWaylandPresentationSupportKHR = nothrow
  301. VkBool32 function( VkPhysicalDevice physicalDevice
  302. , uint queueFamilyIndex
  303. , wl_display* display );
  304. mixin template Functions() {
  305. PFN_vkCreateWaylandSurfaceKHR vkCreateWaylandSurfaceKHR;
  306. PFN_vkGetPhysicalDeviceWaylandPresentationSupportKHR vkGetPhysicalDeviceWaylandPresentationSupportKHR;
  307. pragma(inline, true)
  308. void bindFunctions(alias bind)() {
  309. bind(cast(void**)&vkCreateWaylandSurfaceKHR, "vkCreateWaylandSurfaceKHR");
  310. bind( cast(void**)&vkGetPhysicalDeviceWaylandPresentationSupportKHR
  311. , "vkGetPhysicalDeviceWaylandPresentationSupportKHR" );
  312. }
  313. }
  314. version (none) {
  315. VkResult vkCreateWaylandSurfaceKHR( VkInstance instance
  316. , const(VkWaylandSurfaceCreateInfoKHR)* pCreateInfo
  317. , const(VkAllocationCallbacks)* pAllocator
  318. , VkSurfaceKHR* pSurface );
  319. VkBool32 vkGetPhysicalDeviceWaylandPresentationSupportKHR( VkPhysicalDevice physicalDevice
  320. , uint queueFamilyIndex
  321. , wl_display* display );
  322. }
  323. }