static void gfx_ctx_wl_swap_buffers(void *data, void *data2) { gfx_ctx_wayland_data_t *wl = (gfx_ctx_wayland_data_t*)data; switch (wl_api) { case GFX_CTX_OPENGL_API: case GFX_CTX_OPENGL_ES_API: case GFX_CTX_OPENVG_API: #ifdef HAVE_EGL egl_swap_buffers(&wl->egl); #endif break; case GFX_CTX_VULKAN_API: #ifdef HAVE_VULKAN vulkan_present(&wl->vk, wl->vk.context.current_swapchain_index); vulkan_acquire_next_image(&wl->vk); flush_wayland_fd(&wl->input); #endif break; case GFX_CTX_NONE: default: break; } }
static void gfx_ctx_x_swap_buffers(void *data) { gfx_ctx_x_data_t *x = (gfx_ctx_x_data_t*)data; switch (x_api) { case GFX_CTX_OPENGL_API: case GFX_CTX_OPENGL_ES_API: #ifdef HAVE_OPENGL if (x->g_is_double) glXSwapBuffers(g_x11_dpy, x->g_glx_win); #endif break; case GFX_CTX_VULKAN_API: #ifdef HAVE_VULKAN vulkan_present(&x->vk, x->vk.context.current_swapchain_index); vulkan_acquire_next_image(&x->vk); #endif break; case GFX_CTX_NONE: default: break; } }
static bool gfx_ctx_wgl_set_resize(void *data, unsigned width, unsigned height) { (void)data; (void)width; (void)height; switch (win32_api) { case GFX_CTX_VULKAN_API: #ifdef HAVE_VULKAN if (!vulkan_create_swapchain(&win32_vk, width, height, win32_interval)) { RARCH_ERR("[Win32/Vulkan]: Failed to update swapchain.\n"); return false; } if (win32_vk.created_new_swapchain) vulkan_acquire_next_image(&win32_vk); win32_vk.context.invalid_swapchain = true; win32_vk.need_new_swapchain = false; #endif break; case GFX_CTX_NONE: default: break; } return false; }
static void gfx_ctx_x_swap_buffers(void *data, void *data2) { gfx_ctx_x_data_t *x = (gfx_ctx_x_data_t*)data; switch (x_api) { case GFX_CTX_OPENGL_API: case GFX_CTX_OPENGL_ES_API: #if defined(HAVE_OPENGL) if (x->swap_mode) { if (x->g_interval) { glXWaitForMscOML(g_x11_dpy, x->g_glx_win, x->msc + x->g_interval, 0, 0, &x->ust, &x->msc, &x->sbc); glXSwapBuffersMscOML(g_x11_dpy, x->g_glx_win, 0, 0, 0); } else glXSwapBuffersMscOML(g_x11_dpy, x->g_glx_win, 0, x->divisor, x->remainder); #if 0 RARCH_LOG("UST: %d, MSC: %d, SBC: %d\n", x->ust, x->msc, x->sbc); #endif } else { if (x->g_is_double) glXSwapBuffers(g_x11_dpy, x->g_glx_win); } #endif break; case GFX_CTX_VULKAN_API: #ifdef HAVE_VULKAN vulkan_present(&x->vk, x->vk.context.current_swapchain_index); vulkan_acquire_next_image(&x->vk); #endif break; case GFX_CTX_NONE: default: break; } }
static void gfx_ctx_wgl_swap_buffers(void *data, void *data2) { (void)data; switch (win32_api) { case GFX_CTX_OPENGL_API: SwapBuffers(win32_hdc); break; case GFX_CTX_VULKAN_API: #ifdef HAVE_VULKAN vulkan_present(&win32_vk, win32_vk.context.current_swapchain_index); vulkan_acquire_next_image(&win32_vk); #endif break; case GFX_CTX_NONE: default: break; } }
static bool gfx_ctx_wl_set_resize(void *data, unsigned width, unsigned height) { gfx_ctx_wayland_data_t *wl = (gfx_ctx_wayland_data_t*)data; switch (wl_api) { case GFX_CTX_OPENGL_API: case GFX_CTX_OPENGL_ES_API: case GFX_CTX_OPENVG_API: #ifdef HAVE_EGL wl_egl_window_resize(wl->win, width, height, 0, 0); #endif break; case GFX_CTX_VULKAN_API: #ifdef HAVE_VULKAN wl->width = width; wl->height = height; if (vulkan_create_swapchain(&wl->vk, width, height, wl->swap_interval)) { wl->vk.context.invalid_swapchain = true; vulkan_acquire_next_image(&wl->vk); } else { RARCH_ERR("[Wayland/Vulkan]: Failed to update swapchain.\n"); return false; } wl->vk.need_new_swapchain = false; #endif break; case GFX_CTX_NONE: default: break; } return true; }
static bool gfx_ctx_x_set_resize(void *data, unsigned width, unsigned height) { (void)data; (void)width; (void)height; switch (x_api) { case GFX_CTX_VULKAN_API: #ifdef HAVE_VULKAN { gfx_ctx_x_data_t *x = (gfx_ctx_x_data_t*)data; /* FIXME/TODO - threading error here */ if (!vulkan_create_swapchain(&x->vk, width, height, x->g_interval)) { RARCH_ERR("[X/Vulkan]: Failed to update swapchain.\n"); x->vk.swapchain = VK_NULL_HANDLE; return false; } if (x->vk.created_new_swapchain) vulkan_acquire_next_image(&x->vk); x->vk.context.invalid_swapchain = true; x->vk.need_new_swapchain = false; } #endif break; case GFX_CTX_NONE: default: break; } return true; }
static void android_gfx_ctx_swap_buffers(void *data, void *data2) { android_ctx_data_t *and = (android_ctx_data_t*)data; switch (android_api) { case GFX_CTX_OPENGL_API: case GFX_CTX_OPENGL_ES_API: case GFX_CTX_OPENVG_API: #ifdef HAVE_EGL egl_swap_buffers(&and->egl); #endif break; case GFX_CTX_VULKAN_API: #ifdef HAVE_VULKAN vulkan_present(&and->vk, and->vk.context.current_swapchain_index); vulkan_acquire_next_image(&and->vk); #endif break; case GFX_CTX_NONE: default: break; } }
static void gfx_ctx_khr_display_swap_buffers(void *data) { khr_display_ctx_data_t *khr = (khr_display_ctx_data_t*)data; vulkan_present(&khr->vk, khr->vk.context.current_swapchain_index); vulkan_acquire_next_image(&khr->vk); }