Do not allocate backend data 39/315039/2
authorChangyeon Lee <cyeon.lee@samsung.com>
Wed, 24 Jul 2024 03:21:32 +0000 (12:21 +0900)
committerChangyeon Lee <cyeon.lee@samsung.com>
Wed, 24 Jul 2024 06:26:31 +0000 (15:26 +0900)
backend data is allocated in hal-api

Change-Id: I9246ebdb0e074e1a91c80a47656dcc8d817a3459

src/tdm_backend_nexell.c

index 284bc5ceb3eb34c2112fef8f4c05b90db22af2ca..e0ac71221ad0192373d56dc2941e001d7da6c6fd 100644 (file)
@@ -330,27 +330,6 @@ hal_backend_tdm_nexell_exit(void *data)
        display_data = (tdm_nexell_display *)backend_data->display;
        TDM_BACKEND_RETURN_VAL_IF_FAIL(display_data != NULL, -1);
 
-       if (backend_data->pp_funcs) {
-               free(backend_data->pp_funcs);
-               backend_data->pp_funcs = NULL;
-       }
-       if (backend_data->hwc_window_funcs) {
-               free(backend_data->hwc_window_funcs);
-               backend_data->hwc_window_funcs = NULL;
-       }
-       if (backend_data->hwc_funcs) {
-               free(backend_data->hwc_funcs);
-               backend_data->hwc_funcs = NULL;
-       }
-       if (backend_data->output_funcs) {
-               free(backend_data->output_funcs);
-               backend_data->output_funcs = NULL;
-       }
-       if (backend_data->display_funcs) {
-               free(backend_data->display_funcs);
-               backend_data->display_funcs = NULL;
-       }
-
        _tdm_nexell_display_deinitialize(display_data);
 
 #ifdef HAVE_UDEV
@@ -361,8 +340,8 @@ hal_backend_tdm_nexell_exit(void *data)
        if (display_data->drm_fd >= 0)
                close(display_data->drm_fd);
 
-       free(display_data);
-       free(backend_data);
+       free(backend_data->display);
+       backend_data->display = NULL;
 
        return HAL_TDM_ERROR_NONE;
 }
