X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2Ftdm_server.c;h=30bb47515d0f2714e52cc41b61ad35308341464b;hb=d83a8cb9702ec0084ffcaaefe561a7c20f030d15;hp=840e575b703a631c26a48af4371acf84644407b6;hpb=278ae74126ba11c906c1780f303b3245148de555;p=platform%2Fcore%2Fuifw%2Flibtdm.git diff --git a/src/tdm_server.c b/src/tdm_server.c index 840e575..30bb475 100644 --- a/src/tdm_server.c +++ b/src/tdm_server.c @@ -9,7 +9,7 @@ * Taeheon Kim , * YoungJun Cho , * SooChan Lim , - * Boram Park + * Boram Park * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the @@ -239,8 +239,10 @@ static void _tdm_server_vblank_cb_set_name(struct wl_client *client, struct wl_resource *resource, const char *name) { tdm_server_vblank_info *vblank_info = wl_resource_get_user_data(resource); + tdm_error ret; - tdm_vblank_set_name(vblank_info->vblank, name); + ret = tdm_vblank_set_name(vblank_info->vblank, name); + TDM_RETURN_IF_FAIL(ret == TDM_ERROR_NONE); } /* LCOV_EXCL_STOP */ @@ -249,8 +251,10 @@ static void _tdm_server_vblank_cb_set_fps(struct wl_client *client, struct wl_resource *resource, uint32_t fps) { tdm_server_vblank_info *vblank_info = wl_resource_get_user_data(resource); + tdm_error ret; - tdm_vblank_set_fps(vblank_info->vblank, fps); + ret = tdm_vblank_set_fps(vblank_info->vblank, fps); + TDM_RETURN_IF_FAIL(ret == TDM_ERROR_NONE); } /* LCOV_EXCL_STOP */ @@ -259,8 +263,10 @@ static void _tdm_server_vblank_cb_set_offset(struct wl_client *client, struct wl_resource *resource, int32_t offset) { tdm_server_vblank_info *vblank_info = wl_resource_get_user_data(resource); + tdm_error ret; - tdm_vblank_set_offset(vblank_info->vblank, offset); + ret = tdm_vblank_set_offset(vblank_info->vblank, offset); + TDM_RETURN_IF_FAIL(ret == TDM_ERROR_NONE); } /* LCOV_EXCL_STOP */ @@ -268,8 +274,10 @@ static void _tdm_server_vblank_cb_set_enable_fake(struct wl_client *client, struct wl_resource *resource, uint32_t enable_fake) { tdm_server_vblank_info *vblank_info = wl_resource_get_user_data(resource); + tdm_error ret; - tdm_vblank_set_enable_fake(vblank_info->vblank, enable_fake); + ret = tdm_vblank_set_enable_fake(vblank_info->vblank, enable_fake); + TDM_RETURN_IF_FAIL(ret == TDM_ERROR_NONE); } static void @@ -634,14 +642,21 @@ _tdm_server_cb_create_output(struct wl_client *client, struct wl_resource *resou /* LCOV_EXCL_STOP */ } + ret = tdm_output_add_change_handler(output, _tdm_server_cb_output_change, output_info); + if (ret != TDM_ERROR_NONE) { + wl_resource_post_no_memory(resource); + wl_resource_destroy(output_resource); + free(output_info); + TDM_ERR("tdm_output_add_change_handler failed"); + return; + } + LIST_ADDTAIL(&output_info->link, &private_server->output_list); output_info->private_server = private_server; output_info->resource = output_resource; output_info->output = output; LIST_INITHEAD(&output_info->vblank_list); - tdm_output_add_change_handler(output, _tdm_server_cb_output_change, output_info); - wl_resource_set_implementation(output_resource, &tdm_output_implementation, output_info, destroy_output_callback);