Add listeners for tizen_input_device
[platform/core/api/efl-util.git] / src / efl_util.c
index 0a77054..0d977d2 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
+ * Copyright (c) 2011-2015 Samsung Electronics Co., Ltd All Rights Reserved
  *
  * Licensed under the Apache License, Version 2.0 (the License);
  * you may not use this file except in compliance with the License.
  * distributed under the License is distributed on an AS IS BASIS,
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  * See the License for the specific language governing permissions and
- * limitations under the License. 
+ * limitations under the License.
  */
 
-
 #define LOG_TAG "TIZEN_N_EFL_UTIL"
 
 #include <efl_util.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
+#include <unistd.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <xf86drm.h>
+#include <tbm_bufmgr.h>
+#include <tbm_surface.h>
+#include <tbm_surface_internal.h>
 #include <Elementary.h>
+#include <Ecore_Evas.h>
+#include <pthread.h>
 
-#if X11
-#include <Ecore_X.h>
-#include <utilX.h>
-#endif
-
-#if WAYLAND
 #include <Ecore_Wayland.h>
 #include <wayland-client.h>
-#include "tizen_notification-client-protocol.h"
+#include <wayland-tbm-client.h>
+#include <tizen-extension-client-protocol.h>
+#include <screenshooter-client-protocol.h>
+
+#include <efl_util_screenshot_extension.h>
+
+#include <dlog.h>
+#ifdef LOG_TAG
+#undef LOG_TAG
 #endif
 
-typedef struct _notification_error_cb_info
+#define LOG_TAG "TIZEN_N_EFL_UTIL"
+
+
+/* callback handler index */
+#define CBH_NOTI_LEV 0
+#define CBH_SCR_MODE 1
+#define CBH_MAX      2
+
+typedef void (*Efl_Util_Cb)(Evas_Object *, int, void *);
+
+typedef struct _Efl_Util_Callback_Info
 {
-   Evas_Object *window;
-   efl_util_notification_window_level_error_cb err_cb;
-   void *user_data;
-} notification_error_cb_info;
+   Evas_Object *win;
+   Efl_Util_Cb cb;
+   void *data;
+} Efl_Util_Callback_Info;
 
-Eina_List *_g_notification_error_cb_info_list;
-static Ecore_Event_Handler* _noti_level_access_result_handler = NULL;
-static int _noti_handler_count = 0;
+typedef struct _Efl_Util_Wl_Surface_Lv_Info
+{
+   void *surface; /* wl_surface */
+   int level;
+   Eina_Bool wait_for_done;
+   uint32_t state;
+} Efl_Util_Wl_Surface_Lv_Info;
 
-static notification_error_cb_info *_notification_error_cb_info_find(Evas_Object *window);
-static Eina_Bool _efl_util_notification_info_add(Evas_Object *window, efl_util_notification_window_level_error_cb callback, void *user_data);
-static Eina_Bool _efl_util_notification_info_del(Evas_Object *window);
+typedef struct _Efl_Util_Wl_Surface_Scr_Mode_Info
+{
+   void *surface; /* wl_surface */
+   unsigned int mode;
+   Eina_Bool wait_for_done;
+   uint32_t state;
+} Efl_Util_Wl_Surface_Scr_Mode_Info;
 
-#if X11
-static unsigned int _noti_level_access_result_atom = 0;
+typedef struct _Efl_Util_Wl_Surface_Brightness_Info
+{
+   void *surface; /* wl_surface */
+   int brightness;
+   Eina_Bool wait_for_done;
+   uint32_t state;
+} Efl_Util_Wl_Surface_Brightness_Info;
 
-static Eina_Bool _efl_util_client_message(void *data, int type, void *event);
-static notification_error_cb_info *_notification_error_cb_info_find_by_xwin(unsigned int xwin);
-#endif
+typedef struct _Efl_Util_Wl_Output_Info
+{
+    struct wl_output *output;
+    int offset_x, offset_y, width, height;
+} Efl_Util_Wl_Output_Info;
 
-#if WAYLAND
-typedef struct _Surface_Level
+typedef struct _Efl_Util_Data
 {
-   struct wl_surface *surface;
-   int32_t level;
-   Eina_Bool wait_set_level_done;
-} Surface_Level;
+   /* wayland related stuffs */
+   struct
+   {
+      Eina_Bool init;
+      int ref_count;
+
+      struct wl_display *dpy;
+      struct wl_registry *reg;
+
+      struct wl_event_queue *queue;
+
+      struct
+      {
+         struct tizen_policy *proto;
+         Eina_Hash *hash_noti_lv;
+         Eina_Hash *hash_scr_mode;
+      } policy;
+      struct
+      {
+         struct wl_event_queue *queue;
+         struct screenshooter *screenshooter;
+         struct tizen_screenshooter *tz_screenshooter;
+         struct wayland_tbm_client *tbm_client;
+         Eina_List *output_list;
+         uint32_t noti;
+      } shot;
+      struct
+      {
+         struct tizen_input_device_manager *devicemgr;
+         int request_notified;
+         Eina_List *device_list;
+      } devmgr;
+      struct
+      {
+         struct tizen_display_policy *proto;
+         Eina_Hash *hash_brightness;
+      } display_policy;
+   } wl;
+
+   struct
+   {
+      Eina_List *info_list; /* list of callback info */
+      unsigned int atom; /* x11 atom */
+   } cb_handler[CBH_MAX];
+} Efl_Util_Data;
+
+static Efl_Util_Data _eflutil =
+{
+   {
+      EINA_FALSE,
+      0,
+      NULL, NULL, NULL,
+      { NULL, NULL, NULL }, /* tizen_policy protocol */
+      { NULL, NULL, NULL, NULL, NULL, 0 }, /* screenshooter protocol */
+      { NULL, -1 } /* tizen_input_device_manager protocol */
+   },
+   {
+      { NULL, 0 }, /* handler for notification level */
+      { NULL, 0 }  /* handler for screen mode */
+   },
+};
 
-static void _cb_handle_registry_global(void *data, struct wl_registry *registry, unsigned int name, const char *interface, unsigned int version);
-static void _cb_handle_registry_global_remove(void *data, struct wl_registry *registry, unsigned int name);
-static void _notification_set_level_done(void *data, struct tizen_notification *tizen_notification, struct wl_surface *surface, int32_t level, uint32_t error_state);
-static notification_error_cb_info *_notification_error_cb_info_find_by_wl_surface(struct wl_surface *surface);
+static Eina_Bool               _cb_info_add(Evas_Object *win, Efl_Util_Cb cb, void *data, int idx);
+static Eina_Bool               _cb_info_del_by_win(Evas_Object *win, int idx);
+static Eina_List              *_cb_info_list_get(int idx);
+static Efl_Util_Callback_Info *_cb_info_find_by_win(Evas_Object *win, int idx);
+static Eina_Bool               _wl_init(void);
+static void                    _wl_shutdown(void);
+
+static void                    _cb_wl_reg_global(void *data, struct wl_registry *reg, unsigned int name, const char *interface, unsigned int version);
+static void                    _cb_wl_reg_global_remove(void *data, struct wl_registry *reg, unsigned int name);
+static void                    _cb_wl_reg_screenshooter_global(void *data, struct wl_registry *reg, unsigned int name, const char *interface, unsigned int version);
+static void                    _cb_wl_reg_screenshooter_global_remove(void *data, struct wl_registry *reg, unsigned int name);
+static Efl_Util_Callback_Info *_cb_info_find_by_wlsurf(void *wlsurf, int idx);
+static void                    _cb_wl_tz_policy_conformant(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface, uint32_t is_conformant);
+static void                    _cb_wl_tz_policy_conformant_area(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface, uint32_t conformant_part, uint32_t state, int32_t x, int32_t y, int32_t w, int32_t h);
+static void                    _cb_wl_tz_policy_notification_done(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface, int32_t level, uint32_t state);
+static void                    _cb_wl_tz_policy_transient_for_done(void *data, struct tizen_policy *tizen_policy, uint32_t child_id);
+static void                    _cb_wl_tz_policy_scr_mode_done(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface, uint32_t mode, uint32_t state);
+static void                    _cb_wl_tz_policy_iconify_state_changed(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, uint32_t iconified, uint32_t force);
+static void                    _cb_wl_tz_policy_supported_aux_hints(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, struct wl_array *hints, uint32_t num_hints);
+static void                    _cb_wl_tz_policy_allowed_aux_hint(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, int id);
+static void                    _cb_wl_tz_policy_aux_message(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, const char *key, const char *val, struct wl_array *options);
+
+static void                    _cb_wl_tz_display_policy_brightness_done(void *data, struct tizen_display_policy *tizen_display_policy, struct wl_surface *surface_resource, int32_t brightness, uint32_t state);
+
+static void                    _cb_device_add(void *data EINA_UNUSED, struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED, uint32_t serial  EINA_UNUSED, const char *identifier  EINA_UNUSED, struct tizen_input_device *device  EINA_UNUSED, struct wl_seat *seat EINA_UNUSED);
+static void                    _cb_device_remove(void *data EINA_UNUSED, struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED, uint32_t serial EINA_UNUSED, const char *identifier  EINA_UNUSED, struct tizen_input_device *device EINA_UNUSED, struct wl_seat *seat EINA_UNUSED);
+static void                    _cb_error(void *data EINA_UNUSED, struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED, uint32_t errorcode);
+static void                    _cb_block_expired(void *data EINA_UNUSED, struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED);
+static void                    _cb_device_info(void *data EINA_UNUSED, struct tizen_input_device *tizen_input_device EINA_UNUSED, const char *name EINA_UNUSED, uint32_t clas EINA_UNUSED, uint32_t subclas EINA_UNUSED, struct wl_array *axes EINA_UNUSED);
+static void                    _cb_event_device(void *data EINA_UNUSED, struct tizen_input_device *tizen_input_device EINA_UNUSED, unsigned int serial EINA_UNUSED, const char *name EINA_UNUSED, uint32_t time EINA_UNUSED);
+static void                    _cb_axis(void *data EINA_UNUSED, struct tizen_input_device *tizen_input_device EINA_UNUSED, uint32_t axis_type EINA_UNUSED, wl_fixed_t value EINA_UNUSED);
+
+static const struct wl_registry_listener _wl_reg_listener =
+{
+   _cb_wl_reg_global,
+   _cb_wl_reg_global_remove
+};
 
-static const struct wl_registry_listener _registry_listener =
+static const struct wl_registry_listener _wl_reg_screenshooter_listener =
 {
-   _cb_handle_registry_global,
-   _cb_handle_registry_global_remove
+   _cb_wl_reg_screenshooter_global,
+   _cb_wl_reg_screenshooter_global_remove
 };
 