@@ -371,13 +350,6 @@ static int
 hal_backend_tdm_nexell_init(void **data)
 {
        hal_tdm_backend_data *backend_data = NULL;
-       hal_tdm_display_funcs *display_funcs = NULL;
-       hal_tdm_output_funcs *output_funcs = NULL;
-       hal_tdm_hwc_funcs *hwc_funcs = NULL;
-       hal_tdm_hwc_window_funcs *hwc_window_funcs = NULL;
-#ifdef ENABLE_PP
-       hal_tdm_pp_funcs *pp_funcs = NULL;
-#endif
        tdm_nexell_display *display_data = NULL;
        hal_tdm_error ret;
        int drm_fd;
@@ -386,14 +358,16 @@ hal_backend_tdm_nexell_init(void **data)
        hal_tdm_event_source *udev_event_source;
 #endif
 
-       /* allocate a hal_tdm_backend_data */
-       backend_data = calloc(1, sizeof(struct _hal_tdm_backend_data));
+       if (!data) {
+               TDM_BACKEND_ERR("data is NULL");
+               return -1;
+       }
+
+       backend_data = *(hal_tdm_backend_data **)data;
        if (!backend_data) {
-               TDM_BACKEND_ERR("fail to alloc backend_data!\n");
-               *data = NULL;
+               TDM_BACKEND_ERR("backend_data is NULL");
                return -1;
        }
-       *data = backend_data;
 
        /* allocate a hal_tdm_display */
        display_data = calloc(1, sizeof(struct _tdm_nexell_display));
@@ -464,104 +438,64 @@ hal_backend_tdm_nexell_init(void **data)
        backend_data->num_event_sources++;
 #endif
 
-       /* alloc and register display_funcs */
-       display_funcs = calloc(1, sizeof(struct _hal_tdm_display_funcs));
-       if (!display_funcs) {
-               TDM_BACKEND_ERR("fail to alloc display_funcs!\n");
-               goto failed;
-       }
-       backend_data->display_funcs = display_funcs;
-
-       display_funcs->display_get_capability = nexell_display_get_capability;
-       display_funcs->display_get_pp_capability = nexell_display_get_pp_capability;
-       display_funcs->display_get_outputs = nexell_display_get_outputs;
-       display_funcs->display_get_fd = nexell_display_get_fd;
-       display_funcs->display_handle_events = nexell_display_handle_events;
-       display_funcs->display_create_pp = nexell_display_create_pp;
-
-       /* alloc and register output_funcs */
-       output_funcs = calloc(1, sizeof(struct _hal_tdm_output_funcs));
-       if (!output_funcs) {
-               TDM_BACKEND_ERR("fail to alloc output_funcs!\n");
-               goto failed;
-       }
-       backend_data->output_funcs = output_funcs;
-
-       output_funcs->output_get_capability = nexell_output_get_capability;
-       output_funcs->output_set_property = nexell_output_set_property;
-       output_funcs->output_get_property = nexell_output_get_property;
-       output_funcs->output_wait_vblank = nexell_output_wait_vblank;
-       output_funcs->output_set_vblank_handler = nexell_output_set_vblank_handler;
-       output_funcs->output_set_dpms = nexell_output_set_dpms;
-       output_funcs->output_get_dpms = nexell_output_get_dpms;
-       output_funcs->output_set_mode = nexell_output_set_mode;
-       output_funcs->output_get_mode = nexell_output_get_mode;
-       output_funcs->output_set_mirror = NULL;
-       output_funcs->output_unset_mirror = NULL;
+       backend_data->display_funcs->display_get_capability = nexell_display_get_capability;
+       backend_data->display_funcs->display_get_pp_capability = nexell_display_get_pp_capability;
+       backend_data->display_funcs->display_get_outputs = nexell_display_get_outputs;
+       backend_data->display_funcs->display_get_fd = nexell_display_get_fd;
+       backend_data->display_funcs->display_handle_events = nexell_display_handle_events;
+       backend_data->display_funcs->display_create_pp = nexell_display_create_pp;
+
+       backend_data->output_funcs->output_get_capability = nexell_output_get_capability;
+       backend_data->output_funcs->output_set_property = nexell_output_set_property;
+       backend_data->output_funcs->output_get_property = nexell_output_get_property;
+       backend_data->output_funcs->output_wait_vblank = nexell_output_wait_vblank;
+       backend_data->output_funcs->output_set_vblank_handler = nexell_output_set_vblank_handler;
+       backend_data->output_funcs->output_set_dpms = nexell_output_set_dpms;
+       backend_data->output_funcs->output_get_dpms = nexell_output_get_dpms;
+       backend_data->output_funcs->output_set_mode = nexell_output_set_mode;
+       backend_data->output_funcs->output_get_mode = nexell_output_get_mode;
+       backend_data->output_funcs->output_set_mirror = NULL;
+       backend_data->output_funcs->output_unset_mirror = NULL;
 #ifdef HAVE_UDEV
-       output_funcs->output_set_status_handler = nexell_output_set_status_handler;
+       backend_data->output_funcs->output_set_status_handler = nexell_output_set_status_handler;
 #endif
-       output_funcs->output_get_hwc = nexell_output_get_hwc;
-
-       /* alloc and register hwc_funcs */
-       hwc_funcs = calloc(1, sizeof(struct _hal_tdm_hwc_funcs));
-       if (!hwc_funcs) {
-               TDM_BACKEND_ERR("fail to alloc hwc_funcs!\n");
-               goto failed;
-       }
-       backend_data->hwc_funcs = hwc_funcs;
-
-       hwc_funcs->hwc_create_window = nexell_hwc_create_window;
-       hwc_funcs->hwc_get_video_supported_formats = nexell_hwc_get_video_supported_formats;
-       hwc_funcs->hwc_get_video_available_properties = NULL;
-       hwc_funcs->hwc_get_capabilities = nexell_hwc_get_capabilities;
-       hwc_funcs->hwc_get_available_properties = nexell_hwc_get_available_properties;
-       hwc_funcs->hwc_get_client_target_buffer_queue = nexell_hwc_get_client_target_buffer_queue;
-       hwc_funcs->hwc_set_client_target_buffer = nexell_hwc_set_client_target_buffer;
-       hwc_funcs->hwc_set_client_target_acquire_fence = NULL;
-       hwc_funcs->hwc_validate = nexell_hwc_validate;
-       hwc_funcs->hwc_get_changed_composition_types = nexell_hwc_get_changed_composition_types;
-       hwc_funcs->hwc_accept_validation = nexell_hwc_accept_validation;
-       hwc_funcs->hwc_commit = nexell_hwc_commit;
-       hwc_funcs->hwc_set_commit_handler = nexell_hwc_set_commit_handler;
-       hwc_funcs->hwc_get_commit_fence = NULL;
-       hwc_funcs->hwc_get_release_fences = NULL;
-
-       /* alloc and register hwc_window_funcs */
-       hwc_window_funcs = calloc(1, sizeof(struct _hal_tdm_hwc_window_funcs));
-       if (!hwc_window_funcs) {
-               TDM_BACKEND_ERR("fail to alloc hwc_window_funcs!\n");
-               goto failed;
-       }
-       backend_data->hwc_window_funcs = hwc_window_funcs;
-
-       hwc_window_funcs->hwc_window_destroy = nexell_hwc_window_destroy;
-       hwc_window_funcs->hwc_window_acquire_buffer_queue = nexell_hwc_window_acquire_buffer_queue;
-       hwc_window_funcs->hwc_window_release_buffer_queue = nexell_hwc_window_release_buffer_queue;
-       hwc_window_funcs->hwc_window_set_composition_type = nexell_hwc_window_set_composition_type;
-       hwc_window_funcs->hwc_window_set_buffer_damage = nexell_hwc_window_set_buffer_damage;
-       hwc_window_funcs->hwc_window_set_info = nexell_hwc_window_set_info;
-       hwc_window_funcs->hwc_window_set_buffer = nexell_hwc_window_set_buffer;
-       hwc_window_funcs->hwc_window_set_property = nexell_hwc_window_set_property;
-       hwc_window_funcs->hwc_window_get_property = nexell_hwc_window_get_property;
-       hwc_window_funcs->hwc_window_get_constraints = nexell_hwc_window_get_constraints;
-       hwc_window_funcs->hwc_window_set_name = nexell_hwc_window_set_name;
-       hwc_window_funcs->hwc_window_set_cursor_image = nexell_hwc_window_set_cursor_image;
+       backend_data->output_funcs->output_get_hwc = nexell_output_get_hwc;
+
+       backend_data->hwc_funcs->hwc_create_window = nexell_hwc_create_window;
+       backend_data->hwc_funcs->hwc_get_video_supported_formats = nexell_hwc_get_video_supported_formats;
+       backend_data->hwc_funcs->hwc_get_video_available_properties = NULL;
+       backend_data->hwc_funcs->hwc_get_capabilities = nexell_hwc_get_capabilities;
+       backend_data->hwc_funcs->hwc_get_available_properties = nexell_hwc_get_available_properties;
+       backend_data->hwc_funcs->hwc_get_client_target_buffer_queue = nexell_hwc_get_client_target_buffer_queue;
+       backend_data->hwc_funcs->hwc_set_client_target_buffer = nexell_hwc_set_client_target_buffer;
+       backend_data->hwc_funcs->hwc_set_client_target_acquire_fence = NULL;
+       backend_data->hwc_funcs->hwc_validate = nexell_hwc_validate;
+       backend_data->hwc_funcs->hwc_get_changed_composition_types = nexell_hwc_get_changed_composition_types;
+       backend_data->hwc_funcs->hwc_accept_validation = nexell_hwc_accept_validation;
+       backend_data->hwc_funcs->hwc_commit = nexell_hwc_commit;
+       backend_data->hwc_funcs->hwc_set_commit_handler = nexell_hwc_set_commit_handler;
+       backend_data->hwc_funcs->hwc_get_commit_fence = NULL;
+       backend_data->hwc_funcs->hwc_get_release_fences = NULL;
+
+       backend_data->hwc_window_funcs->hwc_window_destroy = nexell_hwc_window_destroy;
+       backend_data->hwc_window_funcs->hwc_window_acquire_buffer_queue = nexell_hwc_window_acquire_buffer_queue;
+       backend_data->hwc_window_funcs->hwc_window_release_buffer_queue = nexell_hwc_window_release_buffer_queue;
+       backend_data->hwc_window_funcs->hwc_window_set_composition_type = nexell_hwc_window_set_composition_type;
+       backend_data->hwc_window_funcs->hwc_window_set_buffer_damage = nexell_hwc_window_set_buffer_damage;
+       backend_data->hwc_window_funcs->hwc_window_set_info = nexell_hwc_window_set_info;
+       backend_data->hwc_window_funcs->hwc_window_set_buffer = nexell_hwc_window_set_buffer;
+       backend_data->hwc_window_funcs->hwc_window_set_property = nexell_hwc_window_set_property;
+       backend_data->hwc_window_funcs->hwc_window_get_property = nexell_hwc_window_get_property;
+       backend_data->hwc_window_funcs->hwc_window_get_constraints = nexell_hwc_window_get_constraints;
+       backend_data->hwc_window_funcs->hwc_window_set_name = nexell_hwc_window_set_name;
+       backend_data->hwc_window_funcs->hwc_window_set_cursor_image = nexell_hwc_window_set_cursor_image;
 
 #ifdef ENABLE_PP
-       /* alloc and register pp_funcs */
-       pp_funcs = calloc(1, sizeof(struct _hal_tdm_pp_funcs));
-       if (!pp_funcs) {
-               TDM_BACKEND_ERR("fail to alloc pp_funcs!\n");
-               goto failed;
-       }
-       backend_data->pp_funcs = pp_funcs;
-
-       pp_funcs->pp_destroy = nexell_pp_destroy;
-       pp_funcs->pp_set_info = nexell_pp_set_info;
-       pp_funcs->pp_attach = nexell_pp_attach;
-       pp_funcs->pp_commit = nexell_pp_commit;
-       pp_funcs->pp_set_done_handler = nexell_pp_set_done_handler;
+       backend_data->pp_funcs->pp_destroy = nexell_pp_destroy;
+       backend_data->pp_funcs->pp_set_info = nexell_pp_set_info;
+       backend_data->pp_funcs->pp_attach = nexell_pp_attach;
+       backend_data->pp_funcs->pp_commit = nexell_pp_commit;
+       backend_data->pp_funcs->pp_set_done_handler = nexell_pp_set_done_handler;
 #endif
 
        TDM_BACKEND_INFO("init success!");