summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Michael <cp.michael@samsung.com>2013-06-24 10:14:21 +0100
committerChris Michael <cp.michael@samsung.com>2013-06-24 10:14:21 +0100
commit0ae72828693817b507da10d7d199aa6ba250d6d8 (patch)
tree0894eb3c3866fe890f8885d0d1cd3fee6c03852e
parent712a528025dcd6f906d906741ebe105996f1b26e (diff)
downloadefl-0ae72828693817b507da10d7d199aa6ba250d6d8.tar.gz
Port cedric's async uploading GL texture commit to wayland_egl engine.
Signed-off-by: Chris Michael <cp.michael@samsung.com>
-rw-r--r--src/modules/evas/engines/wayland_egl/evas_engine.c53
-rw-r--r--src/modules/evas/engines/wayland_egl/evas_engine.h1
-rw-r--r--src/modules/evas/engines/wayland_egl/evas_wl_main.c25
3 files changed, 73 insertions, 6 deletions
diff --git a/src/modules/evas/engines/wayland_egl/evas_engine.c b/src/modules/evas/engines/wayland_egl/evas_engine.c
index 7e4d3cdaa6..b9f36d82a9 100644
--- a/src/modules/evas/engines/wayland_egl/evas_engine.c
+++ b/src/modules/evas/engines/wayland_egl/evas_engine.c
@@ -92,6 +92,8 @@ static void _native_free_cb(void *data, void *image);
static int eng_image_colorspace_get(void *data EINA_UNUSED, void *image);
static int eng_image_alpha_get(void *data EINA_UNUSED, void *image);
+static Eina_Bool eng_gl_preload_make_current(void *data, void *doit);
+
#define EVGLINIT(_re, _ret) if (!evgl_init(_re)) return _ret;
/* local variables */
@@ -210,8 +212,8 @@ evgl_extn_veto(Render_Engine *re)
if (getenv("EVAS_GL_INFO")) printf("EGL EXTENSION:\n%s\n", str);
if (!strstr(str, "EGL_EXT_buffer_age"))
extn_have_buffer_age = EINA_FALSE;
- if (!strstr(str, "swap_buffers_with_damage"))
- glsym_eglSwapBuffersWithDamage = NULL;
+ /* if (!strstr(str, "swap_buffers_with_damage")) */
+ /* glsym_eglSwapBuffersWithDamage = NULL; */
}
else
{
@@ -475,6 +477,7 @@ _re_winfree(Render_Engine *re)
{
if ((!re) || (!re->win)) return;
if (!re->win->surf) return;
+ evas_gl_preload_render_relax(eng_gl_preload_make_current, re);
eng_window_unsurf(re->win);
}
@@ -674,6 +677,7 @@ eng_setup(Evas *evas, void *info)
evas_common_font_init();
evas_common_draw_init();
evas_common_tilebuf_init();
+ evas_gl_preload_init();
evgl_extn_veto(re);
// evgl_engine_init(re, &evgl_funcs);
initted = EINA_TRUE;
@@ -867,6 +871,8 @@ eng_output_free(void *data)
if ((re = (Render_Engine *)data))
{
+ evas_gl_preload_render_relax(eng_gl_preload_make_current, re);
+
if (re->win)
{
eng_window_free(re->win);
@@ -890,6 +896,7 @@ eng_output_free(void *data)
if ((initted) && (!gl_wins))
{
+ evas_gl_preload_shutdown();
evas_common_image_shutdown();
evas_common_font_shutdown();
initted = EINA_FALSE;
@@ -1127,6 +1134,8 @@ eng_output_redraws_next_update_get(void *data, int *x, int *y, int *w, int *h, i
if (first_rect)
{
+ evas_gl_preload_render_lock(eng_gl_preload_make_current, re);
+
eng_window_use(re->win);
if (!_re_wincheck(re)) return NULL;
@@ -1182,11 +1191,11 @@ eng_output_flush(void *data, Evas_Render_Mode render_mode)
if (!(re = (Render_Engine *)data)) return;
- if (render_mode == EVAS_RENDER_MODE_ASYNC_INIT) return;
+ if (render_mode == EVAS_RENDER_MODE_ASYNC_INIT) goto end;
- if (!_re_wincheck(re)) return;
+ if (!_re_wincheck(re)) goto end;
- if (!re->win->draw.drew) return;
+ if (!re->win->draw.drew) goto end;
re->win->draw.drew = EINA_FALSE;
eng_window_use(re->win);
@@ -1269,6 +1278,8 @@ eng_output_flush(void *data, Evas_Render_Mode render_mode)
evas_common_tilebuf_free_render_rects(re->rects);
re->rects = NULL;
}
+end:
+ evas_gl_preload_render_unlock(eng_gl_preload_make_current, re);
}
static void
@@ -1419,6 +1430,30 @@ eng_gl_get_pixels_set(void *data, void *get_pixels, void *get_pixels_data, void
re->func.obj = (Evas_Object*)obj;
}
+static Eina_Bool
+eng_gl_preload_make_current(void *data, void *doit)
+{
+ Render_Engine *re;
+
+ if (!(re = (Render_Engine *)data))
+ return EINA_FALSE;
+
+ if (doit)
+ {
+ if (!eglMakeCurrent(re->win->egl_disp, re->win->egl_surface[0],
+ re->win->egl_surface[0], re->win->egl_context[0]))
+ return EINA_FALSE;
+ }
+ else
+ {
+ if (!eglMakeCurrent(re->win->egl_disp, EGL_NO_SURFACE,
+ EGL_NO_SURFACE, EGL_NO_CONTEXT))
+ return EINA_FALSE;
+ }
+
+ return EINA_TRUE;
+}
+
static void
eng_rectangle_draw(void *data, void *context, void *surface, int x, int y, int w, int h, Eina_Bool do_async EINA_UNUSED)
{
@@ -1817,16 +1852,21 @@ eng_image_data_put(void *data, void *image, DATA32 *image_data)
}
static void
-eng_image_data_preload_request(void *data EINA_UNUSED, void *image, const Eo *target)
+eng_image_data_preload_request(void *data, void *image, const Eo *target)
{
Evas_GL_Image *gim;
RGBA_Image *im;
+ Render_Engine *re;
if (!(gim = image)) return;
if (gim->native.data) return;
im = (RGBA_Image *)gim->im;
if (!im) return;
evas_cache_image_preload_data(&im->cache_entry, target, NULL, NULL, NULL);
+ if (!(re = (Render_Engine *)data)) return;
+ if (!gim->tex)
+ gim->tex = evas_gl_common_texture_new(re->win->gl_context, gim->im);
+ evas_gl_preload_target_register(gim->tex, (Eo *)target);
}
static void
@@ -1840,6 +1880,7 @@ eng_image_data_preload_cancel(void *data EINA_UNUSED, void *image, const Eo *tar
im = (RGBA_Image *)gim->im;
if (!im) return;
evas_cache_image_preload_cancel(&im->cache_entry, target);
+ evas_gl_preload_target_unregister(gim->tex, (Eo *)target);
}
static void *
diff --git a/src/modules/evas/engines/wayland_egl/evas_engine.h b/src/modules/evas/engines/wayland_egl/evas_engine.h
index 02e1937956..80765401fd 100644
--- a/src/modules/evas/engines/wayland_egl/evas_engine.h
+++ b/src/modules/evas/engines/wayland_egl/evas_engine.h
@@ -80,5 +80,6 @@ void eng_window_free(Evas_GL_Wl_Window *gw);
void eng_window_use(Evas_GL_Wl_Window *gw);
void eng_window_unsurf(Evas_GL_Wl_Window *gw);
void eng_window_resurf(Evas_GL_Wl_Window *gw);
+Eina_Bool eng_window_make_current(void *data, void *doit);
#endif
diff --git a/src/modules/evas/engines/wayland_egl/evas_wl_main.c b/src/modules/evas/engines/wayland_egl/evas_wl_main.c
index 9ef76705b6..00a84f81f5 100644
--- a/src/modules/evas/engines/wayland_egl/evas_wl_main.c
+++ b/src/modules/evas/engines/wayland_egl/evas_wl_main.c
@@ -223,6 +223,8 @@ eng_window_use(Evas_GL_Wl_Window *gw)
{
Eina_Bool force = EINA_FALSE;
+ evas_gl_preload_render_lock(eng_window_make_current, gw);
+
if (_evas_gl_wl_window)
{
if ((eglGetCurrentContext() !=
@@ -305,3 +307,26 @@ eng_window_resurf(Evas_GL_Wl_Window *gw)
gw->surf = EINA_TRUE;
}
+
+Eina_Bool
+eng_window_make_current(void *data, void *doit)
+{
+ Evas_GL_Wl_Window *gw;
+
+ if (!(gw = data)) return EINA_FALSE;
+
+ if (doit)
+ {
+ if (!eglMakeCurrent(gw->egl_disp, gw->egl_surface[0],
+ gw->egl_surface[0], gw->egl_context[0]))
+ return EINA_FALSE;
+ }
+ else
+ {
+ if (!eglMakeCurrent(gw->egl_disp, EGL_NO_SURFACE,
+ EGL_NO_SURFACE, EGL_NO_CONTEXT))
+ return EINA_FALSE;
+ }
+
+ return EINA_TRUE;
+}