-struct tizen_notification_listener _tizen_notification_listener =
+struct tizen_policy_listener _wl_tz_policy_listener =
 {
-   _notification_set_level_done,
+   _cb_wl_tz_policy_conformant,
+   _cb_wl_tz_policy_conformant_area,
+   _cb_wl_tz_policy_notification_done,
+   _cb_wl_tz_policy_transient_for_done,
+   _cb_wl_tz_policy_scr_mode_done,
+   _cb_wl_tz_policy_iconify_state_changed,
+   _cb_wl_tz_policy_supported_aux_hints,
+   _cb_wl_tz_policy_allowed_aux_hint,
+   _cb_wl_tz_policy_aux_message,
 };
 
-static struct tizen_notification *_tizen_notification = NULL;
-static Eina_Bool _efl_util_init_done = EINA_FALSE;
-static Eina_Hash *hash_surface_levels = NULL;
+struct tizen_input_device_manager_listener _wl_tz_devmgr_listener =
+{
+   _cb_device_add,
+   _cb_device_remove,
+   _cb_error,
+   _cb_block_expired
+};
 
-static void
-_cb_handle_registry_global(void *data, struct wl_registry *registry, unsigned int name, const char *interface, unsigned int version)
+struct tizen_input_device_listener _wl_tz_dev_listener =
+{
+   _cb_device_info,
+   _cb_event_device,
+   _cb_axis,
+};
+
+struct tizen_display_policy_listener _wl_tz_display_policy_listener =
+{
+   _cb_wl_tz_display_policy_brightness_done,
+};
+
+static Eina_Bool
+_cb_info_add(Evas_Object *win,
+             Efl_Util_Cb cb,
+             void *data,
+             int idx)
 {
-   if (!strcmp(interface, "tizen_notification"))
+   Efl_Util_Callback_Info *info;
+
+   info = _cb_info_find_by_win(win, idx);
+   if (info)
      {
-        _tizen_notification = wl_registry_bind(registry, name, &tizen_notification_interface, 1);
-        if (!_tizen_notification) return;
-        tizen_notification_add_listener(_tizen_notification, &_tizen_notification_listener, NULL);
-        _efl_util_init_done = EINA_TRUE;
-        hash_surface_levels = eina_hash_pointer_new(free);
+        _eflutil.cb_handler[idx].info_list
+           = eina_list_remove(_eflutil.cb_handler[idx].info_list,
+                              info);
+        free(info);
      }
+
+   info = (Efl_Util_Callback_Info *)calloc(1, sizeof(Efl_Util_Callback_Info));
+   if (!info) return EINA_FALSE;
+
+   info->win = win;
+   info->cb = cb;
+   info->data = data;
+
+   _eflutil.cb_handler[idx].info_list
+      = eina_list_append(_eflutil.cb_handler[idx].info_list,
+                         info);
+
+   return EINA_TRUE;
 }
 
-# define _FREE_FUNC(_h, _fn) do { if (_h) { _fn((void*)_h); _h = NULL; } } while (0)
-static void
-_cb_handle_registry_global_remove(void *data, struct wl_registry *registry, unsigned int name)
+static Eina_Bool
+_cb_info_del_by_win(Evas_Object *win,
+                    int idx)
 {
-   _tizen_notification = NULL;
-   _efl_util_init_done = EINA_FALSE;
-   _FREE_FUNC(hash_surface_levels, eina_hash_free);
-   /* no-op */
+   Efl_Util_Callback_Info *info;
+
+   info = _cb_info_find_by_win(win, idx);
+   if (!info) return EINA_FALSE;
+
+   _eflutil.cb_handler[idx].info_list
+      = eina_list_remove(_eflutil.cb_handler[idx].info_list,
+                         info);
+   free(info);
+
+   return EINA_TRUE;
 }
 
-static void
-_notification_set_level_done(void *data,
-                             struct tizen_notification *tizen_notification,
-                             struct wl_surface *surface,
-                             int32_t level,
-                             uint32_t error_state)
+static Eina_List *
+_cb_info_list_get(int idx)
 {
-   Surface_Level *sl;
-   notification_error_cb_info *cb_info = NULL;
-   efl_util_error_e error_cb_state = EFL_UTIL_ERROR_NONE;
+   return _eflutil.cb_handler[idx].info_list;
+}
 
-   if (hash_surface_levels)
-     {
-        sl = eina_hash_find(hash_surface_levels, &surface);
-        if (sl)
-          {
-             sl->level = level;
-             sl->wait_set_level_done = EINA_FALSE;
-          }
-     }
+static Efl_Util_Callback_Info *
+_cb_info_find_by_win(Evas_Object *win,
+                     int idx)
+{
+   Eina_List *l, *ll;
+   Efl_Util_Callback_Info *info;
 
-   cb_info = _notification_error_cb_info_find_by_wl_surface(surface);
-   if (cb_info)
+   l = _cb_info_list_get(idx);
+   EINA_LIST_FOREACH(l, ll, info)
      {
-        switch (error_state)
-          {
-             case TIZEN_NOTIFICATION_ERROR_STATE_NONE:
-                error_cb_state = EFL_UTIL_ERROR_NONE;
-                break;
-             case TIZEN_NOTIFICATION_ERROR_STATE_PERMISSION_DENIED:
-             default:
-                error_cb_state = EFL_UTIL_ERROR_PERMISSION_DENIED;
-                break;
-          }
-        if (cb_info->err_cb)
-          cb_info->err_cb(cb_info->window, error_cb_state , cb_info->user_data);
+        if (info->win == win) return info;
      }
+
+   return NULL;
 }
 
-static void
-_efl_util_wl_init(void)
+static Eina_Bool
+_wl_init(void)
 {
-   static Eina_Bool init = EINA_FALSE;
-   if (!init)
+   _eflutil.wl.ref_count++;
+
+   if (_eflutil.wl.init) return EINA_TRUE;
+
+   ecore_wl_init(NULL);
+
+   _eflutil.wl.dpy = ecore_wl_display_get();
+   EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.dpy, fail);
+
+   _eflutil.wl.queue = wl_display_create_queue(_eflutil.wl.dpy);
+   EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.queue, fail);
+
+   _eflutil.wl.reg = wl_display_get_registry(_eflutil.wl.dpy);
+   EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.reg, fail);
+
+   wl_proxy_set_queue((struct wl_proxy*)_eflutil.wl.reg, _eflutil.wl.queue);
+   wl_registry_add_listener(_eflutil.wl.reg, &_wl_reg_listener, NULL);
+
+   _eflutil.wl.init = EINA_TRUE;
+
+   return EINA_TRUE;
+fail:
+   if (_eflutil.wl.queue)
      {
-        wl_registry_add_listener(wl_display_get_registry(ecore_wl_display_get()),
-                                 &_registry_listener, NULL);
-        init = EINA_TRUE;
+        wl_event_queue_destroy(_eflutil.wl.queue);
+        _eflutil.wl.queue = NULL;
      }
-   while (!_efl_util_init_done)
-     wl_display_dispatch(ecore_wl_display_get());
+
+   if (_eflutil.wl.reg)
+     {
+        wl_registry_destroy(_eflutil.wl.reg);
+        _eflutil.wl.reg = NULL;
+     }
+
+   _eflutil.wl.dpy = NULL;
+
+   ecore_wl_shutdown();
+   return EINA_FALSE;
 }
-#endif
 
