summaryrefslogtreecommitdiff
path: root/src/egl/drivers/dri2/platform_tizen.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/egl/drivers/dri2/platform_tizen.c')
-rw-r--r--src/egl/drivers/dri2/platform_tizen.c21
1 files changed, 16 insertions, 5 deletions
diff --git a/src/egl/drivers/dri2/platform_tizen.c b/src/egl/drivers/dri2/platform_tizen.c
index 4b5b8bd6634..30d12cb4565 100644
--- a/src/egl/drivers/dri2/platform_tizen.c
+++ b/src/egl/drivers/dri2/platform_tizen.c
@@ -882,10 +882,7 @@ tizen_create_image_from_name(_EGLDisplay *disp, _EGLContext *ctx,
return NULL;
}
- if (!_eglInitImage(&dri2_img->base, disp)) {
- free(dri2_img);
- return NULL;
- }
+ _eglInitImage(&dri2_img->base, disp);
dri2_img->dri_image =
dri2_dpy->image->createImageFromName(dri2_dpy->dri_screen,
@@ -1250,6 +1247,20 @@ tizen_add_configs(_EGLDriver *drv, _EGLDisplay *dpy)
return (count != 0);
}
+static EGLBoolean tizen_set_swap_interval(_EGLDriver *drv, _EGLDisplay *dpy,
+ _EGLSurface *surf, EGLint interval)
+{
+ tpl_result_t res = TPL_ERROR_NONE;
+ struct dri2_egl_surface *dri2_surf = dri2_egl_surface(surf);
+
+ res = tpl_surface_set_post_interval(dri2_surf->tpl_surface, interval);
+
+ if (res != TPL_ERROR_NONE)
+ return EGL_FALSE;
+
+ return EGL_TRUE;
+}
+
static struct dri2_egl_display_vtbl tizen_display_vtbl = {
.authenticate = NULL,
.create_window_surface = tizen_create_window_surface,
@@ -1257,7 +1268,7 @@ static struct dri2_egl_display_vtbl tizen_display_vtbl = {
.create_pbuffer_surface = tizen_create_pbuffer_surface,
.destroy_surface = tizen_destroy_surface,
.create_image = tizen_create_image_khr,
- .swap_interval = dri2_fallback_swap_interval,
+ .swap_interval = tizen_set_swap_interval,
.swap_buffers = tizen_swap_buffers,
.swap_buffers_with_damage = tizen_swap_buffers_with_damage,
.swap_buffers_region = dri2_fallback_swap_buffers_region,