use vblank instead of the output commit handler in case of tdm_layer_commit
[platform/core/uifw/libtdm.git] / src / tdm_thread.c
index 03ce03a..4659740 100644 (file)
@@ -285,7 +285,7 @@ tdm_thread_handle_cb(tdm_private_loop *private_loop)
                        tdm_output *output_backend =
                                tdm_display_find_output_stamp(private_loop->dpy, output_commit->output_stamp);
                        if (!output_backend) {
-                               TDM_WRN("no output(%ld)", output_commit->output_stamp);
+                               TDM_WRN("no output(%f)", output_commit->output_stamp);
                                break;
                        }
                        tdm_output_cb_commit(output_backend, output_commit->sequence,
@@ -298,7 +298,7 @@ tdm_thread_handle_cb(tdm_private_loop *private_loop)
                        tdm_output *output_backend =
                                tdm_display_find_output_stamp(private_loop->dpy, output_vblank->output_stamp);
                        if (!output_backend) {
-                               TDM_WRN("no output(%ld)", output_vblank->output_stamp);
+                               TDM_WRN("no output(%f)", output_vblank->output_stamp);
                                break;
                        }
                        tdm_output_cb_vblank(output_backend, output_vblank->sequence,
@@ -311,19 +311,30 @@ tdm_thread_handle_cb(tdm_private_loop *private_loop)
                        tdm_output *output_backend =
                                tdm_display_find_output_stamp(private_loop->dpy, output_status->output_stamp);
                        if (!output_backend) {
-                               TDM_WRN("no output(%ld)", output_status->output_stamp);
+                               TDM_WRN("no output(%f)", output_status->output_stamp);
                                break;
                        }
                        tdm_output_cb_status(output_backend, output_status->status,
                                                                 output_status->user_data);
                        break;
                }
+               case TDM_THREAD_CB_OUTPUT_DPMS: {
+                       tdm_thread_cb_output_dpms *output_dpms = (tdm_thread_cb_output_dpms*)base;
+                       tdm_output *output_backend =
+                               tdm_display_find_output_stamp(private_loop->dpy, output_dpms->output_stamp);
+                       if (!output_backend) {
+                               TDM_WRN("no output(%f)", output_dpms->output_stamp);
+                               break;
+                       }
+                       tdm_output_cb_dpms(output_backend, output_dpms->dpms, output_dpms->user_data);
+                       break;
+               }
                case TDM_THREAD_CB_PP_DONE: {
                        tdm_thread_cb_pp_done *pp_done = (tdm_thread_cb_pp_done*)base;
                        tdm_pp *pp_backend =
                                tdm_pp_find_stamp(private_loop->dpy, pp_done->pp_stamp);
                        if (!pp_backend) {
-                               TDM_WRN("no pp(%ld)", pp_done->pp_stamp);
+                               TDM_WRN("no pp(%f)", pp_done->pp_stamp);
                                break;
                        }
                        tdm_pp_cb_done(pp_backend, pp_done->src, pp_done->dst, pp_done->user_data);
@@ -334,12 +345,17 @@ tdm_thread_handle_cb(tdm_private_loop *private_loop)
                        tdm_capture *capture_backend =
                                tdm_capture_find_stamp(private_loop->dpy, capture_done->capture_stamp);
                        if (!capture_backend) {
-                               TDM_WRN("no capture(%ld)", capture_done->capture_stamp);
+                               TDM_WRN("no capture(%f)", capture_done->capture_stamp);
                                break;
                        }
                        tdm_capture_cb_done(capture_backend, capture_done->buffer, capture_done->user_data);
                        break;
                }
+               case TDM_THREAD_CB_VBLANK_SW: {
+                       tdm_thread_cb_vblank_sw *vblank_sw = (tdm_thread_cb_vblank_sw*)base;
+                       tdm_vblank_cb_vblank_SW(NULL, vblank_sw->vblank_stamp);
+                       break;
+               }
                default:
                        break;
                }