-int
-efl_util_set_notification_window_level(Evas_Object *window, efl_util_notification_level_e level)
+static void
+_wl_shutdown(void)
 {
-   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
-   EINA_SAFETY_ON_FALSE_RETURN_VAL((level >= EFL_UTIL_NOTIFICATION_LEVEL_1) &&
-                                   (level <= EFL_UTIL_NOTIFICATION_LEVEL_TOP),
-                                   EFL_UTIL_ERROR_INVALID_PARAMETER);
+   Eina_List *l, *ll;
+   struct tizen_input_device *data;
+   Efl_Util_Wl_Output_Info *output;
 
-#if X11
-   Ecore_X_Window xwin = elm_win_xwindow_get(window);
-   if (xwin)
-     {
-        Ecore_X_Window_Type window_type;
-        if(ecore_x_netwm_window_type_get(xwin, &window_type) == EINA_TRUE)
-          {
-             // success to get window type
-             if(window_type != ECORE_X_WINDOW_TYPE_NOTIFICATION)
-               {
-                  // given EFL window's type is not notification type.
-                  return EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE;
-               }
-          }
-        else
-          return EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE;
+   if (!_eflutil.wl.init) return;
 
-        utilx_set_system_notification_level(ecore_x_display_get(), xwin,
-                                            level);
-        return EFL_UTIL_ERROR_NONE;
-     }
-#endif
+   _eflutil.wl.ref_count--;
+   if (_eflutil.wl.ref_count > 0)
+     return;
 
-#if WAYLAND
-   Ecore_Wl_Window *wl_win = elm_win_wl_window_get(window);
-   if (wl_win)
-     {
-        _efl_util_wl_init();
+   // tizen_policy
+   if (_eflutil.wl.policy.proto)
+     tizen_policy_destroy(_eflutil.wl.policy.proto);
+   _eflutil.wl.policy.proto = NULL;
 
-        if (hash_surface_levels)
+   eina_hash_free(_eflutil.wl.policy.hash_noti_lv);
+   _eflutil.wl.policy.hash_noti_lv = NULL;
+   eina_hash_free(_eflutil.wl.policy.hash_scr_mode);
+   _eflutil.wl.policy.hash_scr_mode = NULL;
+
+   // wl_output
+   if (_eflutil.wl.shot.output_list)
+     {
+        EINA_LIST_FREE(_eflutil.wl.shot.output_list, output)
           {
-             Surface_Level *sl;
-             struct wl_surface *surface = ecore_wl_window_surface_get(wl_win);
-             sl = eina_hash_find(hash_surface_levels, &surface);
-             if (!sl)
-               {
-                  sl = calloc(1, sizeof(Surface_Level));
-                  if (sl)
-                    {
-                       sl->surface = surface;
-                       sl->level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT;
-                       sl->wait_set_level_done = EINA_TRUE;
-                       eina_hash_add(hash_surface_levels, &surface, sl);
-                    }
-               }
-             else
-               {
-                  sl->wait_set_level_done = EINA_TRUE;
-               }
+             wl_output_destroy(output->output);
+             free(output);
           }
-
-        //Add notification window type check
-        tizen_notification_set_level(_tizen_notification,
-                                     ecore_wl_window_surface_get(wl_win),
-                                     level);
-        return EFL_UTIL_ERROR_NONE;
      }
-#endif
+   _eflutil.wl.shot.output_list = NULL;
 
-   return EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE;
-}
+   // screenshooter
+   if (_eflutil.wl.shot.screenshooter)
+     screenshooter_destroy(_eflutil.wl.shot.screenshooter);
+   _eflutil.wl.shot.screenshooter = NULL;
 
-int
-efl_util_get_notification_window_level(Evas_Object *window, efl_util_notification_level_e *level)
-{
+   // tizen_input_device_manager
+   EINA_LIST_FOREACH_SAFE(_eflutil.wl.devmgr.device_list, l, ll, data)
+     {
+        tizen_input_device_release(data);
+        _eflutil.wl.devmgr.device_list = eina_list_remove_list(_eflutil.wl.devmgr.device_list, l);
+     }
+   ecore_wl_sync();
+   if (_eflutil.wl.devmgr.devicemgr)
+     tizen_input_device_manager_destroy(_eflutil.wl.devmgr.devicemgr);
+   _eflutil.wl.devmgr.devicemgr = NULL;
 
-   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
-   EINA_SAFETY_ON_NULL_RETURN_VAL(level, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   // tizen_display_policy
+   if (_eflutil.wl.display_policy.proto)
+     tizen_display_policy_destroy(_eflutil.wl.display_policy.proto);
+   _eflutil.wl.display_policy.proto = NULL;
+
+   eina_hash_free(_eflutil.wl.display_policy.hash_brightness);
+   _eflutil.wl.display_policy.hash_brightness = NULL;
 
-#if X11
-   Ecore_X_Window_Type window_type;
-   Utilx_Notification_Level utilx_level;
-   Ecore_X_Window xwin = elm_win_xwindow_get(window);
-   if (xwin)
+   if (_eflutil.wl.reg)
      {
-        if(ecore_x_netwm_window_type_get(xwin, &window_type) == EINA_TRUE)
-          {
-             // success to get window type
-             if(window_type != ECORE_X_WINDOW_TYPE_NOTIFICATION)
-               {
-                  // given EFL window's type is not notification type.
-                  return EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE;
-               }
+        wl_proxy_set_queue((struct wl_proxy*)_eflutil.wl.reg, NULL);
+        wl_registry_destroy(_eflutil.wl.reg);
+        _eflutil.wl.reg = NULL;
+     }
 
-             utilx_level = utilx_get_system_notification_level (ecore_x_display_get(), xwin);
+   if (_eflutil.wl.queue)
+     {
+        wl_event_queue_destroy(_eflutil.wl.queue);
+        _eflutil.wl.queue = NULL;
+     }
 
-             if(utilx_level == UTILX_NOTIFICATION_LEVEL_LOW)
-               {
-                  *level = EFL_UTIL_NOTIFICATION_LEVEL_1;
-               }
-             else if(utilx_level == UTILX_NOTIFICATION_LEVEL_NORMAL)
-               {
-                  *level = EFL_UTIL_NOTIFICATION_LEVEL_2;
-               }
-             else if(utilx_level == UTILX_NOTIFICATION_LEVEL_HIGH)
-               {
-                  *level = EFL_UTIL_NOTIFICATION_LEVEL_3;
-               }
-             else
-               {
-                  return EFL_UTIL_ERROR_INVALID_PARAMETER;
-               }
+   _eflutil.wl.dpy = NULL;
+   _eflutil.wl.init = EINA_FALSE;
 
-          }
-        else
-          {
-             // fail to get window type
-             return EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE;
-          }
+   ecore_wl_shutdown();
+}
 
-        return EFL_UTIL_ERROR_NONE;
+static void
+_cb_wl_output_geometry(void *data, struct wl_output *wl_output, int x, int y,
+                       int physical_width, int physical_height, int subpixel,
+                       const char *make, const char *model, int transform)
+{
+   Efl_Util_Wl_Output_Info *output = wl_output_get_user_data(wl_output);
+   if (wl_output == output->output)
+     {
+        output->offset_x = x;
+        output->offset_y = y;
      }
-#endif
+}
 
-#if WAYLAND
-   Ecore_Wl_Window *wl_win = elm_win_wl_window_get(window);
-   if (wl_win)
+static void
+_cb_wl_output_mode(void *data, struct wl_output *wl_output, uint32_t flags,
+                   int width, int height, int refresh)
+{
+   Efl_Util_Wl_Output_Info *output = wl_output_get_user_data(wl_output);
+   if (wl_output == output->output && (flags & WL_OUTPUT_MODE_CURRENT))
      {
-        Surface_Level *sl;
-        struct wl_surface *surface = ecore_wl_window_surface_get(wl_win);
-
-        sl = eina_hash_find(hash_surface_levels, &surface);
-        if (sl)
-          {
-            if (sl->wait_set_level_done)
-              {
-                  if (ecore_wl_window_shell_surface_get(wl_win) ||
-                      ecore_wl_window_xdg_surface_get(wl_win))
-                    {
-                       while (sl->wait_set_level_done)
-                         {
-                            ecore_wl_flush();
-                            wl_display_dispatch(ecore_wl_display_get());
-                         }
-                    }
-                  else
-                    {
-                       *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT;
-                       return EFL_UTIL_ERROR_INVALID_PARAMETER;
-                    }
-              }
-
-            switch (sl->level)
-              {
-                 case TIZEN_NOTIFICATION_LEVEL_1:
-                   *level = EFL_UTIL_NOTIFICATION_LEVEL_1;
-                   break;
-                 case TIZEN_NOTIFICATION_LEVEL_2:
-                   *level = EFL_UTIL_NOTIFICATION_LEVEL_2;
-                   break;
-                 case TIZEN_NOTIFICATION_LEVEL_3:
-                   *level = EFL_UTIL_NOTIFICATION_LEVEL_3;
-                   break;
-                 case TIZEN_NOTIFICATION_LEVEL_NONE:
-                   *level = EFL_UTIL_NOTIFICATION_LEVEL_NONE;
-                   break;
-                 case TIZEN_NOTIFICATION_LEVEL_DEFAULT:
-                   *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT;
-                   break;
-                 case TIZEN_NOTIFICATION_LEVEL_MEDIUM:
-                   *level = EFL_UTIL_NOTIFICATION_LEVEL_MEDIUM;
-                   break;
-                 case TIZEN_NOTIFICATION_LEVEL_HIGH:
-                   *level = EFL_UTIL_NOTIFICATION_LEVEL_HIGH;
-                   break;
-                 case TIZEN_NOTIFICATION_LEVEL_TOP:
-                   *level = EFL_UTIL_NOTIFICATION_LEVEL_TOP;
-                   break;
-                 default:
-                   *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT;
-                   return EFL_UTIL_ERROR_INVALID_PARAMETER;
-              }
-            return EFL_UTIL_ERROR_NONE;
-          }
-        else
-          {
-             *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT;
-          }
+        output->width = width;
+        output->height = height;
      }
-#endif
-   return EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE;
 }
 
-int
-efl_util_set_notification_window_level_error_cb(Evas_Object *window, efl_util_notification_window_level_error_cb callback, void *user_data)
+static void
+_cb_wl_output_done(void *data, struct wl_output *wl_output)
 {
-   Eina_Bool ret = EINA_FALSE;
+}
 
-   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
-   EINA_SAFETY_ON_NULL_RETURN_VAL(callback, EFL_UTIL_ERROR_INVALID_PARAMETER);
+static void
+_cb_wl_output_scale(void *data, struct wl_output *wl_output, int32_t factor)
+{
+}
 
-   ret = _efl_util_notification_info_add(window, callback, user_data);
-   if (ret)
-     {
-#if X11
-        if (!_noti_level_access_result_atom)
-          _noti_level_access_result_atom = ecore_x_atom_get("_E_NOTIFICATION_LEVEL_ACCESS_RESULT");
+static const struct wl_output_listener output_listener =
+{
+    _cb_wl_output_geometry,
+    _cb_wl_output_mode,
+    _cb_wl_output_done,
+    _cb_wl_output_scale
+};
 
-        if (!_noti_level_access_result_handler)
-          _noti_level_access_result_handler = ecore_event_handler_add(ECORE_X_EVENT_CLIENT_MESSAGE, _efl_util_client_message, NULL);
-        _noti_handler_count++;
+static void
+_cb_wl_screenshot_done(void *data, struct screenshooter *screenshooter)
+{
+   Eina_Bool *shot_done = (Eina_Bool*)data;
+   if (shot_done)
+     *shot_done = EINA_TRUE;
+}
 
-        return EFL_UTIL_ERROR_NONE;
-#endif
+static const struct screenshooter_listener screenshooter_listener =
+{
+    _cb_wl_screenshot_done
+};
 
-#if WAYLAND
-        return EFL_UTIL_ERROR_NONE;
-#endif
-     }
-   return EFL_UTIL_ERROR_OUT_OF_MEMORY;
+static void
+_cb_tz_screenshot_format(void *data, struct tizen_screenshooter *tz_screenshooter, uint32_t format)
+{
 }
 
-int
-efl_util_unset_notification_window_level_error_cb(Evas_Object *window)
+static void
+_cb_tz_screenshot_noti(void *data, struct tizen_screenshooter *tz_screenshooter, uint32_t noti)
 {
-   Eina_Bool ret = EINA_FALSE;
+   _eflutil.wl.shot.noti = noti;
+}
 
-   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+static const struct tizen_screenshooter_listener tz_screenshooter_listener =
+{
+    _cb_tz_screenshot_format,
+    _cb_tz_screenshot_noti
+};
 
-   ret = _efl_util_notification_info_del(window);
-   if (ret)
+static void
+_cb_wl_reg_global(void *data,
+                  struct wl_registry *reg,
+                  unsigned int name,
+                  const char *interface,
+                  unsigned int version)
+{
+   if (!strcmp(interface, "tizen_policy"))
      {
-        _noti_handler_count--;
-        if (_noti_handler_count == 0)
-          {
-             if (_noti_level_access_result_handler)
-               {
-                  ecore_event_handler_del(_noti_level_access_result_handler);
-                  _noti_level_access_result_handler = NULL;
-               }
-          }
-        return EFL_UTIL_ERROR_NONE;
+        struct tizen_policy *proto;
+        proto = wl_registry_bind(reg,
+                                  name,
+                                  &tizen_policy_interface,
+                                  1);
+        if (!proto) return;
+
+        tizen_policy_add_listener(proto,
+                                  &_wl_tz_policy_listener,
+                                  NULL);
+
+        _eflutil.wl.policy.hash_noti_lv = eina_hash_pointer_new(free);
+        _eflutil.wl.policy.hash_scr_mode = eina_hash_pointer_new(free);
+        _eflutil.wl.policy.proto = proto;
      }
+   else if (strcmp(interface, "wl_output") == 0)
+     {
+        Efl_Util_Wl_Output_Info *output = calloc(1, sizeof(Efl_Util_Wl_Output_Info));
+        EINA_SAFETY_ON_NULL_RETURN(output);
 
-   return EFL_UTIL_ERROR_INVALID_PARAMETER;
-}
+        _eflutil.wl.shot.output_list = eina_list_append(_eflutil.wl.shot.output_list, output);
 
-#if X11
-static Eina_Bool
-_efl_util_client_message(void *data, int type, void *event)
-{
-   Ecore_X_Event_Client_Message *ev;
+        output->output = wl_registry_bind(reg, name, &wl_output_interface, version);
+        wl_output_add_listener(output->output, &output_listener, output);
+     }
+   else if (strcmp(interface, "tizen_input_device_manager") == 0)
+     {
+        _eflutil.wl.devmgr.devicemgr = wl_registry_bind(reg, name, &tizen_input_device_manager_interface, version);
+        tizen_input_device_manager_add_listener(_eflutil.wl.devmgr.devicemgr, &_wl_tz_devmgr_listener, NULL);
+     }
+   else if (!strcmp(interface, "tizen_display_policy"))
+     {
+        _eflutil.wl.display_policy.proto = wl_registry_bind(reg, name, &tizen_display_policy_interface, version);
+        if (!_eflutil.wl.display_policy.proto) return;
 
-   ev = event;
-   if (!ev) return ECORE_CALLBACK_PASS_ON;
+        tizen_display_policy_add_listener(_eflutil.wl.display_policy.proto,
+                                          &_wl_tz_display_policy_listener,
+                                          NULL);
 
-   if (ev->message_type == _noti_level_access_result_atom)
-     {
-        Ecore_X_Window xwin;
-        xwin = ev->win;
+        _eflutil.wl.display_policy.hash_brightness = eina_hash_pointer_new(free);
+     }
 
-        notification_error_cb_info *cb_info = NULL;
-        cb_info = _notification_error_cb_info_find_by_xwin(xwin);
-        if (cb_info)
+}
+/* LCOV_EXCL_START */
+static void
+_cb_wl_reg_global_remove(void *data,
+                         struct wl_registry *reg,
+                         unsigned int name)
+{
+   Eina_List *l, *ll;
+   struct tizen_input_device *ddata;
+   Efl_Util_Wl_Output_Info *output;
+
+   // tizen_policy
+   if (_eflutil.wl.policy.proto)
+     tizen_policy_destroy(_eflutil.wl.policy.proto);
+   _eflutil.wl.policy.proto = NULL;
+
+   eina_hash_free(_eflutil.wl.policy.hash_noti_lv);
+   _eflutil.wl.policy.hash_noti_lv = NULL;
+   eina_hash_free(_eflutil.wl.policy.hash_scr_mode);
+   _eflutil.wl.policy.hash_scr_mode = NULL;
+
+   // wl_output
+   if (_eflutil.wl.shot.output_list)
+     {
+        EINA_LIST_FREE(_eflutil.wl.shot.output_list, output)
           {
-             int access = ev->data.l[1];
-             if (access == 0) // permission denied
-               {
-                  if (cb_info->err_cb)
-                    {
-                       cb_info->err_cb(cb_info->window, EFL_UTIL_ERROR_PERMISSION_DENIED, cb_info->user_data);
-                    }
-               }
+             wl_output_destroy(output->output);
+             free(output);
           }
      }
+   _eflutil.wl.shot.output_list = NULL;
+
+   // screenshooter
+   if (_eflutil.wl.shot.screenshooter)
+     screenshooter_destroy(_eflutil.wl.shot.screenshooter);
+   _eflutil.wl.shot.screenshooter = NULL;
+
+   // tizen_input_device_manager
+   EINA_LIST_FOREACH_SAFE(_eflutil.wl.devmgr.device_list, l, ll, ddata)
+     {
+        tizen_input_device_release(ddata);
+        _eflutil.wl.devmgr.device_list = eina_list_remove_list(_eflutil.wl.devmgr.device_list, l);
+     }
+   if (_eflutil.wl.devmgr.devicemgr)
+     tizen_input_device_manager_destroy(_eflutil.wl.devmgr.devicemgr);
+   _eflutil.wl.devmgr.devicemgr = NULL;
 
-   return ECORE_CALLBACK_PASS_ON;
+   // tizen_display_policy
+   if (_eflutil.wl.display_policy.proto)
+     tizen_display_policy_destroy(_eflutil.wl.display_policy.proto);
+   _eflutil.wl.display_policy.proto = NULL;
+
+   eina_hash_free(_eflutil.wl.display_policy.hash_brightness);
+   _eflutil.wl.display_policy.hash_brightness = NULL;
 }
+/* LCOV_EXCL_STOP */
 
-static notification_error_cb_info *
-_notification_error_cb_info_find_by_xwin(unsigned int xwin)
+static void
+_cb_wl_reg_screenshooter_global(void *data,
+                  struct wl_registry *reg,
+                  unsigned int name,
+                  const char *interface,
+                  unsigned int version)
 {
-   Eina_List *l;
-   notification_error_cb_info* temp;
-   unsigned int temp_xwin;
-
-   EINA_LIST_FOREACH(_g_notification_error_cb_info_list, l, temp)
+   if (strcmp(interface, "screenshooter") == 0)
      {
-        if (temp->window)
-          {
-             temp_xwin = elm_win_xwindow_get(temp->window);
-             if (xwin == temp_xwin)
-               {
-                  return temp;
-               }
-          }
+        _eflutil.wl.shot.screenshooter = wl_registry_bind(reg, name, &screenshooter_interface, version);
+        screenshooter_add_listener(_eflutil.wl.shot.screenshooter, &screenshooter_listener, NULL);
      }
+   else if (strcmp(interface, "tizen_screenshooter") == 0)
+     {
+        _eflutil.wl.shot.tz_screenshooter = wl_registry_bind(reg, name, &tizen_screenshooter_interface, version);
+        tizen_screenshooter_add_listener(_eflutil.wl.shot.tz_screenshooter, &tz_screenshooter_listener, NULL);
 
-   return NULL;
+        wl_display_roundtrip_queue(_eflutil.wl.dpy, _eflutil.wl.shot.queue);
+     }
 }
-#endif
 
-#if WAYLAND
-static notification_error_cb_info *
-_notification_error_cb_info_find_by_wl_surface(struct wl_surface *surface)
+/* LCOV_EXCL_START */
+static void
+_cb_wl_reg_screenshooter_global_remove(void *data,
+                         struct wl_registry *reg,
+                         unsigned int name)
 {
-   Eina_List *l;
-   notification_error_cb_info* temp;
-   struct wl_surface *temp_surface;
+}
+
+static Efl_Util_Callback_Info *
+_cb_info_find_by_wlsurf(void *wlsurf,
+                        int idx)
+{
+   Eina_List *l, *ll;
+   Efl_Util_Callback_Info *info;
+   Ecore_Wl_Window *wlwin2 = NULL;
+   void *wlsurf2 = NULL;
 
-   EINA_LIST_FOREACH(_g_notification_error_cb_info_list, l, temp)
+   l = _cb_info_list_get(idx);
+   EINA_LIST_FOREACH(l, ll, info)
      {
-        if (temp->window)
-          {
-             temp_surface = ecore_wl_window_surface_get(elm_win_wl_window_get(temp->window));
-             if (surface == temp_surface)
-               {
-                  return temp;
-               }
-          }
+        wlwin2 = elm_win_wl_window_get(info->win);
+        wlsurf2 = ecore_wl_window_surface_get(wlwin2);
+        if (wlsurf== wlsurf2) return info;
      }
 
    return NULL;
 }
-#endif
 
-static notification_error_cb_info *
-_notification_error_cb_info_find(Evas_Object *window)
+static void
+_cb_wl_tz_policy_conformant(void *data, struct tizen_policy *tizen_policy,
+                            struct wl_surface *surface, uint32_t is_conformant)
 {
-   Eina_List *l;
-   notification_error_cb_info* temp;
+}
+
+static void
+_cb_wl_tz_policy_conformant_area(void *data, struct tizen_policy *tizen_policy,
+                                 struct wl_surface *surface, uint32_t conformant_part,
+                                 uint32_t state, int32_t x, int32_t y, int32_t w, int32_t h)
+{
+}
+/* LCOV_EXCL_STOP */
+
+static void
+_cb_wl_tz_policy_notification_done(void *data,
+                                   struct tizen_policy *tizen_policy,
+                                   struct wl_surface *surface,
+                                   int32_t level,
+                                   uint32_t state)
+{
+   Efl_Util_Wl_Surface_Lv_Info *lv_info;
+   Efl_Util_Callback_Info *cb_info;
 
-   EINA_LIST_FOREACH(_g_notification_error_cb_info_list, l, temp)
+   lv_info = eina_hash_find(_eflutil.wl.policy.hash_noti_lv, &surface);
+   if (lv_info)
      {
-        if (temp->window == window)
-          {
-             return temp;
-          }
+        lv_info->level = level;
+        lv_info->wait_for_done = EINA_FALSE;
+        lv_info->state = state;
      }
 
-   return NULL;
+   if (state != TIZEN_POLICY_ERROR_STATE_PERMISSION_DENIED) return;
+
+   cb_info = _cb_info_find_by_wlsurf((void *)surface, CBH_NOTI_LEV);
+   if (!cb_info) return;
+   if (!cb_info->cb) return;
+
+   cb_info->cb(cb_info->win,
+               EFL_UTIL_ERROR_PERMISSION_DENIED,
+               cb_info->data);
 }
 
-static Eina_Bool
-_efl_util_notification_info_add(Evas_Object *window, efl_util_notification_window_level_error_cb callback, void *user_data)
+/* LCOV_EXCL_START */
+static void
+_cb_wl_tz_policy_transient_for_done(void *data, struct tizen_policy *tizen_policy, uint32_t child_id)
+{
+}
+/* LCOV_EXCL_STOP */
+
+static void
+_cb_wl_tz_policy_scr_mode_done(void *data,
+                               struct tizen_policy *tizen_policy,
+                               struct wl_surface *surface,
+                               uint32_t mode,
+                               uint32_t state)
 {
-   notification_error_cb_info* _err_info = _notification_error_cb_info_find(window);
 
-   if (_err_info)
-     {
-        _g_notification_error_cb_info_list = eina_list_remove(_g_notification_error_cb_info_list, _err_info);
-        free(_err_info);
-        _err_info = NULL;
-     }
+   Efl_Util_Wl_Surface_Scr_Mode_Info *scr_mode_info;
+   Efl_Util_Callback_Info *cb_info;
 
-   _err_info = (notification_error_cb_info*)calloc(1, sizeof(notification_error_cb_info));
-   if (!_err_info)
+   scr_mode_info = eina_hash_find(_eflutil.wl.policy.hash_scr_mode, &surface);
+   if (scr_mode_info)
      {
-        return EINA_FALSE;
+        scr_mode_info->mode = mode;
+        scr_mode_info->wait_for_done = EINA_FALSE;
+        scr_mode_info->state = state;
      }
-   _err_info->window = window;
-   _err_info->err_cb = callback;
-   _err_info->user_data = user_data;
 
-   _g_notification_error_cb_info_list = eina_list_append(_g_notification_error_cb_info_list, _err_info);
+   if (state != TIZEN_POLICY_ERROR_STATE_PERMISSION_DENIED) return;
 
-   return EINA_TRUE;
+   cb_info = _cb_info_find_by_wlsurf((void *)surface, CBH_SCR_MODE);
+   if (!cb_info) return;
+   if (!cb_info->cb) return;
+
+   cb_info->cb(cb_info->win,
+               EFL_UTIL_ERROR_PERMISSION_DENIED,
+               cb_info->data);
 }
 
-static Eina_Bool
-_efl_util_notification_info_del(Evas_Object *window)
+/* LCOV_EXCL_START */
+static void                    _cb_wl_tz_policy_iconify_state_changed(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, uint32_t iconified, uint32_t force)
 {
-   notification_error_cb_info* _err_info = _notification_error_cb_info_find(window);
-   if (!_err_info)
+}
+
+static void                    _cb_wl_tz_policy_supported_aux_hints(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, struct wl_array *hints, uint32_t num_hints)
+{
+}
+
+static void                    _cb_wl_tz_policy_allowed_aux_hint(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, int id)
+{
+}
+
+static void                    _cb_wl_tz_policy_aux_message(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, const char *key, const char *val, struct wl_array *options)
+{
+}
+/* LCOV_EXCL_STOP */
+
+static void
+_cb_wl_tz_display_policy_brightness_done(void *data,
+                                 struct tizen_display_policy *tizen_display_policy,
+                                 struct wl_surface *surface,
+                                 int32_t brightness,
+                                 uint32_t state)
+{
+   Efl_Util_Wl_Surface_Brightness_Info *brightness_info;
+
+   brightness_info = eina_hash_find(_eflutil.wl.display_policy.hash_brightness, &surface);
+   if (brightness_info)
      {
-        return EINA_FALSE;
+        brightness_info->brightness = brightness;
+        brightness_info->wait_for_done = EINA_FALSE;
+        brightness_info->state = state;
      }
+}
+
+static void
+_cb_window_del(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
+{
+   Efl_Util_Wl_Surface_Lv_Info *lv_info;
+
+   lv_info = data;
+   if (EINA_UNLIKELY(!lv_info))
+     return;
+
+   eina_hash_del(_eflutil.wl.policy.hash_noti_lv, &lv_info->surface, lv_info);
+
+   eina_hash_population(_eflutil.wl.policy.hash_noti_lv);
+
+   if (eina_hash_population(_eflutil.wl.policy.hash_noti_lv) == 0)
+     {
+        _wl_shutdown();
+     }
+}
+
+static Eina_Bool
+_init_tizen_policy_proto(void)
+{
+   int ret = 0;
+
+   if (!_eflutil.wl.policy.proto)
+     {
+        ret = _wl_init();
+        EINA_SAFETY_ON_FALSE_RETURN_VAL(ret, EINA_FALSE);
+
+        ret = 0;
+        while (!_eflutil.wl.policy.proto && ret != -1)
+          ret = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+
+        EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.policy.proto, EINA_FALSE);
+     }
+
+   return EINA_TRUE;
+}
+
+API int
+efl_util_set_notification_window_level(Evas_Object *window,
+                                       efl_util_notification_level_e level)
+{
+   Eina_Bool ret;
+   Elm_Win_Type type;
+   Ecore_Wl_Window *wlwin;
+   struct wl_surface *surface;
+   Efl_Util_Wl_Surface_Lv_Info *lv_info;
+   Ecore_Wl_Window_Type wl_type;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL((level >= EFL_UTIL_NOTIFICATION_LEVEL_NONE) &&
+                                   (level <= EFL_UTIL_NOTIFICATION_LEVEL_TOP),
+                                   EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   if (level == EFL_UTIL_NOTIFICATION_LEVEL_1)
+     {
+        dlog_print(DLOG_WARN, LOG_TAG,
+          "DEPRECATION WARNING: EFL_UTIL_NOTIFICATION_LEVEL_1 is deprecated and will be removed from next release. Use EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT instead.");
+     }
+   else if (level == EFL_UTIL_NOTIFICATION_LEVEL_2)
+     {
+        dlog_print(DLOG_WARN, LOG_TAG,
+          "DEPRECATION WARNING: EFL_UTIL_NOTIFICATION_LEVEL_2 is deprecated and will be removed from next release. Use EFL_UTIL_NOTIFICATION_LEVEL_MEDIUM instead.");
+     }
+   else if (level == EFL_UTIL_NOTIFICATION_LEVEL_3)
+     {
+        dlog_print(DLOG_WARN, LOG_TAG,
+          "DEPRECATION WARNING: EFL_UTIL_NOTIFICATION_LEVEL_3 is deprecated and will be removed from next release. Use EFL_UTIL_NOTIFICATION_LEVEL_TOP instead.");
+     }
+
+   wlwin = elm_win_wl_window_get(window);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(wlwin, EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
+
+   type = elm_win_type_get(window);
+   if (type != ELM_WIN_NOTIFICATION)
+     {
+        wl_type = ecore_wl_window_type_get(wlwin);
+        EINA_SAFETY_ON_FALSE_RETURN_VAL((wl_type == ECORE_WL_WINDOW_TYPE_NOTIFICATION),
+                                        EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
+     }
+
+   ret = _init_tizen_policy_proto();
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(ret, EFL_UTIL_ERROR_NOT_SUPPORTED);
+
+   surface = ecore_wl_window_surface_get(wlwin);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(surface,
+                                  EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
+
+   lv_info = eina_hash_find(_eflutil.wl.policy.hash_noti_lv, &surface);
+   if (!lv_info)
+     {
+        lv_info = calloc(1, sizeof(Efl_Util_Wl_Surface_Lv_Info));
+        EINA_SAFETY_ON_NULL_RETURN_VAL(lv_info, EFL_UTIL_ERROR_OUT_OF_MEMORY);
+
+        lv_info->surface = surface;
+        lv_info->level = (int)level;
+        lv_info->wait_for_done = EINA_TRUE;
+        lv_info->state = TIZEN_POLICY_ERROR_STATE_NONE;
+        eina_hash_add(_eflutil.wl.policy.hash_noti_lv,
+                      &surface,
+                      lv_info);
+
+        evas_object_event_callback_add(window, EVAS_CALLBACK_DEL,
+                                       _cb_window_del, lv_info);
+     }
+   else
+     {
+        lv_info->level = (int)level;
+        lv_info->wait_for_done = EINA_TRUE;
+        lv_info->state = TIZEN_POLICY_ERROR_STATE_NONE;
+     }
+
+
+   tizen_policy_set_notification_level(_eflutil.wl.policy.proto,
+                                       surface, (int)level);
+
+   if (lv_info->wait_for_done)
+     {
+        int count = 0;
+        while (lv_info->wait_for_done && (count < 3))
+          {
+             ecore_wl_flush();
+             wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+             count++;
+          }
+
+        if (lv_info->wait_for_done)
+          {
+             return EFL_UTIL_ERROR_INVALID_PARAMETER;
+          }
+        else
+          {
+             if (lv_info->state == TIZEN_POLICY_ERROR_STATE_PERMISSION_DENIED)
+               {
+                  return EFL_UTIL_ERROR_PERMISSION_DENIED;
+               }
+          }
+     }
+
+   return EFL_UTIL_ERROR_NONE;
+}
+
+API int
+efl_util_get_notification_window_level(Evas_Object *window,
+                                       efl_util_notification_level_e *level)
+{
+   Eina_Bool ret;
+   Elm_Win_Type type;
+   Ecore_Wl_Window *wlwin;
+   struct wl_surface *surface;
+   Efl_Util_Wl_Surface_Lv_Info *lv_info;
+   Ecore_Wl_Window_Type wl_type;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(level, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   wlwin = elm_win_wl_window_get(window);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(wlwin, EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
+
+   type = elm_win_type_get(window);
+   if (type != ELM_WIN_NOTIFICATION)
+     {
+        wl_type = ecore_wl_window_type_get(wlwin);
+        EINA_SAFETY_ON_FALSE_RETURN_VAL((wl_type == ECORE_WL_WINDOW_TYPE_NOTIFICATION),
+                                        EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
+     }
+
+   surface = ecore_wl_window_surface_get(wlwin);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(surface,
+                                  EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
+
+   ret = _init_tizen_policy_proto();
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(ret, EFL_UTIL_ERROR_NOT_SUPPORTED);
+
+   lv_info = eina_hash_find(_eflutil.wl.policy.hash_noti_lv, &surface);
+   if (lv_info)
+     {
+        if (lv_info->wait_for_done)
+          {
+             int count = 0;
+             while ((lv_info->wait_for_done) && (count < 3))
+               {
+                  ecore_wl_flush();
+                  wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+                  count++;
+               }
+
+             if (lv_info->wait_for_done)
+               {
+                  *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT;
+                  return EFL_UTIL_ERROR_INVALID_PARAMETER;
+               }
+          }
+
+        switch (lv_info->level)
+          {
+           case TIZEN_POLICY_LEVEL_1:       *level = EFL_UTIL_NOTIFICATION_LEVEL_1;       break;
+           case TIZEN_POLICY_LEVEL_2:       *level = EFL_UTIL_NOTIFICATION_LEVEL_2;       break;
+           case TIZEN_POLICY_LEVEL_3:       *level = EFL_UTIL_NOTIFICATION_LEVEL_3;       break;
+           case TIZEN_POLICY_LEVEL_NONE:    *level = EFL_UTIL_NOTIFICATION_LEVEL_NONE;    break;
+           case TIZEN_POLICY_LEVEL_DEFAULT: *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT; break;
+           case TIZEN_POLICY_LEVEL_MEDIUM:  *level = EFL_UTIL_NOTIFICATION_LEVEL_MEDIUM;  break;
+           case TIZEN_POLICY_LEVEL_HIGH:    *level = EFL_UTIL_NOTIFICATION_LEVEL_HIGH;    break;
+           case TIZEN_POLICY_LEVEL_TOP:     *level = EFL_UTIL_NOTIFICATION_LEVEL_TOP;     break;
+           default:                         *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT;
+            return EFL_UTIL_ERROR_INVALID_PARAMETER;
+          }
+        return EFL_UTIL_ERROR_NONE;
+     }
+   else
+     *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT;
+
+   return EFL_UTIL_ERROR_NONE;
+}
+
+API int
+efl_util_set_notification_window_level_error_cb(Evas_Object *window,
+                                                efl_util_notification_window_level_error_cb callback,
+                                                void *user_data)
+{
+   dlog_print(DLOG_WARN, LOG_TAG,
+     "DEPRECATION WARNING: efl_util_set_notification_window_level_error_cb() is deprecated and will be removed from next release. Use the return value of efl_util_set_notification_window_level() instead.");
+
+   Eina_Bool ret = EINA_FALSE;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(callback, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   ret = _cb_info_add(window,
+                      (Efl_Util_Cb)callback,
+                      user_data,
+                      CBH_NOTI_LEV);
+   if (!ret) return EFL_UTIL_ERROR_OUT_OF_MEMORY;
+
+   return EFL_UTIL_ERROR_NONE;
+}
+
+API int
+efl_util_unset_notification_window_level_error_cb(Evas_Object *window)
+{
+   dlog_print(DLOG_WARN, LOG_TAG,
+     "DEPRECATION WARNING: efl_util_unset_notification_window_level_error_cb() is deprecated and will be removed from next release. Use the return value of efl_util_set_notification_window_level() instead.");
+
+   Eina_Bool ret = EINA_FALSE;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   ret = _cb_info_del_by_win(window, CBH_NOTI_LEV);
+   if (!ret) return EFL_UTIL_ERROR_INVALID_PARAMETER;
+
+   return EFL_UTIL_ERROR_NONE;
+}
+
+API int
+efl_util_set_window_opaque_state(Evas_Object *window,
+                                 int opaque)
+{
+   Eina_Bool ret;
+   Ecore_Wl_Window *wlwin;
+   struct wl_surface *surface;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(((opaque >= 0) && (opaque <= 1)),
+                                   EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   wlwin = elm_win_wl_window_get(window);
+   if (!wlwin)
+      return EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE;
+
+   surface  = ecore_wl_window_surface_get(wlwin);
+   if (!surface)
+      return EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE;
+
+   ret = _init_tizen_policy_proto();
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(ret, EFL_UTIL_ERROR_NOT_SUPPORTED);
+
+   tizen_policy_set_opaque_state(_eflutil.wl.policy.proto, surface, opaque);
+
+   return EFL_UTIL_ERROR_NONE;
+}
+
+API int
+efl_util_set_window_screen_mode(Evas_Object *window,
+                                efl_util_screen_mode_e mode)
+{
+   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(((mode >= EFL_UTIL_SCREEN_MODE_DEFAULT) &&
+                                    (mode <= EFL_UTIL_SCREEN_MODE_ALWAYS_ON)),
+                                   EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   Ecore_Wl_Window *wlwin;
+   struct wl_surface *surface;
+   Efl_Util_Wl_Surface_Scr_Mode_Info *scr_mode_info;
+   Eina_Bool ret;
+
+   wlwin = elm_win_wl_window_get(window);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(wlwin, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   surface = ecore_wl_window_surface_get(wlwin);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(surface, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   ret = _init_tizen_policy_proto();
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(ret, EFL_UTIL_ERROR_NOT_SUPPORTED);
+
+   scr_mode_info = eina_hash_find(_eflutil.wl.policy.hash_scr_mode, &surface);
+   if (!scr_mode_info)
+     {
+        scr_mode_info = calloc(1, sizeof(Efl_Util_Wl_Surface_Scr_Mode_Info));
+        EINA_SAFETY_ON_NULL_RETURN_VAL(scr_mode_info, EFL_UTIL_ERROR_OUT_OF_MEMORY);
+
+        scr_mode_info->surface = surface;
+        scr_mode_info->mode = (unsigned int)mode;
+        scr_mode_info->wait_for_done = EINA_TRUE;
+        scr_mode_info->state = TIZEN_POLICY_ERROR_STATE_NONE;
+
+        eina_hash_add(_eflutil.wl.policy.hash_scr_mode,
+                      &surface,
+                      scr_mode_info);
+     }
+   else
+     {
+        scr_mode_info->mode = (unsigned int)mode;
+        scr_mode_info->wait_for_done = EINA_TRUE;
+        scr_mode_info->state = TIZEN_POLICY_ERROR_STATE_NONE;
+     }
+
+   tizen_policy_set_window_screen_mode(_eflutil.wl.policy.proto,
+                                       surface, (unsigned int)mode);
+   if (scr_mode_info->wait_for_done)
+     {
+        int count = 0;
+        while (scr_mode_info->wait_for_done && (count < 3))
+          {
+             ecore_wl_flush();
+             wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+             count++;
+          }
+
+        if (scr_mode_info->wait_for_done)
+          {
+             return EFL_UTIL_ERROR_INVALID_PARAMETER;
+          }
+        else
+          {
+             if (scr_mode_info->state == TIZEN_POLICY_ERROR_STATE_PERMISSION_DENIED)
+               {
+                  return EFL_UTIL_ERROR_PERMISSION_DENIED;
+               }
+          }
+     }
+
+   return EFL_UTIL_ERROR_NONE;
+}
+
+API int
+efl_util_get_window_screen_mode(Evas_Object *window,
+                                efl_util_screen_mode_e *mode)
+{
+   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(mode, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   Ecore_Wl_Window *wlwin;
+   struct wl_surface *surface;
+   Efl_Util_Wl_Surface_Scr_Mode_Info *scr_mode_info;
+   Eina_Bool ret;
+
+   wlwin = elm_win_wl_window_get(window);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(wlwin, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   surface = ecore_wl_window_surface_get(wlwin);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(surface, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   ret = _init_tizen_policy_proto();
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(ret, EFL_UTIL_ERROR_NOT_SUPPORTED);
+
+   scr_mode_info = eina_hash_find(_eflutil.wl.policy.hash_scr_mode, &surface);
+   if (scr_mode_info)
+     {
+        if (scr_mode_info->wait_for_done)
+          {
+             while (scr_mode_info->wait_for_done)
+               {
+                  ecore_wl_flush();
+                  wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+               }
+          }
+
+        switch (scr_mode_info->mode)
+          {
+           case TIZEN_POLICY_MODE_DEFAULT:
+              *mode = EFL_UTIL_SCREEN_MODE_DEFAULT;
+              break;
+
+           case TIZEN_POLICY_MODE_ALWAYS_ON:
+              *mode = EFL_UTIL_SCREEN_MODE_ALWAYS_ON;
+              break;
+
+           default:
+              *mode = EFL_UTIL_SCREEN_MODE_DEFAULT;
+              return EFL_UTIL_ERROR_INVALID_PARAMETER;
+          }
+
+        return EFL_UTIL_ERROR_NONE;
+     }
+   else
+     {
+        *mode = EFL_UTIL_SCREEN_MODE_DEFAULT;
+        return EFL_UTIL_ERROR_INVALID_PARAMETER;
+     }
+}
+
+#ifndef TIZEN_WEARABLE
+API int
+efl_util_set_window_screen_mode_error_cb(Evas_Object *window,
+                                         efl_util_window_screen_mode_error_cb callback,
+                                         void *user_data)
+{
+   dlog_print(DLOG_WARN, LOG_TAG,
+     "DEPRECATION WARNING: efl_util_set_window_screen_mode_error_cb() is deprecated and will be removed from next release. Use the return value of efl_util_set_window_screen_mode() instead.");
+
+   Eina_Bool ret = EINA_FALSE;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(callback, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   ret = _cb_info_add(window,
+                      (Efl_Util_Cb)callback,
+                      user_data,
+                      CBH_SCR_MODE);
+   if (!ret) return EFL_UTIL_ERROR_OUT_OF_MEMORY;
+
+   return EFL_UTIL_ERROR_NONE;
+}
+
+API int
+efl_util_unset_window_screen_mode_error_cb(Evas_Object *window)
+{
+   dlog_print(DLOG_WARN, LOG_TAG,
+     "DEPRECATION WARNING: efl_util_unset_window_screen_mode_error_cb() is deprecated and will be removed from next release. Use the return value of efl_util_set_window_screen_mode() instead.");
+
+   Eina_Bool ret = EINA_FALSE;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   ret = _cb_info_del_by_win(window, CBH_SCR_MODE);
+   if (!ret) return EFL_UTIL_ERROR_INVALID_PARAMETER;
+
+   return EFL_UTIL_ERROR_NONE;
+}
+#endif
+
+static Eina_Bool
+_init_tizen_display_policy_proto(void)
+{
+   int ret = 0;
+
+   if (!_eflutil.wl.display_policy.proto)
+     {
+        ret = _wl_init();
+        EINA_SAFETY_ON_FALSE_RETURN_VAL(ret, EINA_FALSE);
+
+        ret = 0;
+        while (!_eflutil.wl.display_policy.proto && ret != -1)
+          ret = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+
+        EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.display_policy.proto, EINA_FALSE);
+     }
+
+   return EINA_TRUE;
+}
+
+API int
+efl_util_set_window_brightness(Evas_Object *window, int brightness)
+{
+   Ecore_Wl_Window *wlwin;
+   struct wl_surface *surface;
+   Efl_Util_Wl_Surface_Brightness_Info *brightness_info;
+   Eina_Bool ret;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(brightness <= 100, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   wlwin = elm_win_wl_window_get(window);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(wlwin, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   surface = ecore_wl_window_surface_get(wlwin);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(surface, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   ret = _init_tizen_display_policy_proto();
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(ret, EFL_UTIL_ERROR_NOT_SUPPORTED);
+
+   brightness_info = eina_hash_find(_eflutil.wl.display_policy.hash_brightness, &surface);
+   if (!brightness_info)
+     {
+        brightness_info = calloc(1, sizeof(Efl_Util_Wl_Surface_Brightness_Info));
+        EINA_SAFETY_ON_NULL_RETURN_VAL(brightness_info, EFL_UTIL_ERROR_OUT_OF_MEMORY);
+
+        brightness_info->surface = surface;
+        brightness_info->brightness = brightness;
+        brightness_info->wait_for_done = EINA_TRUE;
+        brightness_info->state = TIZEN_DISPLAY_POLICY_ERROR_STATE_NONE;
+
+        eina_hash_add(_eflutil.wl.display_policy.hash_brightness,
+                      &surface,
+                      brightness_info);
+     }
+   else
+     {
+        brightness_info->brightness = brightness;
+        brightness_info->wait_for_done = EINA_TRUE;
+        brightness_info->state = TIZEN_DISPLAY_POLICY_ERROR_STATE_NONE;
+     }
+
+   tizen_display_policy_set_window_brightness(_eflutil.wl.display_policy.proto,
+                                              surface, brightness);
+   if (brightness_info->wait_for_done)
+     {
+        int count = 0;
+        while (brightness_info->wait_for_done && (count < 3))
+          {
+             ecore_wl_flush();
+             wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+             count++;
+          }
+
+        if (brightness_info->wait_for_done)
+          {
+             return EFL_UTIL_ERROR_INVALID_PARAMETER;
+          }
+        else
+          {
+             if (brightness_info->state == TIZEN_DISPLAY_POLICY_ERROR_STATE_PERMISSION_DENIED)
+               {
+                  return EFL_UTIL_ERROR_PERMISSION_DENIED;
+               }
+          }
+     }
+
+   return EFL_UTIL_ERROR_NONE;
+}
+
+API int
+efl_util_get_window_brightness(Evas_Object *window, int *brightness)
+{
+   Ecore_Wl_Window *wlwin;
+   struct wl_surface *surface;
+   Efl_Util_Wl_Surface_Brightness_Info *brightness_info;
+   Eina_Bool ret;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(brightness, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   wlwin = elm_win_wl_window_get(window);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(wlwin, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   surface = ecore_wl_window_surface_get(wlwin);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(surface, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   ret = _init_tizen_display_policy_proto();
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(ret, EFL_UTIL_ERROR_NOT_SUPPORTED);
+
+   brightness_info = eina_hash_find(_eflutil.wl.display_policy.hash_brightness, &surface);
+   if (brightness_info)
+     {
+        if (brightness_info->wait_for_done)
+          {
+             while (brightness_info->wait_for_done)
+               {
+                  ecore_wl_flush();
+                  wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+               }
+          }
+         *brightness = brightness_info->brightness;
+     }
+   else
+     *brightness = -1;
+
+   return EFL_UTIL_ERROR_NONE;
+}
+
+
+struct _efl_util_inputgen_h
+{
+   unsigned int init_type;
+};
+
+static void
+_cb_device_add(void *data EINA_UNUSED,
+               struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED,
+               uint32_t serial EINA_UNUSED,
+               const char *identifier EINA_UNUSED,
+               struct tizen_input_device *device,
+               struct wl_seat *seat EINA_UNUSED)
+{
+   Eina_List *l;
+   struct tizen_input_device *ddata;
+
+   EINA_LIST_FOREACH(_eflutil.wl.devmgr.device_list, l, ddata)
+     {
+        if (device == ddata) return;
+     }
+   tizen_input_device_add_listener(device, &_wl_tz_dev_listener, NULL);
+   _eflutil.wl.devmgr.device_list = eina_list_append(_eflutil.wl.devmgr.device_list, device);
+}
+
+/* LCOV_EXCL_START */
+static void
+_cb_device_remove(void *data EINA_UNUSED,
+               struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED,
+               uint32_t serial  EINA_UNUSED,
+               const char *identifier  EINA_UNUSED,
+               struct tizen_input_device *device,
+               struct wl_seat *seat  EINA_UNUSED)
+{
+   Eina_List *l, *ll;
+   struct tizen_input_device *ddata;
+
+   EINA_LIST_FOREACH_SAFE(_eflutil.wl.devmgr.device_list, l, ll, ddata)
+     {
+        if (device == ddata)
+          {
+             _eflutil.wl.devmgr.device_list = eina_list_remove_list(_eflutil.wl.devmgr.device_list, l);
+             tizen_input_device_release(device);
+          }
+     }
+}
+/* LCOV_EXCL_STOP */
+
+static void
+_cb_error(void *data EINA_UNUSED,
+          struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED,
+          uint32_t errorcode)
+{
+   _eflutil.wl.devmgr.request_notified = errorcode;
+}
+
+/* LCOV_EXCL_START */
+static void
+_cb_block_expired(void *data EINA_UNUSED,
+                  struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED)
+{
+   ;
+}
+/* LCOV_EXCL_STOP */
+
+/* LCOV_EXCL_START */
+static void
+_cb_device_info(void *data EINA_UNUSED,
+                struct tizen_input_device *tizen_input_device EINA_UNUSED,
+                const char *name EINA_UNUSED, uint32_t clas EINA_UNUSED,
+                uint32_t subclas EINA_UNUSED, struct wl_array *axes EINA_UNUSED)
+{
+   ;
+}
+
+static void
+_cb_event_device(void *data EINA_UNUSED,
+                 struct tizen_input_device *tizen_input_device EINA_UNUSED,
+                 unsigned int serial EINA_UNUSED,
+                 const char *name EINA_UNUSED, uint32_t time EINA_UNUSED)
+{
+   ;
+}
+
+static void
+_cb_axis(void *data EINA_UNUSED,
+         struct tizen_input_device *tizen_input_device EINA_UNUSED,
+         uint32_t axis_type EINA_UNUSED, wl_fixed_t value EINA_UNUSED)
+{
+   ;
+}
+/* LCOV_EXCL_STOP */
+
+static efl_util_error_e
+_efl_util_input_convert_input_generator_error(int ret)
+{
+   switch (ret)
+     {
+        case TIZEN_INPUT_DEVICE_MANAGER_ERROR_NONE:
+           return EFL_UTIL_ERROR_NONE;
+        case TIZEN_INPUT_DEVICE_MANAGER_ERROR_NO_PERMISSION:
+           return EFL_UTIL_ERROR_PERMISSION_DENIED;
+        case TIZEN_INPUT_DEVICE_MANAGER_ERROR_NO_SYSTEM_RESOURCES:
+           return EFL_UTIL_ERROR_OUT_OF_MEMORY;
+        case TIZEN_INPUT_DEVICE_MANAGER_ERROR_INVALID_PARAMETER:
+           return EFL_UTIL_ERROR_INVALID_PARAMETER;
+        default :
+           return EFL_UTIL_ERROR_NONE;
+     }
+}
+
+API efl_util_inputgen_h
+efl_util_input_initialize_generator(unsigned int dev_type)
+{
+   int ret = EFL_UTIL_ERROR_NONE;
+   efl_util_inputgen_h inputgen_h = NULL;
+
+   if (!dev_type ||
+        dev_type & ~(EFL_UTIL_INPUT_DEVTYPE_TOUCHSCREEN
+                    | EFL_UTIL_INPUT_DEVTYPE_KEYBOARD
+                    | EFL_UTIL_INPUT_DEVTYPE_POINTER))
+     {
+        set_last_result(EFL_UTIL_ERROR_NO_SUCH_DEVICE);
+        goto out;
+     }
+
+   inputgen_h = (efl_util_inputgen_h)calloc(1, sizeof(struct _efl_util_inputgen_h));
+   if (!inputgen_h)
+     {
+        set_last_result(EFL_UTIL_ERROR_OUT_OF_MEMORY);
+        goto out;
+     }
+
+   inputgen_h->init_type |= dev_type;
+
+   ret = _wl_init();
+   if (ret == (int)EINA_FALSE)
+     {
+        set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
+        goto out;
+     }
+
+   while (!_eflutil.wl.devmgr.devicemgr)
+     wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+
+   tizen_input_device_manager_init_generator(_eflutil.wl.devmgr.devicemgr);
+
+   while (_eflutil.wl.devmgr.request_notified == -1)
+     wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+
+   ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
+   _eflutil.wl.devmgr.request_notified = -1;
+
+   set_last_result(ret);
+   if (ret != TIZEN_INPUT_DEVICE_MANAGER_ERROR_NONE)
+     goto out;
+
+   return inputgen_h;
+
+out:
+   if (inputgen_h)
+     {
+        free(inputgen_h);
+        inputgen_h = NULL;
+     }
+   return NULL;
+}
+
+API int
+efl_util_input_deinitialize_generator(efl_util_inputgen_h inputgen_h)
+{
+   int ret = EFL_UTIL_ERROR_NONE;
+   EINA_SAFETY_ON_NULL_RETURN_VAL(inputgen_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   free(inputgen_h);
+   inputgen_h = NULL;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.devmgr.devicemgr, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   tizen_input_device_manager_deinit_generator(_eflutil.wl.devmgr.devicemgr);
+
+   while (_eflutil.wl.devmgr.request_notified == -1)
+     wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+
+   ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
+   _eflutil.wl.devmgr.request_notified = -1;
+
+   _wl_shutdown();
+
+   return ret;
+}
+
+API int
+efl_util_input_generate_key(efl_util_inputgen_h inputgen_h, const char *key_name, int pressed)
+{
+   int ret = EFL_UTIL_ERROR_NONE;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(inputgen_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(key_name, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(pressed == 0 || pressed == 1, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(inputgen_h->init_type & EFL_UTIL_INPUT_DEVTYPE_KEYBOARD, EFL_UTIL_ERROR_NO_SUCH_DEVICE);
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.devmgr.devicemgr, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   tizen_input_device_manager_generate_key(_eflutil.wl.devmgr.devicemgr, key_name, pressed);
+
+   while (_eflutil.wl.devmgr.request_notified == -1)
+     wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+
+   ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
+   _eflutil.wl.devmgr.request_notified = -1;
+
+   return ret;
+}
+
+API int
+efl_util_input_generate_touch(efl_util_inputgen_h inputgen_h, int idx,
+                              efl_util_input_touch_type_e touch_type, int x, int y)
+{
+   int ret;
+   enum tizen_input_device_manager_pointer_event_type type;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(inputgen_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(idx >= 0, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL((x > 0 && y > 0), EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(inputgen_h->init_type & EFL_UTIL_INPUT_DEVTYPE_TOUCHSCREEN, EFL_UTIL_ERROR_NO_SUCH_DEVICE);
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.devmgr.devicemgr, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   switch(touch_type)
+     {
+        case EFL_UTIL_INPUT_TOUCH_BEGIN:
+           type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_BEGIN;
+           break;
+        case EFL_UTIL_INPUT_TOUCH_UPDATE:
+           type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_UPDATE;
+           break;
+        case EFL_UTIL_INPUT_TOUCH_END:
+           type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_END;
+           break;
+        default:
+           return EFL_UTIL_ERROR_INVALID_PARAMETER;
+     }
+
+   tizen_input_device_manager_generate_touch(_eflutil.wl.devmgr.devicemgr, type, x, y, idx);
+
+   while (_eflutil.wl.devmgr.request_notified == -1)
+     wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+
+   ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
+   _eflutil.wl.devmgr.request_notified = -1;
+
+   return ret;
+}
+
+API int
+efl_util_input_generate_pointer(efl_util_inputgen_h inputgen_h, int buttons, efl_util_input_pointer_type_e pointer_type, int x, int y)
+{
+   int ret;
+   enum tizen_input_device_manager_pointer_event_type type;
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(inputgen_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(buttons > 0, EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL((x >= 0 && y >= 0), EFL_UTIL_ERROR_INVALID_PARAMETER);
+   EINA_SAFETY_ON_FALSE_RETURN_VAL(inputgen_h->init_type & EFL_UTIL_INPUT_DEVTYPE_POINTER, EFL_UTIL_ERROR_NO_SUCH_DEVICE);
+
+   EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.devmgr.devicemgr, EFL_UTIL_ERROR_INVALID_PARAMETER);
+
+   switch(pointer_type)
+     {
+        case EFL_UTIL_INPUT_POINTER_BUTTON_DOWN:
+           type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_BEGIN;
+           break;
+        case EFL_UTIL_INPUT_POINTER_MOVE:
+           type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_UPDATE;
+           break;
+        case EFL_UTIL_INPUT_POINTER_BUTTON_UP:
+           type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_END;
+           break;
+        default:
+           return EFL_UTIL_ERROR_INVALID_PARAMETER;
+     }
+
+   tizen_input_device_manager_generate_pointer(_eflutil.wl.devmgr.devicemgr, type, x, y, buttons);
+
+   while (_eflutil.wl.devmgr.request_notified == -1)
+     wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+
+   ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
+   _eflutil.wl.devmgr.request_notified = -1;
+
+   return ret;
+}
+
+
+struct _efl_util_screenshot_h
+{
+   int width;
+   int height;
+
+   Eina_Bool shot_done;
+
+   /* tbm bufmgr */
+   tbm_bufmgr bufmgr;
+
+   Eina_Bool auto_rotation;
+};
+
+/* scrrenshot handle */
+static efl_util_screenshot_h g_screenshot;
+static Eina_Bool shot_mutex_init;
+static pthread_mutex_t shot_lock;
+
+static Eina_Bool
+_screenshot_mutex_init(void)
+{
+   if (shot_mutex_init)
+     return EINA_TRUE;
+
+   if (pthread_mutex_init(&shot_lock, NULL))
+     {
+        fprintf(stderr, "[screenshot] fail: mutex init"); /*LCOV_EXCL_LINE*/
+        return EINA_FALSE; /*LCOV_EXCL_LINE*/
+     }
+
+   shot_mutex_init = EINA_TRUE;
+
+   return EINA_TRUE;
+}
+
+static Eina_Bool
+_screenshot_mutex_destory(void)
+{
+   if (!shot_mutex_init)
+     return EINA_TRUE;
+
+   if (pthread_mutex_destroy(&shot_lock))
+     {
+        fprintf(stderr, "[screenshot] fail: mutex destory"); /*LCOV_EXCL_LINE*/
+        return EINA_FALSE; /*LCOV_EXCL_LINE*/
+     }
+
+   shot_mutex_init = EINA_FALSE;
 
-   _g_notification_error_cb_info_list = eina_list_remove(_g_notification_error_cb_info_list, _err_info);
-   free(_err_info);
-
    return EINA_TRUE;
 }
+
+void
+_screenshot_mutex_lock(void)
+{
+   if (!_screenshot_mutex_init())
+     return;
+
+   pthread_mutex_lock(&shot_lock);
+}
+
+void
+_screenshot_mutex_unlock(void)
+{
+   pthread_mutex_unlock(&shot_lock);
+}
+
+API efl_util_screenshot_h
+efl_util_screenshot_initialize(int width, int height)
+{
+   efl_util_screenshot_h screenshot = NULL;
+   struct wl_display *display_wrapper = NULL;
+   struct wl_registry *reg = NULL;
+   int ret = 0;
+
+   EINA_SAFETY_ON_FALSE_GOTO(width > 0, fail_param);
+   EINA_SAFETY_ON_FALSE_GOTO(height > 0, fail_param);
+
+   _screenshot_mutex_lock();
+
+   if (!_eflutil.wl.shot.screenshooter)
+     {
+        ret = _wl_init();
+        if (ret == (int)EINA_FALSE)
+          {
+             set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
+             _screenshot_mutex_unlock();
+             return NULL;
+          }
+        wl_display_roundtrip_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
+
+        display_wrapper = wl_proxy_create_wrapper(_eflutil.wl.dpy);
+        EINA_SAFETY_ON_NULL_GOTO(display_wrapper, fail_init);
+
+        _eflutil.wl.shot.queue = wl_display_create_queue(_eflutil.wl.dpy);
+        EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.shot.queue, fail_init);
+
+        reg = wl_display_get_registry(display_wrapper);
+        EINA_SAFETY_ON_NULL_GOTO(reg, fail_init);
+
+        wl_proxy_set_queue((struct wl_proxy*)reg, _eflutil.wl.shot.queue);
+
+        wl_registry_add_listener(reg, &_wl_reg_screenshooter_listener, NULL);
+
+        ret = wl_display_roundtrip_queue(_eflutil.wl.dpy, _eflutil.wl.shot.queue);
+        EINA_SAFETY_ON_TRUE_GOTO(ret == -1, fail_init);
+        EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.shot.screenshooter, fail_init);
+        EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.shot.tz_screenshooter, fail_init);
+
+        _eflutil.wl.shot.tbm_client = wayland_tbm_client_init(_eflutil.wl.dpy);
+        EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.shot.tbm_client, fail_init);
+     }
+
+   if (_eflutil.wl.shot.noti == 0)
+     {
+        fprintf(stderr, "[screenshot] fail: privilege error\n"); /* LCOV_EXCL_LINE */
+        goto fail_init;
+     }
+
+   if (g_screenshot)
+     {
+        if (g_screenshot->width != width || g_screenshot->height != height)
+          {
+             g_screenshot->width = width;
+             g_screenshot->height = height;
+          }
+
+        _screenshot_mutex_unlock();
+
+        return g_screenshot;
+     }
+
+   screenshot = calloc(1, sizeof(struct _efl_util_screenshot_h));
+   EINA_SAFETY_ON_NULL_GOTO(screenshot, fail_memory);
+
+   screenshot->width = width;
+   screenshot->height = height;
+   screenshot->auto_rotation = EINA_TRUE;
+
+   screenshot->bufmgr = wayland_tbm_client_get_bufmgr(_eflutil.wl.shot.tbm_client);
+   EINA_SAFETY_ON_NULL_GOTO(screenshot->bufmgr, fail_init);
+
+   g_screenshot = screenshot;
+   set_last_result(EFL_UTIL_ERROR_NONE);
+
+   screenshooter_set_user_data(_eflutil.wl.shot.screenshooter, &screenshot->shot_done);
+
+   _screenshot_mutex_unlock();
+
+   return g_screenshot;
+
+fail_param:
+   set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
+   return NULL;
+fail_memory:
+/* LCOV_EXCL_START */
+   if (display_wrapper)
+     wl_proxy_wrapper_destroy(display_wrapper);
+   set_last_result(EFL_UTIL_ERROR_OUT_OF_MEMORY);
+   return NULL;
+/* LCOV_EXCL_STOP */
+fail_init:
+   if (screenshot)
+     efl_util_screenshot_deinitialize(screenshot);
+   _screenshot_mutex_unlock();
+   if (display_wrapper)
+     wl_proxy_wrapper_destroy(display_wrapper);
+   set_last_result(EFL_UTIL_ERROR_SCREENSHOT_INIT_FAIL);
+   return NULL;
+}
+
+API int
+efl_util_screenshot_deinitialize(efl_util_screenshot_h screenshot)
+{
+   _screenshot_mutex_lock();
+
+   if (!screenshot)
+     {
+        _screenshot_mutex_unlock();
+        _screenshot_mutex_destory();
+        return EFL_UTIL_ERROR_INVALID_PARAMETER;
+     }
+
+   free(screenshot);
+   g_screenshot = NULL;
+
+   if (_eflutil.wl.shot.queue)
+     {
+        wl_event_queue_destroy(_eflutil.wl.shot.queue);
+        _eflutil.wl.shot.queue = NULL;
+     }
+
+   if (_eflutil.wl.shot.screenshooter)
+     {
+        screenshooter_destroy(_eflutil.wl.shot.screenshooter);
+        _eflutil.wl.shot.screenshooter = NULL;
+     }
+   if (_eflutil.wl.shot.tz_screenshooter)
+     {
+        tizen_screenshooter_destroy(_eflutil.wl.shot.tz_screenshooter);
+        _eflutil.wl.shot.tz_screenshooter = NULL;
+     }
+
+   _screenshot_mutex_unlock();
+   _screenshot_mutex_destory();
+
+   _wl_shutdown();
+
+   return EFL_UTIL_ERROR_NONE;
+}
+
+
+API tbm_surface_h
+efl_util_screenshot_take_tbm_surface(efl_util_screenshot_h screenshot)
+{
+   tbm_surface_h t_surface = NULL;
+   struct wl_buffer *buffer = NULL;
+   Efl_Util_Wl_Output_Info *output;
+   int ret = 0;
+
+   _screenshot_mutex_lock();
+
+   if (!screenshot || (screenshot != g_screenshot))
+     {
+        set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
+        _screenshot_mutex_unlock();
+        return NULL;
+     }
+
+   output = eina_list_nth(_eflutil.wl.shot.output_list, 0);
+   if (!output)
+     {
+        fprintf(stderr, "[screenshot] fail: no output for screenshot\n"); /* LCOV_EXCL_LINE */
+        goto fail;
+     }
+
+   t_surface = tbm_surface_create(screenshot->width, screenshot->height, TBM_FORMAT_XRGB8888);
+   if (!t_surface)
+     {
+        fprintf(stderr, "[screenshot] fail: tbm_surface_create\n"); /* LCOV_EXCL_LINE */
+        goto fail;
+     }
+
+   buffer = wayland_tbm_client_create_buffer(_eflutil.wl.shot.tbm_client, t_surface);
+   if (!buffer)
+     {
+        fprintf(stderr, "[screenshot] fail: create wl_buffer for screenshot\n"); /* LCOV_EXCL_LINE */
+        goto fail;
+     }
+
+   screenshooter_shoot(_eflutil.wl.shot.screenshooter, output->output, buffer);
+
+   screenshot->shot_done = EINA_FALSE;
+   while (!screenshot->shot_done && ret != -1)
+     ret = wl_display_roundtrip_queue(_eflutil.wl.dpy, _eflutil.wl.shot.queue);
+
+   if (ret == -1)
+     {
+        fprintf(stderr, "[screenshot] fail: screenshooter_shoot\n"); /* LCOV_EXCL_LINE */
+        goto fail;
+     }
+
+   wl_buffer_destroy(buffer);
+
+   /* reset shot_done for next screenshot */
+   screenshot->shot_done = EINA_FALSE;
+
+   set_last_result(EFL_UTIL_ERROR_NONE);
+
+   _screenshot_mutex_unlock();
+
+   return t_surface;
+
+fail:
+   if (t_surface)
+     tbm_surface_destroy(t_surface);
+   if (buffer)
+     wl_buffer_destroy(buffer);
+
+   set_last_result(EFL_UTIL_ERROR_SCREENSHOT_EXECUTION_FAIL);
+
+   _screenshot_mutex_unlock();
+
+   return NULL;
+}
+
+API int
+efl_util_screenshot_set_auto_rotation(efl_util_screenshot_h screenshot, int set)
+{
+   if (!screenshot || (screenshot != g_screenshot))
+     return EFL_UTIL_ERROR_INVALID_PARAMETER;
+
+   if (!(set == 0 || set == 1))
+     return EFL_UTIL_ERROR_INVALID_PARAMETER;
+
+   if (set)
+     g_screenshot->auto_rotation = EINA_TRUE;
+   else
+     g_screenshot->auto_rotation = EINA_FALSE;
+
+   tizen_screenshooter_set_oneshot_auto_rotation(_eflutil.wl.shot.tz_screenshooter, g_screenshot->auto_rotation);
+
+   return EFL_UTIL_ERROR_NONE;
+}
+
+API int
+efl_util_screenshot_get_auto_rotation(efl_util_screenshot_h screenshot, int *set)
+{
+   if (!screenshot || (screenshot != g_screenshot) || !set)
+     return EFL_UTIL_ERROR_INVALID_PARAMETER;
+
+   *set = g_screenshot->auto_rotation;
+
+   return EFL_UTIL_ERROR_NONE;
+}