2013-05-14 00:16:45 -07:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include <config.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <Eina.h>
|
|
|
|
#include <Ecore.h>
|
|
|
|
#include "ecore_private.h"
|
|
|
|
#include <Ecore_Input.h>
|
|
|
|
#include <Ecore_Input_Evas.h>
|
|
|
|
#include <Ecore_Evas.h>
|
|
|
|
#include "ecore_evas_private.h"
|
2013-05-14 02:45:47 -07:00
|
|
|
#include "ecore_evas_drm.h"
|
2016-05-03 09:03:00 -07:00
|
|
|
#include <Ecore_Drm2.h>
|
2014-08-21 02:22:16 -07:00
|
|
|
#include <Evas_Engine_Drm.h>
|
2016-05-03 09:03:00 -07:00
|
|
|
#include <drm_fourcc.h>
|
2013-05-14 02:45:47 -07:00
|
|
|
|
2014-08-28 10:36:59 -07:00
|
|
|
#ifdef BUILD_ECORE_EVAS_GL_DRM
|
2014-08-21 02:22:16 -07:00
|
|
|
# include <Evas_Engine_GL_Drm.h>
|
|
|
|
# include <dlfcn.h>
|
|
|
|
#endif
|
2013-05-14 02:45:47 -07:00
|
|
|
|
2015-04-28 05:24:48 -07:00
|
|
|
#ifdef EAPI
|
|
|
|
# undef EAPI
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
# ifdef DLL_EXPORT
|
|
|
|
# define EAPI __declspec(dllexport)
|
|
|
|
# else
|
|
|
|
# define EAPI
|
|
|
|
# endif /* ! DLL_EXPORT */
|
|
|
|
#else
|
|
|
|
# ifdef __GNUC__
|
|
|
|
# if __GNUC__ >= 4
|
|
|
|
# define EAPI __attribute__ ((visibility("default")))
|
|
|
|
# else
|
|
|
|
# define EAPI
|
|
|
|
# endif
|
|
|
|
# else
|
|
|
|
# define EAPI
|
|
|
|
# endif
|
|
|
|
#endif /* ! _WIN32 */
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
typedef struct _Ecore_Evas_Engine_Drm_Data
|
2014-03-28 03:36:44 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
int fd;
|
|
|
|
int cw, ch;
|
|
|
|
int clockid;
|
|
|
|
int x, y, w, h;
|
|
|
|
int depth, bpp;
|
|
|
|
unsigned int format;
|
|
|
|
Ecore_Drm2_Device *dev;
|
|
|
|
Ecore_Drm2_Output *output;
|
|
|
|
} Ecore_Evas_Engine_Drm_Data;
|
2014-03-28 03:36:44 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
static int _drm_init_count = 0;
|
2014-08-21 02:22:16 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
static int
|
|
|
|
_ecore_evas_drm_init(Ecore_Evas_Engine_Drm_Data *edata, const char *device)
|
2013-05-14 02:45:47 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
if (++_drm_init_count != 1) return _drm_init_count;
|
2013-05-14 02:45:47 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (!ecore_drm2_init())
|
2015-04-07 11:10:41 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
ERR("Failed to init Ecore_Drm2 library");
|
|
|
|
goto init_err;
|
2015-04-07 11:10:41 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (!device) device = "seat0";
|
2013-05-14 02:45:47 -07:00
|
|
|
|
2016-05-24 13:18:46 -07:00
|
|
|
edata->dev = ecore_drm2_device_find(device, 0);
|
2016-05-03 09:03:00 -07:00
|
|
|
if (!edata->dev)
|
2014-03-28 03:36:44 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
ERR("Failed to create device");
|
|
|
|
goto dev_err;
|
2014-03-28 03:36:44 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
edata->fd = ecore_drm2_device_open(edata->dev);
|
|
|
|
if (edata->fd < 0)
|
2015-01-07 06:51:12 -08:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
ERR("Failed to open device");
|
|
|
|
goto open_err;
|
2015-01-07 06:51:12 -08:00
|
|
|
}
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
edata->clockid = ecore_drm2_device_clock_id_get(edata->dev);
|
|
|
|
ecore_drm2_device_cursor_size_get(edata->dev, &edata->cw, &edata->ch);
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (!ecore_drm2_outputs_create(edata->dev))
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
ERR("Could not create outputs");
|
|
|
|
goto output_err;
|
2014-03-10 03:02:31 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
edata->output = ecore_drm2_output_find(edata->dev, edata->x, edata->y);
|
|
|
|
if (!edata->output)
|
|
|
|
WRN("Could not find output at %d %d", edata->x, edata->y);
|
2014-03-18 00:27:33 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ecore_event_evas_init();
|
2015-11-17 12:55:41 -08:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
return _drm_init_count;
|
2015-11-17 12:55:41 -08:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
output_err:
|
|
|
|
ecore_drm2_device_close(edata->dev);
|
|
|
|
open_err:
|
|
|
|
ecore_drm2_device_free(edata->dev);
|
|
|
|
dev_err:
|
|
|
|
ecore_drm2_shutdown();
|
|
|
|
init_err:
|
|
|
|
return --_drm_init_count;
|
|
|
|
}
|
2015-11-17 12:55:41 -08:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
static int
|
|
|
|
_ecore_evas_drm_shutdown(Ecore_Evas_Engine_Drm_Data *edata)
|
|
|
|
{
|
|
|
|
if (--_drm_init_count != 0) return _drm_init_count;
|
2015-11-17 12:55:41 -08:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ecore_drm2_outputs_destroy(edata->dev);
|
|
|
|
ecore_drm2_device_close(edata->dev);
|
|
|
|
ecore_drm2_device_free(edata->dev);
|
|
|
|
ecore_drm2_shutdown();
|
|
|
|
ecore_event_evas_shutdown();
|
2014-08-21 02:22:16 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
return _drm_init_count;
|
2014-08-21 02:22:16 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
static void
|
|
|
|
_drm_free(Ecore_Evas *ee)
|
2014-08-21 02:22:16 -07:00
|
|
|
{
|
|
|
|
Ecore_Evas_Engine_Drm_Data *edata;
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ecore_evas_input_event_unregister(ee);
|
2014-08-21 02:22:16 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
edata = ee->engine.data;
|
|
|
|
_ecore_evas_drm_shutdown(edata);
|
|
|
|
free(edata);
|
|
|
|
}
|
2014-08-21 02:22:16 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
static int
|
|
|
|
_drm_render_updates_process(Ecore_Evas *ee, Eina_List *updates)
|
|
|
|
{
|
|
|
|
int rend = 0;
|
2014-08-21 02:22:16 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if ((ee->visible) && (updates))
|
2015-06-03 09:57:59 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
_ecore_evas_idle_timeout_update(ee);
|
|
|
|
rend = 1;
|
2015-06-03 09:57:59 -07:00
|
|
|
}
|
|
|
|
else
|
2016-05-03 09:03:00 -07:00
|
|
|
evas_norender(ee->evas);
|
2014-08-21 02:22:16 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (ee->func.fn_post_render) ee->func.fn_post_render(ee);
|
2014-08-21 02:22:16 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
return rend;
|
|
|
|
}
|
2014-08-21 02:22:16 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
static void
|
|
|
|
_drm_render_updates(void *data, Evas *evas EINA_UNUSED, void *event)
|
|
|
|
{
|
|
|
|
Evas_Event_Render_Post *ev;
|
|
|
|
Ecore_Evas *ee;
|
2014-08-21 02:22:16 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ev = event;
|
|
|
|
if (!ev) return;
|
2014-08-21 02:22:16 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ee = data;
|
|
|
|
if (!ee) return;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ee->in_async_render = EINA_FALSE;
|
|
|
|
_drm_render_updates_process(ee, ev->updated_area);
|
2013-05-14 02:45:47 -07:00
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static int
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_render(Ecore_Evas *ee)
|
2013-05-14 02:45:47 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
int rend = 0;
|
|
|
|
Eina_List *l;
|
|
|
|
Ecore_Evas *ee2;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (ee->in_async_render) return 0;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (!ee->visible)
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
evas_norender(ee->evas);
|
|
|
|
return 0;
|
2014-03-10 03:02:31 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
EINA_LIST_FOREACH(ee->sub_ecore_evas, l, ee2)
|
2014-12-09 06:36:42 -08:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
if (ee2->func.fn_pre_render) ee2->func.fn_pre_render(ee2);
|
|
|
|
if (ee2->engine.func->fn_render)
|
|
|
|
rend |= ee2->engine.func->fn_render(ee2);
|
|
|
|
if (ee2->func.fn_post_render) ee2->func.fn_post_render(ee2);
|
2014-12-09 06:36:42 -08:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (ee->func.fn_pre_render) ee->func.fn_pre_render(ee);
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (!ee->can_async_render)
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
Eina_List *updates;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
updates = evas_render_updates(ee->evas);
|
|
|
|
rend = _drm_render_updates_process(ee, updates);
|
|
|
|
evas_render_updates_free(updates);
|
2014-03-10 03:02:31 -07:00
|
|
|
}
|
2016-05-03 09:03:00 -07:00
|
|
|
else if (evas_render_async(ee->evas))
|
2015-01-13 07:34:48 -08:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
ee->in_async_render = EINA_TRUE;
|
|
|
|
rend = 1;
|
2015-01-13 07:34:48 -08:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
return rend;
|
2013-05-14 02:45:47 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
static void
|
|
|
|
_drm_screen_geometry_get(const Ecore_Evas *ee, int *x, int *y, int *w, int *h)
|
2013-05-14 02:45:47 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
Ecore_Evas_Engine_Drm_Data *edata;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
edata = ee->engine.data;
|
|
|
|
ecore_drm2_output_geometry_get(edata->output, x, y, w, h);
|
2014-03-10 03:02:31 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
static void
|
|
|
|
_drm_pointer_xy_get(const Ecore_Evas *ee, Evas_Coord *x, Evas_Coord *y)
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
Ecore_Evas_Engine_Drm_Data *edata;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
edata = ee->engine.data;
|
|
|
|
ecore_drm2_device_pointer_xy_get(edata->dev, x, y);
|
2014-03-10 03:02:31 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
static Eina_Bool
|
|
|
|
_drm_pointer_warp(const Ecore_Evas *ee, Evas_Coord x, Evas_Coord y)
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
Ecore_Evas_Engine_Drm_Data *edata;
|
2014-03-28 03:36:44 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
edata = ee->engine.data;
|
|
|
|
ecore_drm2_device_pointer_warp(edata->dev, x, y);
|
|
|
|
return EINA_TRUE;
|
2014-03-10 03:02:31 -07:00
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_show(Ecore_Evas *ee)
|
2014-03-18 03:15:05 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
if ((!ee) || (ee->visible)) return;
|
2014-03-18 03:15:05 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ee->should_be_visible = 1;
|
2014-03-18 03:15:05 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (ee->prop.avoid_damage)
|
|
|
|
_drm_render(ee);
|
2014-03-18 03:18:58 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (ee->prop.override)
|
|
|
|
{
|
|
|
|
ee->prop.withdrawn = EINA_FALSE;
|
|
|
|
if (ee->func.fn_state_change) ee->func.fn_state_change(ee);
|
|
|
|
}
|
2014-03-18 03:18:58 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (ee->visible) return;
|
2014-03-18 03:20:43 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ee->visible = 1;
|
|
|
|
if (ee->prop.fullscreen)
|
|
|
|
{
|
|
|
|
evas_focus_in(ee->evas);
|
|
|
|
if (ee->func.fn_focus_in) ee->func.fn_focus_in(ee);
|
|
|
|
}
|
|
|
|
if (ee->func.fn_show) ee->func.fn_show(ee);
|
2014-03-18 03:20:43 -07:00
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_hide(Ecore_Evas *ee)
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
if ((!ee) || (!ee->visible)) return;
|
|
|
|
|
|
|
|
if (ee->prop.override)
|
|
|
|
{
|
|
|
|
ee->prop.withdrawn = EINA_TRUE;
|
|
|
|
if (ee->func.fn_state_change) ee->func.fn_state_change(ee);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!ee->visible) return;
|
|
|
|
|
|
|
|
ee->visible = 0;
|
|
|
|
ee->should_be_visible = 0;
|
|
|
|
evas_sync(ee->evas);
|
|
|
|
if (ee->func.fn_hide) ee->func.fn_hide(ee);
|
2014-03-10 03:02:31 -07:00
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_move(Ecore_Evas *ee, int x, int y)
|
2014-03-18 03:23:55 -07:00
|
|
|
{
|
|
|
|
ee->req.x = x;
|
|
|
|
ee->req.y = y;
|
|
|
|
if ((ee->x == x) && (ee->y == y)) return;
|
|
|
|
ee->x = x;
|
|
|
|
ee->y = y;
|
|
|
|
if (ee->func.fn_move) ee->func.fn_move(ee);
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_resize(Ecore_Evas *ee, int w, int h)
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
|
|
|
ee->req.w = w;
|
|
|
|
ee->req.h = h;
|
|
|
|
if ((ee->w == w) && (ee->h == h)) return;
|
|
|
|
ee->w = w;
|
|
|
|
ee->h = h;
|
|
|
|
evas_output_size_set(ee->evas, w, h);
|
|
|
|
evas_output_viewport_set(ee->evas, 0, 0, w, h);
|
|
|
|
if (ee->func.fn_resize) ee->func.fn_resize(ee);
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_move_resize(Ecore_Evas *ee, int x, int y, int w, int h)
|
2014-03-18 03:27:02 -07:00
|
|
|
{
|
|
|
|
if ((ee->x != x) || (ee->y != y))
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_move(ee, x, y);
|
2014-03-18 03:27:02 -07:00
|
|
|
if ((ee->w != w) || (ee->h != h))
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_resize(ee, w, h);
|
2014-03-18 03:27:02 -07:00
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_rotation_set(Ecore_Evas *ee, int rotation, int resize EINA_UNUSED)
|
2014-03-18 03:30:44 -07:00
|
|
|
{
|
|
|
|
Evas_Engine_Info_Drm *einfo;
|
|
|
|
|
|
|
|
if (ee->rotation == rotation) return;
|
|
|
|
einfo = (Evas_Engine_Info_Drm *)evas_engine_info_get(ee->evas);
|
|
|
|
if (!einfo) return;
|
|
|
|
einfo->info.rotation = rotation;
|
|
|
|
if (!evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo))
|
2016-05-03 09:03:00 -07:00
|
|
|
ERR("evas_engine_info_set() for engine '%s' failed", ee->driver);
|
2014-03-18 03:30:44 -07:00
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_title_set(Ecore_Evas *ee, const char *title)
|
2014-03-18 03:33:38 -07:00
|
|
|
{
|
2015-01-22 11:37:56 -08:00
|
|
|
if (eina_streq(ee->prop.title, title)) return;
|
2014-03-18 03:33:38 -07:00
|
|
|
if (ee->prop.title) free(ee->prop.title);
|
|
|
|
ee->prop.title = NULL;
|
|
|
|
if (title) ee->prop.title = strdup(title);
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_name_class_set(Ecore_Evas *ee, const char *n, const char *c)
|
2014-03-18 03:38:36 -07:00
|
|
|
{
|
2015-01-22 11:37:56 -08:00
|
|
|
if (!eina_streq(ee->prop.name, n))
|
|
|
|
{
|
|
|
|
if (ee->prop.name) free(ee->prop.name);
|
|
|
|
ee->prop.name = NULL;
|
|
|
|
if (n) ee->prop.name = strdup(n);
|
|
|
|
}
|
2016-05-03 09:03:00 -07:00
|
|
|
|
2015-01-22 11:37:56 -08:00
|
|
|
if (!eina_streq(ee->prop.clas, c))
|
|
|
|
{
|
|
|
|
if (ee->prop.clas) free(ee->prop.clas);
|
|
|
|
ee->prop.clas = NULL;
|
|
|
|
if (c) ee->prop.clas = strdup(c);
|
|
|
|
}
|
2014-03-18 03:38:36 -07:00
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_size_min_set(Ecore_Evas *ee, int w, int h)
|
2014-03-18 03:42:19 -07:00
|
|
|
{
|
|
|
|
if ((ee->prop.min.w == w) && (ee->prop.min.h == h)) return;
|
|
|
|
ee->prop.min.w = w;
|
|
|
|
ee->prop.min.h = h;
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_size_max_set(Ecore_Evas *ee, int w, int h)
|
2014-03-18 03:42:19 -07:00
|
|
|
{
|
|
|
|
if ((ee->prop.max.w == w) && (ee->prop.max.h == h)) return;
|
|
|
|
ee->prop.max.w = w;
|
|
|
|
ee->prop.max.h = h;
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_size_base_set(Ecore_Evas *ee, int w, int h)
|
2014-03-18 03:42:19 -07:00
|
|
|
{
|
|
|
|
if ((ee->prop.base.w == w) && (ee->prop.base.h == h)) return;
|
|
|
|
ee->prop.base.w = w;
|
|
|
|
ee->prop.base.h = h;
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_size_step_set(Ecore_Evas *ee, int w, int h)
|
2014-03-18 03:42:19 -07:00
|
|
|
{
|
|
|
|
if ((ee->prop.step.w == w) && (ee->prop.step.h == h)) return;
|
|
|
|
ee->prop.step.w = w;
|
2016-05-03 09:03:00 -07:00
|
|
|
ee->prop.step.h = h;
|
2014-03-18 03:48:16 -07:00
|
|
|
}
|
|
|
|
|
2015-02-06 14:54:08 -08:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_object_cursor_del(void *data, Evas *evas EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event EINA_UNUSED)
|
2015-02-06 14:54:08 -08:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
Ecore_Evas *ee;
|
|
|
|
|
|
|
|
ee = data;
|
|
|
|
if (ee) ee->prop.cursor.object = NULL;
|
2015-02-06 14:54:08 -08:00
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_object_cursor_set(Ecore_Evas *ee, Evas_Object *obj, int layer, int hot_x, int hot_y)
|
2014-03-18 03:48:16 -07:00
|
|
|
{
|
2014-04-02 04:29:03 -07:00
|
|
|
Evas_Object *old;
|
2016-05-03 09:03:00 -07:00
|
|
|
int x, y;
|
2014-06-25 10:20:13 -07:00
|
|
|
|
2014-04-02 04:29:03 -07:00
|
|
|
old = ee->prop.cursor.object;
|
2016-05-03 09:03:00 -07:00
|
|
|
if (!obj)
|
2014-03-18 03:48:16 -07:00
|
|
|
{
|
|
|
|
ee->prop.cursor.object = NULL;
|
|
|
|
ee->prop.cursor.layer = 0;
|
|
|
|
ee->prop.cursor.hot.x = 0;
|
|
|
|
ee->prop.cursor.hot.y = 0;
|
2014-04-02 04:29:03 -07:00
|
|
|
goto end;
|
2014-03-18 03:48:16 -07:00
|
|
|
}
|
2014-06-25 10:20:13 -07:00
|
|
|
|
2014-03-18 03:48:16 -07:00
|
|
|
ee->prop.cursor.object = obj;
|
|
|
|
ee->prop.cursor.layer = layer;
|
|
|
|
ee->prop.cursor.hot.x = hot_x;
|
|
|
|
ee->prop.cursor.hot.y = hot_y;
|
2014-06-25 10:11:16 -07:00
|
|
|
|
2015-03-04 08:48:36 -08:00
|
|
|
ecore_evas_pointer_xy_get(ee, &x, &y);
|
2014-06-25 10:11:16 -07:00
|
|
|
|
2014-04-02 04:29:03 -07:00
|
|
|
if (obj != old)
|
|
|
|
{
|
|
|
|
evas_object_layer_set(ee->prop.cursor.object, ee->prop.cursor.layer);
|
|
|
|
evas_object_pass_events_set(ee->prop.cursor.object, 1);
|
|
|
|
if (evas_pointer_inside_get(ee->evas))
|
|
|
|
evas_object_show(ee->prop.cursor.object);
|
|
|
|
evas_object_event_callback_add(obj, EVAS_CALLBACK_DEL,
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_object_cursor_del, ee);
|
2014-04-02 04:29:03 -07:00
|
|
|
}
|
2014-06-25 10:20:13 -07:00
|
|
|
|
|
|
|
evas_object_move(ee->prop.cursor.object, x - ee->prop.cursor.hot.x,
|
2014-03-18 03:48:16 -07:00
|
|
|
y - ee->prop.cursor.hot.y);
|
2014-06-25 10:20:13 -07:00
|
|
|
|
2014-04-02 04:29:03 -07:00
|
|
|
end:
|
|
|
|
if ((old) && (obj != old))
|
|
|
|
{
|
|
|
|
evas_object_event_callback_del_full
|
2016-05-03 09:03:00 -07:00
|
|
|
(old, EVAS_CALLBACK_DEL, _drm_object_cursor_del, ee);
|
2014-04-02 04:29:03 -07:00
|
|
|
evas_object_del(old);
|
|
|
|
}
|
2014-03-18 03:48:16 -07:00
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_object_cursor_unset(Ecore_Evas *ee)
|
|
|
|
{
|
|
|
|
evas_object_event_callback_del_full(ee->prop.cursor.object,
|
|
|
|
EVAS_CALLBACK_DEL,
|
|
|
|
_drm_object_cursor_del, ee);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
_drm_layer_set(Ecore_Evas *ee, int layer)
|
2014-03-18 03:50:26 -07:00
|
|
|
{
|
|
|
|
if (layer < 1) layer = 1;
|
|
|
|
else if (layer > 255) layer = 255;
|
|
|
|
if (ee->prop.layer == layer) return;
|
|
|
|
ee->prop.layer = layer;
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_iconified_set(Ecore_Evas *ee, Eina_Bool on)
|
2014-03-18 03:52:10 -07:00
|
|
|
{
|
|
|
|
if (ee->prop.iconified == on) return;
|
|
|
|
ee->prop.iconified = on;
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_borderless_set(Ecore_Evas *ee, Eina_Bool on)
|
2014-03-18 04:00:32 -07:00
|
|
|
{
|
|
|
|
if (ee->prop.borderless == on) return;
|
|
|
|
ee->prop.borderless = on;
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_maximized_set(Ecore_Evas *ee, Eina_Bool on)
|
2014-03-18 04:11:23 -07:00
|
|
|
{
|
|
|
|
if (ee->prop.maximized == on) return;
|
|
|
|
ee->prop.maximized = on;
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_fullscreen_set(Ecore_Evas *ee, Eina_Bool on)
|
2014-03-18 04:11:23 -07:00
|
|
|
{
|
2014-03-28 03:36:44 -07:00
|
|
|
Eina_Bool resized = EINA_FALSE;
|
|
|
|
Ecore_Evas_Engine_Drm_Data *edata;
|
|
|
|
|
|
|
|
edata = ee->engine.data;
|
2014-03-18 04:11:23 -07:00
|
|
|
if (ee->prop.fullscreen == on) return;
|
2016-05-03 09:03:00 -07:00
|
|
|
ee->prop.fullscreen = on;
|
|
|
|
|
2014-03-28 03:36:44 -07:00
|
|
|
if (on)
|
|
|
|
{
|
|
|
|
int ow = 0, oh = 0;
|
|
|
|
|
|
|
|
edata->w = ee->w;
|
|
|
|
edata->h = ee->h;
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ecore_drm2_output_geometry_get(edata->output, NULL, NULL, &ow, &oh);
|
2014-03-28 03:36:44 -07:00
|
|
|
if ((ow == 0) || (oh == 0))
|
|
|
|
{
|
|
|
|
ow = ee->w;
|
|
|
|
oh = ee->h;
|
|
|
|
}
|
|
|
|
if ((ow != ee->w) || (oh != ee->h)) resized = EINA_TRUE;
|
|
|
|
ee->w = ow;
|
|
|
|
ee->h = oh;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if ((edata->w != ee->w) || (edata->h != ee->h)) resized = EINA_TRUE;
|
|
|
|
ee->w = edata->w;
|
|
|
|
ee->h = edata->h;
|
|
|
|
}
|
|
|
|
|
|
|
|
ee->req.w = ee->w;
|
|
|
|
ee->req.h = ee->h;
|
2014-03-18 04:11:23 -07:00
|
|
|
ee->prop.fullscreen = on;
|
2014-03-28 03:36:44 -07:00
|
|
|
evas_output_size_set(ee->evas, ee->w, ee->h);
|
|
|
|
evas_output_viewport_set(ee->evas, 0, 0, ee->w, ee->h);
|
|
|
|
evas_damage_rectangle_add(ee->evas, 0, 0, ee->w, ee->h);
|
|
|
|
|
|
|
|
if (resized)
|
|
|
|
{
|
|
|
|
if (ee->func.fn_resize) ee->func.fn_resize(ee);
|
|
|
|
}
|
2014-03-18 04:11:23 -07:00
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_withdrawn_set(Ecore_Evas *ee, Eina_Bool on)
|
2014-03-18 04:11:23 -07:00
|
|
|
{
|
|
|
|
if (ee->prop.withdrawn == on) return;
|
|
|
|
ee->prop.withdrawn = on;
|
|
|
|
if (on) ecore_evas_hide(ee);
|
|
|
|
else ecore_evas_show(ee);
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_ignore_events_set(Ecore_Evas *ee, int on)
|
2014-03-18 04:11:23 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
if (ee->ignore_events == on) return;
|
|
|
|
ee->ignore_events = on;
|
2014-03-18 04:11:23 -07:00
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_alpha_set(Ecore_Evas *ee, int alpha)
|
2014-03-18 04:21:02 -07:00
|
|
|
{
|
|
|
|
if (ee->in_async_render)
|
|
|
|
{
|
|
|
|
ee->delayed.alpha = alpha;
|
|
|
|
ee->delayed.alpha_changed = EINA_TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_transparent_set(Ecore_Evas *ee, int transparent)
|
2014-03-18 04:21:02 -07:00
|
|
|
{
|
|
|
|
if (ee->in_async_render)
|
|
|
|
{
|
|
|
|
ee->delayed.transparent = transparent;
|
|
|
|
ee->delayed.transparent_changed = EINA_TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-21 02:22:16 -07:00
|
|
|
static void
|
2016-05-03 09:03:00 -07:00
|
|
|
_drm_aspect_set(Ecore_Evas *ee, double aspect)
|
2014-03-18 04:23:49 -07:00
|
|
|
{
|
|
|
|
if (ee->prop.aspect == aspect) return;
|
|
|
|
ee->prop.aspect = aspect;
|
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
static Ecore_Evas_Interface_Drm *
|
|
|
|
_ecore_evas_drm_interface_new(void)
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
Ecore_Evas_Interface_Drm *iface;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
iface = calloc(1, sizeof(Ecore_Evas_Interface_Drm));
|
|
|
|
if (!iface) return NULL;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
iface->base.name = "drm";
|
|
|
|
iface->base.version = 1;
|
|
|
|
|
|
|
|
return iface;
|
|
|
|
}
|
|
|
|
|
|
|
|
static Ecore_Evas_Engine_Func _ecore_evas_drm_engine_func =
|
|
|
|
{
|
|
|
|
_drm_free,
|
|
|
|
NULL, //void (*fn_callback_resize_set) (Ecore_Evas *ee, Ecore_Evas_Event_Cb func);
|
|
|
|
NULL, //void (*fn_callback_move_set) (Ecore_Evas *ee, Ecore_Evas_Event_Cb func);
|
|
|
|
NULL, //void (*fn_callback_show_set) (Ecore_Evas *ee, Ecore_Evas_Event_Cb func);
|
|
|
|
NULL, //void (*fn_callback_hide_set) (Ecore_Evas *ee, Ecore_Evas_Event_Cb func);
|
|
|
|
NULL, //_ecore_evas_drm_delete_request_set,
|
|
|
|
NULL, //void (*fn_callback_destroy_set) (Ecore_Evas *ee, Ecore_Evas_Event_Cb func);
|
|
|
|
NULL, //_ecore_evas_drm_callback_focus_in_set,
|
|
|
|
NULL, //_ecore_evas_drm_callback_focus_out_set,
|
|
|
|
NULL, //_ecore_evas_drm_callback_mouse_in_set,
|
|
|
|
NULL, //_ecore_evas_drm_callback_mouse_out_set,
|
|
|
|
NULL, //void (*fn_callback_sticky_set) (Ecore_Evas *ee, Ecore_Evas_Event_Cb func);
|
|
|
|
NULL, //void (*fn_callback_unsticky_set) (Ecore_Evas *ee, Ecore_Evas_Event_Cb func);
|
|
|
|
NULL, //void (*fn_callback_pre_render_set) (Ecore_Evas *ee, Ecore_Evas_Event_Cb func);
|
|
|
|
NULL, //void (*fn_callback_post_render_set) (Ecore_Evas *ee, Ecore_Evas_Event_Cb func);
|
|
|
|
_drm_move,
|
|
|
|
NULL, //void (*fn_managed_move) (Ecore_Evas *ee, int x, int y);
|
|
|
|
_drm_resize,
|
|
|
|
_drm_move_resize,
|
|
|
|
_drm_rotation_set,
|
|
|
|
NULL, //void (*fn_shaped_set) (Ecore_Evas *ee, int shaped);
|
|
|
|
_drm_show,
|
|
|
|
_drm_hide,
|
|
|
|
NULL, //void (*fn_raise) (Ecore_Evas *ee);
|
|
|
|
NULL, //void (*fn_lower) (Ecore_Evas *ee);
|
|
|
|
NULL, //void (*fn_activate) (Ecore_Evas *ee);
|
|
|
|
_drm_title_set,
|
|
|
|
_drm_name_class_set,
|
|
|
|
_drm_size_min_set,
|
|
|
|
_drm_size_max_set,
|
|
|
|
_drm_size_base_set,
|
|
|
|
_drm_size_step_set,
|
|
|
|
_drm_object_cursor_set,
|
|
|
|
_drm_object_cursor_unset,
|
|
|
|
_drm_layer_set,
|
|
|
|
NULL, //void (*fn_focus_set) (Ecore_Evas *ee, Eina_Bool on);
|
|
|
|
_drm_iconified_set,
|
|
|
|
_drm_borderless_set,
|
|
|
|
NULL, //void (*fn_override_set) (Ecore_Evas *ee, Eina_Bool on);
|
|
|
|
_drm_maximized_set,
|
|
|
|
_drm_fullscreen_set,
|
|
|
|
NULL, //void (*fn_avoid_damage_set) (Ecore_Evas *ee, int on);
|
|
|
|
_drm_withdrawn_set,
|
|
|
|
NULL, //void (*fn_sticky_set) (Ecore_Evas *ee, Eina_Bool on);
|
|
|
|
_drm_ignore_events_set,
|
|
|
|
_drm_alpha_set,
|
|
|
|
_drm_transparent_set,
|
|
|
|
NULL, //void (*fn_profiles_set) (Ecore_Evas *ee, const char **profiles, int count);
|
|
|
|
NULL, //void (*fn_profile_set) (Ecore_Evas *ee, const char *profile);
|
|
|
|
|
|
|
|
NULL, //void (*fn_window_group_set) (Ecore_Evas *ee, const Ecore_Evas *ee_group);
|
|
|
|
_drm_aspect_set,
|
|
|
|
NULL, //void (*fn_urgent_set) (Ecore_Evas *ee, Eina_Bool on);
|
|
|
|
NULL, //void (*fn_modal_set) (Ecore_Evas *ee, Eina_Bool on);
|
|
|
|
NULL, //void (*fn_demands_attention_set) (Ecore_Evas *ee, Eina_Bool on);
|
|
|
|
NULL, //void (*fn_focus_skip_set) (Ecore_Evas *ee, Eina_Bool on);
|
|
|
|
|
|
|
|
_drm_render,
|
|
|
|
|
|
|
|
_drm_screen_geometry_get,
|
|
|
|
NULL, //void (*fn_screen_dpi_get) (const Ecore_Evas *ee, int *xdpi, int *ydpi);
|
|
|
|
NULL, //void (*fn_msg_parent_send) (Ecore_Evas *ee, int maj, int min, void *data, int size);
|
|
|
|
NULL, //void (*fn_msg_send) (Ecore_Evas *ee, int maj, int min, void *data, int size);
|
|
|
|
|
|
|
|
_drm_pointer_xy_get,
|
|
|
|
_drm_pointer_warp,
|
|
|
|
|
|
|
|
NULL, // wm_rot_preferred_rotation_set
|
|
|
|
NULL, // wm_rot_available_rotations_set
|
|
|
|
NULL, // wm_rot_manual_rotation_done_set
|
|
|
|
NULL, // wm_rot_manual_rotation_done
|
|
|
|
|
|
|
|
NULL, // aux_hints_set
|
|
|
|
|
|
|
|
NULL, // animator_register
|
|
|
|
NULL // animator_unregister
|
|
|
|
};
|
|
|
|
|
|
|
|
EAPI Ecore_Evas *
|
|
|
|
ecore_evas_drm_new_internal(const char *device, unsigned int parent EINA_UNUSED, int x, int y, int w, int h)
|
|
|
|
{
|
|
|
|
Ecore_Evas *ee;
|
|
|
|
Evas_Engine_Info_Drm *einfo;
|
|
|
|
Ecore_Evas_Interface_Drm *iface;
|
|
|
|
Ecore_Evas_Engine_Drm_Data *edata;
|
2016-05-26 07:46:40 -07:00
|
|
|
int method, mw, mh;
|
2016-05-03 09:03:00 -07:00
|
|
|
|
|
|
|
method = evas_render_method_lookup("drm");
|
|
|
|
if (!method) return NULL;
|
|
|
|
|
|
|
|
ee = calloc(1, sizeof(Ecore_Evas));
|
|
|
|
if (!ee) return NULL;
|
|
|
|
|
|
|
|
edata = calloc(1, sizeof(Ecore_Evas_Engine_Drm_Data));
|
|
|
|
if (!edata)
|
2013-05-14 02:45:47 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
free(ee);
|
|
|
|
return NULL;
|
2013-05-14 02:45:47 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
edata->x = x;
|
|
|
|
edata->y = y;
|
|
|
|
edata->w = w;
|
|
|
|
edata->h = h;
|
|
|
|
edata->depth = 24; // FIXME: Remove hardcode
|
|
|
|
edata->bpp = 32; // FIXME: Remove hardcode
|
|
|
|
edata->format = DRM_FORMAT_XRGB8888;
|
|
|
|
|
|
|
|
if (_ecore_evas_drm_init(edata, device) < 1)
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
free(edata);
|
|
|
|
free(ee);
|
|
|
|
return NULL;
|
2014-03-10 03:02:31 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ECORE_MAGIC_SET(ee, ECORE_MAGIC_EVAS);
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ee->driver = "drm";
|
|
|
|
ee->engine.func = (Ecore_Evas_Engine_Func *)&_ecore_evas_drm_engine_func;
|
|
|
|
ee->engine.data = edata;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
/* FIXME */
|
|
|
|
/* if (edata->device) ee->name = strdup(edata->device); */
|
|
|
|
|
|
|
|
iface = _ecore_evas_drm_interface_new();
|
|
|
|
ee->engine.ifaces = eina_list_append(ee->engine.ifaces, iface);
|
|
|
|
|
|
|
|
ee->x = ee->req.x = x;
|
|
|
|
ee->y = ee->req.y = y;
|
|
|
|
ee->w = ee->req.w = w;
|
|
|
|
ee->h = ee->req.h = h;
|
|
|
|
|
|
|
|
ee->prop.max.w = 32767;
|
|
|
|
ee->prop.max.h = 32767;
|
|
|
|
ee->prop.layer = 4;
|
|
|
|
ee->prop.request_pos = 0;
|
|
|
|
ee->prop.sticky = 0;
|
|
|
|
ee->prop.withdrawn = EINA_TRUE;
|
|
|
|
ee->alpha = EINA_FALSE;
|
|
|
|
|
|
|
|
ee->can_async_render = 1;
|
|
|
|
if (getenv("ECORE_EVAS_FORCE_SYNC_RENDER"))
|
|
|
|
ee->can_async_render = 0;
|
|
|
|
|
|
|
|
ee->evas = evas_new();
|
|
|
|
evas_data_attach_set(ee->evas, ee);
|
|
|
|
evas_output_method_set(ee->evas, method);
|
|
|
|
evas_output_size_set(ee->evas, w, h);
|
|
|
|
evas_output_viewport_set(ee->evas, 0, 0, w, h);
|
|
|
|
|
|
|
|
if (ee->can_async_render)
|
|
|
|
evas_event_callback_add(ee->evas, EVAS_CALLBACK_RENDER_POST,
|
|
|
|
_drm_render_updates, ee);
|
|
|
|
|
|
|
|
einfo = (Evas_Engine_Info_Drm *)evas_engine_info_get(ee->evas);
|
|
|
|
if (einfo)
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
einfo->info.fd = edata->fd;
|
|
|
|
einfo->info.bpp = edata->bpp;
|
|
|
|
einfo->info.depth = edata->depth;
|
|
|
|
einfo->info.format = edata->format;
|
|
|
|
einfo->info.rotation = ee->rotation;
|
|
|
|
einfo->info.output = edata->output;
|
|
|
|
if (!evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo))
|
|
|
|
{
|
|
|
|
ERR("evas_engine_info_set() for engine '%s' failed", ee->driver);
|
|
|
|
goto eng_err;
|
|
|
|
}
|
2014-03-10 03:02:31 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ee->prop.window = ecore_drm2_output_crtc_get(edata->output);
|
|
|
|
ecore_drm2_device_window_set(edata->dev, ee->prop.window);
|
|
|
|
|
|
|
|
ecore_evas_data_set(ee, "device", edata->dev);
|
|
|
|
|
|
|
|
_ecore_evas_register(ee);
|
|
|
|
ecore_event_window_register(ee->prop.window, ee, ee->evas,
|
|
|
|
(Ecore_Event_Mouse_Move_Cb)_ecore_evas_mouse_move_process,
|
|
|
|
(Ecore_Event_Multi_Move_Cb)_ecore_evas_mouse_multi_move_process,
|
|
|
|
(Ecore_Event_Multi_Down_Cb)_ecore_evas_mouse_multi_down_process,
|
|
|
|
(Ecore_Event_Multi_Up_Cb)_ecore_evas_mouse_multi_up_process);
|
2016-06-13 09:49:40 -07:00
|
|
|
_ecore_event_window_direct_cb_set(ee->prop.window, _ecore_evas_input_direct_cb);
|
2016-05-03 09:03:00 -07:00
|
|
|
|
2016-05-26 07:46:40 -07:00
|
|
|
ecore_drm2_output_crtc_size_get(edata->output, &mw, &mh);
|
|
|
|
|
|
|
|
ecore_drm2_device_calibrate(edata->dev, mw, mh);
|
|
|
|
ecore_drm2_device_pointer_max_set(edata->dev, mw, mh);
|
|
|
|
ecore_drm2_device_pointer_warp(edata->dev, mw / 2, mh / 2);
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
return ee;
|
|
|
|
|
|
|
|
eng_err:
|
|
|
|
ecore_evas_free(ee);
|
|
|
|
return NULL;
|
2014-03-10 03:02:31 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
#ifdef BUILD_ECORE_EVAS_GL_DRM
|
|
|
|
EAPI Ecore_Evas *
|
|
|
|
ecore_evas_gl_drm_new_internal(const char *device, unsigned int parent EINA_UNUSED, int x, int y, int w, int h)
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
|
|
|
Ecore_Evas *ee;
|
2016-05-03 09:03:00 -07:00
|
|
|
Evas_Engine_Info_GL_Drm *einfo;
|
|
|
|
Ecore_Evas_Interface_Drm *iface;
|
|
|
|
Ecore_Evas_Engine_Drm_Data *edata;
|
2016-05-26 07:46:40 -07:00
|
|
|
int method, mw, mh;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
method = evas_render_method_lookup("gl_drm");
|
|
|
|
if (!method) return NULL;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ee = calloc(1, sizeof(Ecore_Evas));
|
|
|
|
if (!ee) return NULL;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
edata = calloc(1, sizeof(Ecore_Evas_Engine_Drm_Data));
|
|
|
|
if (!edata)
|
|
|
|
{
|
|
|
|
free(ee);
|
|
|
|
return NULL;
|
|
|
|
}
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
edata->x = x;
|
|
|
|
edata->y = y;
|
|
|
|
edata->w = w;
|
|
|
|
edata->h = h;
|
|
|
|
edata->depth = 24; // FIXME: Remove hardcode
|
|
|
|
edata->bpp = 32; // FIXME: Remove hardcode
|
|
|
|
edata->format = DRM_FORMAT_XRGB8888;
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
dlopen("libglapi.so.0", RTLD_LAZY | RTLD_GLOBAL);
|
|
|
|
if (dlerror())
|
|
|
|
{
|
|
|
|
free(edata);
|
|
|
|
free(ee);
|
|
|
|
return NULL;
|
|
|
|
}
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
if (_ecore_evas_drm_init(edata, device) < 1)
|
2014-03-10 03:02:31 -07:00
|
|
|
{
|
2016-05-03 09:03:00 -07:00
|
|
|
free(edata);
|
|
|
|
free(ee);
|
|
|
|
return NULL;
|
|
|
|
}
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ECORE_MAGIC_SET(ee, ECORE_MAGIC_EVAS);
|
|
|
|
|
|
|
|
ee->driver = "gl_drm";
|
|
|
|
ee->engine.func = (Ecore_Evas_Engine_Func *)&_ecore_evas_drm_engine_func;
|
|
|
|
ee->engine.data = edata;
|
|
|
|
|
|
|
|
/* FIXME */
|
|
|
|
/* if (edata->device) ee->name = strdup(edata->device); */
|
|
|
|
|
|
|
|
iface = _ecore_evas_drm_interface_new();
|
|
|
|
ee->engine.ifaces = eina_list_append(ee->engine.ifaces, iface);
|
|
|
|
|
|
|
|
ee->x = ee->req.x = x;
|
|
|
|
ee->y = ee->req.y = y;
|
|
|
|
ee->w = ee->req.w = w;
|
|
|
|
ee->h = ee->req.h = h;
|
|
|
|
|
|
|
|
ee->prop.max.w = 32767;
|
|
|
|
ee->prop.max.h = 32767;
|
|
|
|
ee->prop.layer = 4;
|
|
|
|
ee->prop.request_pos = 0;
|
|
|
|
ee->prop.sticky = 0;
|
|
|
|
ee->prop.withdrawn = EINA_TRUE;
|
|
|
|
ee->alpha = EINA_FALSE;
|
|
|
|
|
|
|
|
ee->can_async_render = 0; // FIXME ??
|
|
|
|
if (getenv("ECORE_EVAS_FORCE_SYNC_RENDER"))
|
|
|
|
ee->can_async_render = 0;
|
|
|
|
|
|
|
|
ee->evas = evas_new();
|
|
|
|
evas_data_attach_set(ee->evas, ee);
|
|
|
|
evas_output_method_set(ee->evas, method);
|
|
|
|
evas_output_size_set(ee->evas, w, h);
|
|
|
|
evas_output_viewport_set(ee->evas, 0, 0, w, h);
|
|
|
|
|
|
|
|
if (ee->can_async_render)
|
|
|
|
evas_event_callback_add(ee->evas, EVAS_CALLBACK_RENDER_POST,
|
|
|
|
_drm_render_updates, ee);
|
|
|
|
|
|
|
|
einfo = (Evas_Engine_Info_GL_Drm *)evas_engine_info_get(ee->evas);
|
|
|
|
if (einfo)
|
|
|
|
{
|
|
|
|
char *num;
|
|
|
|
|
|
|
|
einfo->info.vsync = EINA_TRUE;
|
|
|
|
|
|
|
|
num = getenv("EVAS_DRM_VSYNC");
|
|
|
|
if ((num) && (!atoi(num)))
|
|
|
|
einfo->info.vsync = EINA_FALSE;
|
|
|
|
|
|
|
|
einfo->info.fd = edata->fd;
|
|
|
|
einfo->info.bpp = edata->bpp;
|
|
|
|
einfo->info.depth = edata->depth;
|
|
|
|
einfo->info.format = edata->format;
|
|
|
|
einfo->info.rotation = ee->rotation;
|
|
|
|
einfo->info.output = edata->output;
|
|
|
|
if (!evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo))
|
|
|
|
{
|
|
|
|
ERR("evas_engine_info_set() for engine '%s' failed", ee->driver);
|
|
|
|
goto eng_err;
|
|
|
|
}
|
2014-03-10 03:02:31 -07:00
|
|
|
}
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ee->prop.window = ecore_drm2_output_crtc_get(edata->output);
|
|
|
|
ecore_drm2_device_window_set(edata->dev, ee->prop.window);
|
2014-03-10 03:02:31 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
ecore_evas_data_set(ee, "device", edata->dev);
|
2014-09-04 07:03:28 -07:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
_ecore_evas_register(ee);
|
|
|
|
ecore_event_window_register(ee->prop.window, ee, ee->evas,
|
|
|
|
(Ecore_Event_Mouse_Move_Cb)_ecore_evas_mouse_move_process,
|
|
|
|
(Ecore_Event_Multi_Move_Cb)_ecore_evas_mouse_multi_move_process,
|
|
|
|
(Ecore_Event_Multi_Down_Cb)_ecore_evas_mouse_multi_down_process,
|
|
|
|
(Ecore_Event_Multi_Up_Cb)_ecore_evas_mouse_multi_up_process);
|
2016-06-13 09:49:40 -07:00
|
|
|
_ecore_event_window_direct_cb_set(ee->prop.window, _ecore_evas_input_direct_cb);
|
2014-09-15 08:44:10 -07:00
|
|
|
|
2016-05-26 07:46:40 -07:00
|
|
|
ecore_drm2_output_crtc_size_get(edata->output, &mw, &mh);
|
|
|
|
|
|
|
|
ecore_drm2_device_calibrate(edata->dev, mw, mh);
|
|
|
|
ecore_drm2_device_pointer_max_set(edata->dev, mw, mh);
|
|
|
|
ecore_drm2_device_pointer_warp(edata->dev, mw / 2, mh / 2);
|
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
return ee;
|
2016-01-25 14:20:27 -08:00
|
|
|
|
2016-05-03 09:03:00 -07:00
|
|
|
eng_err:
|
|
|
|
ecore_evas_free(ee);
|
|
|
|
return NULL;
|
2016-01-25 14:20:27 -08:00
|
|
|
}
|
2016-05-03 09:03:00 -07:00
|
|
|
#endif
|