hwc_window: added tdm_hwc_window_free_buffer_queue
[platform/core/uifw/libtdm.git] / src / tdm_hwc_window.c
index 31e62ad..44e87bc 100644 (file)
@@ -214,6 +214,44 @@ tdm_hwc_window_get_buffer_queue(tdm_hwc_window *hwc_window, tdm_error *error)
        return queue;
 }
 
+EXTERN void
+tdm_hwc_window_free_buffer_queue(tdm_hwc_window *hwc_window, tbm_surface_queue_h queue)
+{
+       tdm_private_module *private_module;
+       tdm_func_hwc_window *func_hwc_window = NULL;
+       tdm_private_display *private_display;
+       tdm_private_output *private_output;
+       tdm_private_hwc *private_hwc;
+       tdm_private_hwc_window *private_hwc_window;
+
+       if (!hwc_window)
+               return;
+
+       private_hwc_window = (tdm_private_hwc_window *)hwc_window;
+       private_hwc = private_hwc_window->private_hwc;
+       private_output = private_hwc->private_output;
+       private_display = private_output->private_display;
+
+       TDM_RETURN_IF_FAIL(queue != NULL);
+
+       _pthread_mutex_lock(&private_display->lock);
+
+       private_module = private_output->private_module;
+       func_hwc_window = &private_module->func_hwc_window;
+
+       if (!func_hwc_window->hwc_window_free_buffer_queue) {
+               _pthread_mutex_unlock(&private_display->lock);
+               TDM_WRN("not implemented!!");
+               return;
+       }
+
+       func_hwc_window->hwc_window_free_buffer_queue(private_hwc_window->hwc_window_backend, queue);
+
+       _pthread_mutex_unlock(&private_display->lock);
+
+       return;
+}
+
 EXTERN tdm_error
 tdm_hwc_window_set_composition_type(tdm_hwc_window *hwc_window,
                                                                        tdm_hwc_window_composition composition_type)