gl-nix.c 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. /******************************************************************************
  2. Copyright (C) 2019 by Jason Francis <[email protected]>
  3. This program is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation, either version 2 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program. If not, see <http://www.gnu.org/licenses/>.
  13. ******************************************************************************/
  14. #include "gl-nix.h"
  15. #include "gl-x11-egl.h"
  16. #ifdef ENABLE_WAYLAND
  17. #include "gl-wayland-egl.h"
  18. #endif
  19. static const struct gl_winsys_vtable *gl_vtable = NULL;
  20. static void init_winsys(void)
  21. {
  22. assert(gl_vtable == NULL);
  23. switch (obs_get_nix_platform()) {
  24. case OBS_NIX_PLATFORM_X11_EGL:
  25. gl_vtable = gl_x11_egl_get_winsys_vtable();
  26. break;
  27. #ifdef ENABLE_WAYLAND
  28. case OBS_NIX_PLATFORM_WAYLAND:
  29. gl_vtable = gl_wayland_egl_get_winsys_vtable();
  30. blog(LOG_INFO, "Using EGL/Wayland");
  31. break;
  32. #endif
  33. }
  34. assert(gl_vtable != NULL);
  35. }
  36. extern struct gl_windowinfo *
  37. gl_windowinfo_create(const struct gs_init_data *info)
  38. {
  39. return gl_vtable->windowinfo_create(info);
  40. }
  41. extern void gl_windowinfo_destroy(struct gl_windowinfo *info)
  42. {
  43. gl_vtable->windowinfo_destroy(info);
  44. }
  45. extern struct gl_platform *gl_platform_create(gs_device_t *device,
  46. uint32_t adapter)
  47. {
  48. init_winsys();
  49. return gl_vtable->platform_create(device, adapter);
  50. }
  51. extern void gl_platform_destroy(struct gl_platform *plat)
  52. {
  53. gl_vtable->platform_destroy(plat);
  54. gl_vtable = NULL;
  55. }
  56. extern bool gl_platform_init_swapchain(struct gs_swap_chain *swap)
  57. {
  58. return gl_vtable->platform_init_swapchain(swap);
  59. }
  60. extern void gl_platform_cleanup_swapchain(struct gs_swap_chain *swap)
  61. {
  62. gl_vtable->platform_cleanup_swapchain(swap);
  63. }
  64. extern void device_enter_context(gs_device_t *device)
  65. {
  66. gl_vtable->device_enter_context(device);
  67. }
  68. extern void device_leave_context(gs_device_t *device)
  69. {
  70. gl_vtable->device_leave_context(device);
  71. }
  72. extern void *device_get_device_obj(gs_device_t *device)
  73. {
  74. return gl_vtable->device_get_device_obj(device);
  75. }
  76. extern void gl_getclientsize(const struct gs_swap_chain *swap, uint32_t *width,
  77. uint32_t *height)
  78. {
  79. gl_vtable->getclientsize(swap, width, height);
  80. }
  81. extern void gl_clear_context(gs_device_t *device)
  82. {
  83. gl_vtable->clear_context(device);
  84. }
  85. extern void gl_update(gs_device_t *device)
  86. {
  87. gl_vtable->update(device);
  88. }
  89. extern void device_load_swapchain(gs_device_t *device, gs_swapchain_t *swap)
  90. {
  91. gl_vtable->device_load_swapchain(device, swap);
  92. }
  93. extern bool device_is_present_ready(gs_device_t *device)
  94. {
  95. UNUSED_PARAMETER(device);
  96. return true;
  97. }
  98. extern void device_present(gs_device_t *device)
  99. {
  100. gl_vtable->device_present(device);
  101. }
  102. extern bool device_is_monitor_hdr(gs_device_t *device, void *monitor)
  103. {
  104. UNUSED_PARAMETER(device);
  105. UNUSED_PARAMETER(monitor);
  106. return false;
  107. }
  108. extern struct gs_texture *device_texture_create_from_dmabuf(
  109. gs_device_t *device, unsigned int width, unsigned int height,
  110. uint32_t drm_format, enum gs_color_format color_format,
  111. uint32_t n_planes, const int *fds, const uint32_t *strides,
  112. const uint32_t *offsets, const uint64_t *modifiers)
  113. {
  114. return gl_vtable->device_texture_create_from_dmabuf(
  115. device, width, height, drm_format, color_format, n_planes, fds,
  116. strides, offsets, modifiers);
  117. }
  118. extern bool device_query_dmabuf_capabilities(gs_device_t *device,
  119. enum gs_dmabuf_flags *dmabuf_flags,
  120. uint32_t **drm_formats,
  121. size_t *n_formats)
  122. {
  123. return gl_vtable->device_query_dmabuf_capabilities(
  124. device, dmabuf_flags, drm_formats, n_formats);
  125. }
  126. extern bool device_query_dmabuf_modifiers_for_format(gs_device_t *device,
  127. uint32_t drm_format,
  128. uint64_t **modifiers,
  129. size_t *n_modifiers)
  130. {
  131. return gl_vtable->device_query_dmabuf_modifiers_for_format(
  132. device, drm_format, modifiers, n_modifiers);
  133. }
  134. struct gs_texture *device_texture_create_from_pixmap(
  135. gs_device_t *device, uint32_t width, uint32_t height,
  136. enum gs_color_format color_format, uint32_t target, void *pixmap)
  137. {
  138. return gl_vtable->device_texture_create_from_pixmap(
  139. device, width, height, color_format, target, pixmap);
  140. }