Fix missing initalize
[platform/core/uifw/libtbm.git] / src / tbm_module.c
index 6c9fd87..16beb7f 100644 (file)
@@ -460,7 +460,7 @@ tbm_module_unload(tbm_module *module)
 }
 
 int
-tbm_module_bufmgr_get_capabilities(tbm_module *module, tbm_error_e *error)
+tbm_module_get_capabilities(tbm_module *module, tbm_error_e *error)
 {
        int capabilities = 0;
        tbm_backend_bufmgr_func *bufmgr_func = NULL;
@@ -496,7 +496,7 @@ tbm_module_bufmgr_get_capabilities(tbm_module *module, tbm_error_e *error)
 }
 
 tbm_error_e
-tbm_module_bufmgr_bind_native_display(tbm_module *module, void *native_display)
+tbm_module_bind_native_display(tbm_module *module, void *native_display)
 {
        tbm_error_e error = TBM_ERROR_NONE;
        tbm_backend_bufmgr_func *bufmgr_func = NULL;
@@ -509,7 +509,7 @@ tbm_module_bufmgr_bind_native_display(tbm_module *module, void *native_display)
        case TBM_MODULE_TYPE_HAL_TBM:
                if (hal_tbm_backend_has_drm_device(module->hal_backend, &ret)) {
                        int fd = tbm_drm_helper_get_fd(); // this must be the auth drm_fd.(master drm_fd);
-                       if (fd < -1) {
+                       if (fd < 0) {
                                TBM_ERR("error: module(%p) native_display(%p)\n", module, native_display);
                                return TBM_ERROR_INVALID_OPERATION;
                        }
@@ -559,7 +559,7 @@ tbm_module_bufmgr_bind_native_display(tbm_module *module, void *native_display)
 }
 
 tbm_error_e
-tbm_module_bufmgr_get_supported_formats(tbm_module *module, uint32_t **formats, uint32_t *num)
+tbm_module_get_supported_formats(tbm_module *module, uint32_t **formats, uint32_t *num)
 {
        tbm_error_e error = TBM_ERROR_NONE;
        tbm_backend_bufmgr_func *bufmgr_func = NULL;
@@ -602,7 +602,7 @@ tbm_module_bufmgr_get_supported_formats(tbm_module *module, uint32_t **formats,
 }
 
 tbm_error_e
-tbm_module_bufmgr_get_plane_data(tbm_module *module, int format, int plane_idx, uint32_t w, uint32_t h,
+tbm_module_get_plane_data(tbm_module *module, int format, int plane_idx, uint32_t w, uint32_t h,
                                        uint32_t *size, uint32_t *offset, uint32_t *pitch, int *bo_idx)
 {
        tbm_error_e error = TBM_ERROR_NONE;
@@ -644,81 +644,934 @@ tbm_module_bufmgr_get_plane_data(tbm_module *module, int format, int plane_idx,
        return error;
 }
 
-tbm_backend_bo_data *
-tbm_module_bufmgr_bo_alloc(tbm_module *module, tbm_bo bo, int size, int flags, tbm_error_e *error)
+int
+tbm_module_support_surface_data(tbm_module *module)
+{
+       tbm_error_e error = TBM_ERROR_NONE;
+       tbm_surface_data *surface_data = NULL;
+
+       TBM_RETURN_VAL_IF_FAIL(module, 0);
+
+       // check once support_surface_data or not.
+       if (module->check_surface_data) {
+               // return the value which already set.
+               return module->support_surface_data;
+       }
+
+       // check this only once
+       module->check_surface_data = 1;
+
+       if (module->type != TBM_MODULE_TYPE_HAL_TBM)
+               goto done;
+
+       // Assume that the hal-tbm supports the hal surface apis if tbm_module_alloc_surface_data succeed.
+       surface_data = tbm_module_alloc_surface_data(module, 10, 10, TBM_FORMAT_ARGB8888, TBM_BO_DEFAULT, &error);
+       if (!surface_data)
+               goto done;
+       free(surface_data);
+
+       module->support_surface_data = 1;
+
+done:
+       return module->support_surface_data;
+}
+
+
+tbm_surface_data *
+tbm_module_alloc_surface_data(tbm_module *module, int width, int height, int format, int flags, tbm_error_e *error)
+{
+       tbm_surface_data *surface_data = NULL;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(module, NULL, *error, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(module->type == TBM_MODULE_TYPE_HAL_TBM, NULL, *error, TBM_ERROR_INVALID_OPERATION);
+
+       surface_data = calloc(1, sizeof(struct _tbm_surface_data));
+       if (!surface_data) {
+               TBM_ERR("memory allocation failed.");
+               *error = TBM_ERROR_OUT_OF_MEMORY;
+               return NULL;
+       }
+
+       surface_data->hal_surface = hal_tbm_bufmgr_alloc_surface(module->hal_bufmgr,
+                                                                                          (uint32_t)width,
+                                                                                          (uint32_t)height,
+                                                                                          (hal_tbm_format)format,
+                                                                                          (hal_tbm_bo_memory_type)flags,
+                                                                                          NULL,
+                                                                                          0,
+                                                                                          (hal_tbm_error *)error);
+       if (!surface_data->hal_surface) {
+               if (*error != TBM_ERROR_NOT_SUPPORTED) // do not print the error message when it is not supported.
+                       TBM_ERR("hal_tbm_bufmgr_alloc_surface failed.");
+               free(surface_data);
+               return NULL;
+       }
+
+       surface_data->module = module;
+
+       return surface_data;
+}
+
+tbm_surface_data *
+tbm_module_import_surface_data(tbm_module *module, int width, int height, int format, tbm_surface_buffer_data *buffer_data, tbm_error_e *error)
 {
-       tbm_backend_bo_data *bo_data = NULL;
+       tbm_surface_data *surface_data = NULL;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(module, NULL, *error, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(module->type == TBM_MODULE_TYPE_HAL_TBM, NULL, *error, TBM_ERROR_INVALID_OPERATION);
+
+       surface_data = calloc(1, sizeof(struct _tbm_surface_data));
+       if (!surface_data) {
+               TBM_ERR("memory allocation failed.");
+               *error = TBM_ERROR_OUT_OF_MEMORY;
+               return NULL;
+       }
+
+       surface_data->hal_surface = hal_tbm_bufmgr_import_surface(module->hal_bufmgr,
+                                                                                       (uint32_t)width,
+                                                                                       (uint32_t)height,
+                                                                                       (hal_tbm_format)format,
+                                                                                       (hal_tbm_surface_buffer_data *)buffer_data,
+                                                                                       (hal_tbm_error *)error);
+       if (!surface_data->hal_surface) {
+               TBM_ERR("hal_tbm_bufmgr_import_surface failed. width:%d height:%d format:%d error:%s",
+                               width, height, format, tbm_error_str(*error));
+               free(surface_data);
+               return NULL;
+       }
+
+       surface_data->module = module;
+
+       return surface_data;
+}
+
+tbm_bo_data *
+tbm_module_alloc_bo_data(tbm_module *module, tbm_bo bo, int size, int flags, tbm_error_e *error)
+{
+       tbm_bo_data *bo_data = NULL;
        tbm_backend_bufmgr_func *bufmgr_func = NULL;
        tbm_bufmgr_backend backend = NULL;
 
        TBM_RETURN_VAL_SET_ERR_IF_FAIL(module, NULL, *error, TBM_ERROR_INVALID_PARAMETER);
 
+       bo_data = calloc(1, sizeof(struct _tbm_bo_data));
+       TBM_GOTO_VAL_SET_ERR_IF_FAIL(bo_data, failed, *error, TBM_ERROR_OUT_OF_MEMORY);
+
        switch (module->type) {
        case TBM_MODULE_TYPE_HAL_TBM:
-               bo_data = (tbm_backend_bo_data *)hal_tbm_bufmgr_alloc_bo(module->hal_bufmgr, size, flags, (hal_tbm_error *)error);
+               bo_data->hal_bo = hal_tbm_bufmgr_alloc_bo(module->hal_bufmgr, size, flags, (hal_tbm_error *)error);
+               TBM_GOTO_VAL_IF_FAIL(bo_data->hal_bo, failed);
                break;
 /* LCOV_EXCL_START */
        case TBM_MODULE_TYPE_TBM_BACKEND:
                bufmgr_func = module->bufmgr_func;
-               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bufmgr_func, NULL, *error, TBM_ERROR_INVALID_OPERATION);
-               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bufmgr_func->bufmgr_alloc_bo, NULL, *error, TBM_ERROR_NOT_SUPPORTED);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(bufmgr_func, failed, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(bufmgr_func->bufmgr_alloc_bo, failed, *error, TBM_ERROR_NOT_SUPPORTED);
 
-               bo_data = module->bufmgr_func->bufmgr_alloc_bo(module->bufmgr_data, (unsigned int)size, flags, error);
+               bo_data->backend_bo_data = bufmgr_func->bufmgr_alloc_bo(module->bufmgr_data, (unsigned int)size, flags, error);
+               TBM_GOTO_VAL_IF_FAIL(bo_data->backend_bo_data, failed);
                break;
        case TBM_MODULE_TYPE_BUFMGR_BACKEND:
                TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+
                backend = module->backend;
-               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend, NULL, *error, TBM_ERROR_INVALID_OPERATION);
-               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend->bo_alloc, NULL, *error, TBM_ERROR_NOT_SUPPORTED);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(backend, failed, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(backend->bo_alloc, failed, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               bo_data->priv = (void *)backend->bo_alloc(bo, size, flags);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(bo_data->priv, failed, *error, TBM_ERROR_INVALID_OPERATION);
 
-               bo_data = (void *)module->backend->bo_alloc(bo, size, flags);
                *error = TBM_ERROR_NONE;
                break;
        default:
                TBM_ERR("Wrong module type:%d", module->type);
                *error = TBM_ERROR_INVALID_OPERATION;
+               goto failed;
                break;
 /* LCOV_EXCL_STOP */
        }
 
+       bo_data->module = module;
+
        return bo_data;
+
+/* LCOV_EXCL_START */
+failed:
+       if (bo_data)
+               free(bo_data);
+
+       return NULL;
+/* LCOV_EXCL_STOP */
 }
 
-tbm_backend_bo_data *
-tbm_module_bufmgr_bo_alloc_with_format(tbm_module *module, int format, int bo_idx, int width,
+tbm_bo_data *
+tbm_module_alloc_bo_data_with_format(tbm_module *module, int format, int bo_idx, int width,
                                                int height, int bpp, tbm_bo_memory_type flags, tbm_error_e *error)
 {
-       tbm_backend_bo_data *bo_data = NULL;
+       tbm_bo_data *bo_data = NULL;
        tbm_backend_bufmgr_func *bufmgr_func = NULL;
 
        TBM_RETURN_VAL_SET_ERR_IF_FAIL(module, NULL, *error, TBM_ERROR_INVALID_PARAMETER);
 
+       bo_data = calloc(1, sizeof(struct _tbm_bo_data));
+       TBM_GOTO_VAL_SET_ERR_IF_FAIL(bo_data, failed, *error, TBM_ERROR_OUT_OF_MEMORY);
+
        switch (module->type) {
        case TBM_MODULE_TYPE_HAL_TBM:
-               bo_data = (tbm_backend_bo_data *)hal_tbm_bufmgr_alloc_bo_with_format(module->hal_bufmgr,
+               bo_data->hal_bo = hal_tbm_bufmgr_alloc_bo_with_format(module->hal_bufmgr,
                                                                                        format, bo_idx, width, height, bpp,
                                                                                        (hal_tbm_bo_memory_type)flags, (hal_tbm_error *)error);
+               if (!bo_data->hal_bo)
+                       goto failed;
                break;
 /* LCOV_EXCL_START */
        case TBM_MODULE_TYPE_TBM_BACKEND:
                bufmgr_func = module->bufmgr_func;
-               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bufmgr_func, NULL, *error, TBM_ERROR_INVALID_OPERATION);
-               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bufmgr_func->bufmgr_alloc_bo_with_format, NULL, *error, TBM_ERROR_NOT_SUPPORTED);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(bufmgr_func, failed, *error, TBM_ERROR_INVALID_OPERATION);
+               if (!bufmgr_func->bufmgr_alloc_bo_with_format) {
+                       *error = TBM_ERROR_NOT_SUPPORTED;
+                       goto failed;
+               }
 
-               bo_data = bufmgr_func->bufmgr_alloc_bo_with_format(module->bufmgr_data, format, bo_idx, width, height, flags, error);
+               bo_data->backend_bo_data = bufmgr_func->bufmgr_alloc_bo_with_format(module->bufmgr_data, format, bo_idx, width, height, flags, error);
+               if (!bo_data->backend_bo_data)
+                       goto failed;
                break;
        case TBM_MODULE_TYPE_BUFMGR_BACKEND:
                TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
-               TBM_ERR("error: not supported tbm_bo_alloc_with_format.");
+               TBM_ERR("error: not supported tbm_module_alloc_bo_data_with_format.");
 
                *error = TBM_ERROR_NOT_SUPPORTED;
+               goto failed;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               *error = TBM_ERROR_INVALID_OPERATION;
+               goto failed;
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       bo_data->module = module;
+
+       return bo_data;
+
+/* LCOV_EXCL_START */
+failed:
+       if (bo_data)
+               free(bo_data);
+
+       return NULL;
+/* LCOV_EXCL_STOP */
+}
+
+tbm_bo_data *
+tbm_module_import_bo_data_with_fd(tbm_module *module, tbm_bo bo, tbm_fd fd, tbm_error_e *error)
+{
+       tbm_bo_data *bo_data = NULL;
+       tbm_backend_bufmgr_func *bufmgr_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(module, NULL, *error, TBM_ERROR_INVALID_PARAMETER);
+
+       bo_data = calloc(1, sizeof(struct _tbm_bo_data));
+       TBM_GOTO_VAL_SET_ERR_IF_FAIL(bo_data, failed, *error, TBM_ERROR_OUT_OF_MEMORY);
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               bo_data->hal_bo = hal_tbm_bufmgr_import_fd(module->hal_bufmgr, (hal_tbm_fd)fd, (hal_tbm_error *)error);
+               TBM_GOTO_VAL_IF_FAIL(bo_data->hal_bo, failed);
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bufmgr_func = module->bufmgr_func;
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(bufmgr_func, failed, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(bufmgr_func->bufmgr_import_fd, failed, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               bo_data->backend_bo_data = bufmgr_func->bufmgr_import_fd(module->bufmgr_data, fd, error);
+               TBM_GOTO_VAL_IF_FAIL(bo_data->backend_bo_data, failed);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(backend, failed, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(backend->bo_import_fd, failed, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               bo_data->priv = (void *)backend->bo_import_fd(bo, fd);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(bo_data->priv, failed, *error, TBM_ERROR_INVALID_OPERATION);
+
+               *error = TBM_ERROR_NONE;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               *error = TBM_ERROR_INVALID_OPERATION;
+               goto failed;
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       bo_data->module = module;
+
+       return bo_data;
+
+/* LCOV_EXCL_START */
+failed:
+       if (bo_data)
+               free(bo_data);
+
+       return NULL;
+/* LCOV_EXCL_STOP */
+}
+
+tbm_bo_data *
+tbm_module_import_bo_data_with_key(tbm_module *module, tbm_bo bo, tbm_key key, tbm_error_e *error)
+{
+       tbm_bo_data *bo_data = NULL;
+       tbm_backend_bufmgr_func *bufmgr_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(module, NULL, *error, TBM_ERROR_INVALID_PARAMETER);
+
+       bo_data = calloc(1, sizeof(struct _tbm_bo_data));
+       TBM_GOTO_VAL_SET_ERR_IF_FAIL(bo_data, failed, *error, TBM_ERROR_OUT_OF_MEMORY);
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               bo_data->hal_bo = hal_tbm_bufmgr_import_key(module->hal_bufmgr, key, (hal_tbm_error *)error);
+               TBM_GOTO_VAL_IF_FAIL(bo_data->hal_bo, failed);
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bufmgr_func = module->bufmgr_func;
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(bufmgr_func, failed, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(bufmgr_func->bufmgr_import_key, failed, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               bo_data->backend_bo_data = bufmgr_func->bufmgr_import_key(module->bufmgr_data, key, error);
+               TBM_GOTO_VAL_IF_FAIL(bo_data->backend_bo_data, failed);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(backend, failed, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(backend->bo_import, failed, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               bo_data->priv = (void *)backend->bo_import(bo, key);
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(bo_data->priv, failed, *error, TBM_ERROR_INVALID_OPERATION);
+
+               *error = TBM_ERROR_NONE;
                break;
        default:
                TBM_ERR("Wrong module type:%d", module->type);
                *error = TBM_ERROR_INVALID_OPERATION;
+               goto failed;
                break;
 /* LCOV_EXCL_STOP */
        }
 
+       bo_data->module = module;
+
        return bo_data;
+
+/* LCOV_EXCL_START */
+failed:
+       if (bo_data)
+               free(bo_data);
+
+       return NULL;
+/* LCOV_EXCL_STOP */
+}
+
+int
+tbm_module_compare_bo_data(tbm_module *module, tbm_bo_data *bo_data1, tbm_bo_data *bo_data2)
+{
+       TBM_RETURN_VAL_IF_FAIL(module, 0);
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               return (bo_data1->hal_bo == bo_data2->hal_bo);
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               return (bo_data1->backend_bo_data == bo_data2->backend_bo_data);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               return (bo_data1->priv == bo_data2->priv);
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       return 0;
+}
+
+void
+tbm_surface_data_free(tbm_surface_data *surface_data)
+{
+       TBM_RETURN_IF_FAIL(surface_data);
+       TBM_RETURN_IF_FAIL(surface_data->module);
+       TBM_RETURN_IF_FAIL(surface_data->module->type == TBM_MODULE_TYPE_HAL_TBM);
+
+       surface_data->module = NULL;
+
+       hal_tbm_surface_free(surface_data->hal_surface);
+       surface_data->hal_surface = NULL;
+
+       free(surface_data);
+}
+
+tbm_error_e
+tbm_surface_data_get_plane_data(tbm_surface_data *surface_data, int plane_idx, uint32_t *size, uint32_t *offset, uint32_t *pitch, int *bo_idx)
+{
+       tbm_error_e error;
+
+       TBM_RETURN_VAL_IF_FAIL(surface_data, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_IF_FAIL(surface_data->hal_surface, TBM_ERROR_NOT_SUPPORTED);
+
+       error = (tbm_error_e)hal_tbm_surface_get_plane_data(surface_data->hal_surface, plane_idx, size, offset, pitch, bo_idx);
+       TBM_RETURN_VAL_IF_FAIL(error == TBM_ERROR_NONE, error);
+
+       return TBM_ERROR_NONE;
+}
+
+tbm_bo_data **
+tbm_surface_data_get_bo_data_array(tbm_surface_data *surface_data, int *num_bos, int *memory_types, tbm_error_e *error)
+{
+       tbm_bo_data **bo_data_array = NULL;
+       hal_tbm_bo **hal_bos = NULL;
+       int i;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(surface_data, NULL, *error, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(surface_data->hal_surface, NULL, *error, TBM_ERROR_NOT_SUPPORTED);
+
+       hal_bos = hal_tbm_surface_get_bos(surface_data->hal_surface, num_bos, (hal_tbm_error *)error);
+       TBM_RETURN_VAL_IF_FAIL(hal_bos, NULL);
+
+       bo_data_array = calloc(*num_bos, sizeof(tbm_bo_data *));
+       TBM_RETURN_VAL_IF_FAIL(bo_data_array, NULL);
+
+       for (i = 0; i < *num_bos; i++) {
+               bo_data_array[i] = calloc(*num_bos, sizeof(struct _tbm_bo_data));
+               TBM_GOTO_VAL_SET_ERR_IF_FAIL(bo_data_array[i], failed, *error, TBM_ERROR_OUT_OF_MEMORY);
+       }
+
+       for (i = 0; i < *num_bos; i++) {
+               bo_data_array[i]->hal_bo = hal_bos[i];
+               bo_data_array[i]->module = surface_data->module;
+       }
+
+       // get memory_types(bo flags)
+       *memory_types = tbm_bo_data_get_memory_types(bo_data_array[0], error);
+       TBM_GOTO_VAL_IF_FAIL(*error == TBM_ERROR_NONE, failed);
+
+       return bo_data_array;
+
+/* LCOV_EXCL_START */
+failed:
+       for (i = 0; i < *num_bos; i++) {
+               if (bo_data_array[i])
+                       free(bo_data_array[i]);
+       }
+       free(bo_data_array);
+
+       return NULL;
+/* LCOV_EXCL_STOP */
+}
+
+tbm_surface_buffer_data *
+tbm_surface_data_export(tbm_surface_data *surface_data, tbm_error_e *error)
+{
+       tbm_surface_buffer_data *buffer_data;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(surface_data, NULL, *error, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(surface_data->hal_surface, NULL, *error, TBM_ERROR_NOT_SUPPORTED);
+
+       buffer_data = (tbm_surface_buffer_data *)hal_tbm_surface_export((hal_tbm_surface *)surface_data->hal_surface,
+                                                                                                                                       (hal_tbm_error *)error);
+       TBM_RETURN_VAL_IF_FAIL(buffer_data, NULL);
+
+       return buffer_data;
+}
+
+void
+tbm_bo_data_free(tbm_bo_data *bo_data, int get_from_surface_data)
+{
+       tbm_module *module = NULL;
+       tbm_backend_bo_func *bo_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+
+       TBM_RETURN_IF_FAIL(bo_data);
+       TBM_RETURN_IF_FAIL(bo_data->module);
+
+       module = bo_data->module;
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               // call hal_tbm_bo_free when bo is created by tbm_bo_alloc api.
+               if (!get_from_surface_data) {
+                       hal_tbm_bo_free(bo_data->hal_bo);
+                       bo_data->hal_bo = NULL;
+               }
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bo_func = module->bo_func;
+               TBM_RETURN_IF_FAIL(bo_func);
+               TBM_RETURN_IF_FAIL(bo_func->bo_free);
+
+               bo_func->bo_free(bo_data->backend_bo_data);
+               bo_data->backend_bo_data = NULL;
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_RETURN_IF_FAIL(backend);
+               TBM_RETURN_IF_FAIL(backend->bo_free);
+
+               backend->bo_free(bo_data->priv);
+               bo_data->priv = NULL;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       bo_data->module = NULL;
+       free(bo_data);
+}
+
+int
+tbm_bo_data_get_size(tbm_bo_data *bo_data, tbm_error_e *error)
+{
+       tbm_module *module = NULL;
+       tbm_backend_bo_func *bo_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+       int size = 0;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data, 0, *error, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data->module, 0, *error, TBM_ERROR_INVALID_PARAMETER);
+
+       module = bo_data->module;
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               size = hal_tbm_bo_get_size(bo_data->hal_bo, (hal_tbm_error *)error);
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bo_func = module->bo_func;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func, 0, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func->bo_get_size, 0, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               size = bo_func->bo_get_size(bo_data->backend_bo_data, error);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend, 0, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend->bo_size, 0, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               size = backend->bo_size(bo_data->priv);
+               if (size == 0)
+                       *error = TBM_ERROR_INVALID_OPERATION;
+               else
+                       *error = TBM_ERROR_NONE;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               *error = TBM_ERROR_INVALID_OPERATION;
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       return size;
+}
+
+int
+tbm_bo_data_get_memory_types(tbm_bo_data *bo_data, tbm_error_e *error)
+{
+       tbm_module *module = NULL;
+       tbm_backend_bo_func *bo_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+       int memory_types = TBM_BO_DEFAULT;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data, 0, *error, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data->module, 0, *error, TBM_ERROR_INVALID_PARAMETER);
+
+       module = bo_data->module;
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               memory_types = (tbm_bo_memory_type)hal_tbm_bo_get_memory_types(bo_data->hal_bo, (hal_tbm_error *)error);
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bo_func = module->bo_func;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func, 0, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func->bo_get_memory_types, 0, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               memory_types = bo_func->bo_get_memory_types(bo_data->backend_bo_data, error);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend, 0, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend->bo_get_flags, 0, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               memory_types = backend->bo_get_flags(bo_data->priv);
+               *error = TBM_ERROR_NONE;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               *error = TBM_ERROR_INVALID_OPERATION;
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       return memory_types;
+}
+
+tbm_bo_handle
+tbm_bo_data_get_handle(tbm_bo_data *bo_data, int device, tbm_error_e *error)
+{
+       tbm_module *module = NULL;
+       tbm_backend_bo_func *bo_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+       tbm_bo_handle bo_handle = (tbm_bo_handle)NULL;
+       hal_tbm_bo_handle hbo_handle;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data, (tbm_bo_handle)NULL, *error, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data->module, (tbm_bo_handle)NULL, *error, TBM_ERROR_INVALID_PARAMETER);
+
+       module = bo_data->module;
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               hbo_handle = hal_tbm_bo_get_handle(bo_data->hal_bo, device, (hal_tbm_error *)error);
+               if (hbo_handle.ptr != NULL)
+                       memcpy(&bo_handle.ptr, &hbo_handle.ptr, sizeof(tbm_bo_handle));
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bo_func = module->bo_func;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func, (tbm_bo_handle)NULL, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func->bo_get_handle, (tbm_bo_handle)NULL, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               bo_handle = bo_func->bo_get_handle(bo_data->backend_bo_data, device, error);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend, (tbm_bo_handle)NULL, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend->bo_get_handle, (tbm_bo_handle)NULL, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               bo_handle = backend->bo_get_handle(bo_data->priv, device);
+               if (!bo_handle.ptr)
+                       *error = TBM_ERROR_INVALID_OPERATION;
+               else
+                       *error = TBM_ERROR_NONE;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               bo_handle.ptr = NULL;
+               *error = TBM_ERROR_INVALID_OPERATION;
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       return bo_handle;
+}
+
+tbm_bo_handle
+tbm_bo_data_map(tbm_bo_data *bo_data, int device, int opt, tbm_error_e *error)
+{
+       tbm_module *module = NULL;
+       tbm_backend_bo_func *bo_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+       tbm_bo_handle bo_handle = (tbm_bo_handle)NULL;
+       hal_tbm_bo_handle hbo_handle = (hal_tbm_bo_handle)NULL;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data, (tbm_bo_handle)NULL, *error, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data->module, (tbm_bo_handle)NULL, *error, TBM_ERROR_INVALID_PARAMETER);
+
+       module = bo_data->module;
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               hbo_handle = hal_tbm_bo_map(bo_data->hal_bo, device, opt, (hal_tbm_error *)error);
+               if (hbo_handle.ptr != NULL)
+                       memcpy(&bo_handle.ptr, &hbo_handle.ptr, sizeof(tbm_bo_handle));
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bo_func = module->bo_func;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func, (tbm_bo_handle)NULL, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func->bo_map, (tbm_bo_handle)NULL, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               bo_handle = bo_func->bo_map(bo_data->backend_bo_data, device, opt, error);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend, (tbm_bo_handle)NULL, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend->bo_map, (tbm_bo_handle)NULL, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               bo_handle = backend->bo_map(bo_data->priv, device, opt);
+               if (!bo_handle.ptr)
+                       *error = TBM_ERROR_INVALID_OPERATION;
+               else
+                       *error = TBM_ERROR_NONE;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               bo_handle.ptr = NULL;
+               *error = TBM_ERROR_INVALID_OPERATION;
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       return bo_handle;
+}
+
+tbm_error_e
+tbm_bo_data_unmap(tbm_bo_data *bo_data)
+{
+       tbm_module *module = NULL;
+       tbm_backend_bo_func *bo_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+       tbm_error_e error;
+       int ret = 0;
+
+       TBM_RETURN_VAL_IF_FAIL(bo_data, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_IF_FAIL(bo_data->module, TBM_ERROR_INVALID_PARAMETER);
+
+       module = bo_data->module;
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               error = (hal_tbm_error)hal_tbm_bo_unmap(bo_data->hal_bo);
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bo_func = module->bo_func;
+               TBM_RETURN_VAL_IF_FAIL(bo_func, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_IF_FAIL(bo_func->bo_unmap, TBM_ERROR_NOT_SUPPORTED);
+
+               error = bo_func->bo_unmap(bo_data->backend_bo_data);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_RETURN_VAL_IF_FAIL(backend, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_IF_FAIL(backend->bo_unmap, TBM_ERROR_NOT_SUPPORTED);
+
+               ret = backend->bo_unmap(bo_data->priv);
+               if (!ret)
+                       error = TBM_ERROR_INVALID_OPERATION;
+               else
+                       error = TBM_ERROR_NONE;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               error = TBM_ERROR_INVALID_OPERATION;
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       return error;
+}
+
+tbm_error_e
+tbm_bo_data_lock(tbm_bo_data *bo_data, int device, int opt)
+{
+       tbm_module *module = NULL;
+       tbm_backend_bo_func *bo_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+       tbm_error_e error;
+       int ret = 0;
+
+       TBM_RETURN_VAL_IF_FAIL(bo_data, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_IF_FAIL(bo_data->module, TBM_ERROR_INVALID_PARAMETER);
+
+       module = bo_data->module;
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               error = (tbm_error_e)hal_tbm_bo_lock(bo_data->hal_bo, device, opt);
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bo_func = module->bo_func;
+               TBM_RETURN_VAL_IF_FAIL(bo_func, TBM_ERROR_INVALID_OPERATION);
+               if (!bo_func->bo_lock)
+                       return TBM_ERROR_NOT_SUPPORTED;
+
+               error = bo_func->bo_lock(bo_data->backend_bo_data, device, opt);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_RETURN_VAL_IF_FAIL(backend, TBM_ERROR_INVALID_OPERATION);
+               if (!backend->bo_unmap)
+                       return TBM_ERROR_NOT_SUPPORTED;
+
+               ret = backend->bo_lock(bo_data->priv, device, opt);
+               if (!ret)
+                       error = TBM_ERROR_INVALID_OPERATION;
+               else
+                       error = TBM_ERROR_NONE;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               error = TBM_ERROR_INVALID_OPERATION;
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       return error;
+}
+
+tbm_error_e
+tbm_bo_data_unlock(tbm_bo_data *bo_data)
+{
+       tbm_module *module = NULL;
+       tbm_backend_bo_func *bo_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+       tbm_error_e error;
+
+       TBM_RETURN_VAL_IF_FAIL(bo_data, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_IF_FAIL(bo_data->module, TBM_ERROR_INVALID_PARAMETER);
+
+       module = bo_data->module;
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               error = (tbm_error_e)hal_tbm_bo_unlock(bo_data->hal_bo);
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bo_func = module->bo_func;
+               TBM_RETURN_VAL_IF_FAIL(bo_func, TBM_ERROR_INVALID_OPERATION);
+               if (!bo_func->bo_unlock)
+                       return TBM_ERROR_NOT_SUPPORTED;
+
+               error = bo_func->bo_unlock(bo_data->backend_bo_data);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_RETURN_VAL_IF_FAIL(backend, TBM_ERROR_INVALID_OPERATION);
+               if (!backend->bo_unlock)
+                       return TBM_ERROR_NOT_SUPPORTED;
+
+               backend->bo_unlock(bo_data->priv);
+               error = TBM_ERROR_NONE;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               error = TBM_ERROR_INVALID_OPERATION;
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       return error;
+}
+
+tbm_fd
+tbm_bo_data_export_fd(tbm_bo_data *bo_data, tbm_error_e *error)
+{
+       tbm_module *module = NULL;
+       tbm_backend_bo_func *bo_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+       tbm_fd fd;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data, -1, *error, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data->module, -1, *error, TBM_ERROR_INVALID_PARAMETER);
+
+       module = bo_data->module;
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               fd = (hal_tbm_fd)hal_tbm_bo_export_fd(bo_data->hal_bo, (hal_tbm_error *)error);
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bo_func = module->bo_func;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func, -1, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func->bo_export_fd, -1, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               fd = bo_func->bo_export_fd(bo_data->backend_bo_data, error);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend, -1, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend->bo_export_fd, -1, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               fd = backend->bo_export_fd(bo_data->priv);
+               if (fd < 0)
+                       *error = TBM_ERROR_INVALID_OPERATION;
+               else
+                       *error = TBM_ERROR_NONE;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               fd = -1;
+               *error = TBM_ERROR_INVALID_OPERATION;
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       return fd;
+}
+
+tbm_key
+tbm_bo_data_export_key(tbm_bo_data *bo_data, tbm_error_e *error)
+{
+       tbm_module *module = NULL;
+       tbm_backend_bo_func *bo_func = NULL;
+       tbm_bufmgr_backend backend = NULL;
+       tbm_key ret;
+
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data, 0, *error, TBM_ERROR_INVALID_PARAMETER);
+       TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_data->module, 0, *error, TBM_ERROR_INVALID_PARAMETER);
+
+       module = bo_data->module;
+
+       switch (module->type) {
+       case TBM_MODULE_TYPE_HAL_TBM:
+               ret = (hal_tbm_fd)hal_tbm_bo_export_key(bo_data->hal_bo, (hal_tbm_error *)error);
+               break;
+/* LCOV_EXCL_START */
+       case TBM_MODULE_TYPE_TBM_BACKEND:
+               bo_func = module->bo_func;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func, 0, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(bo_func->bo_export_key, 0, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               ret = bo_func->bo_export_key(bo_data->backend_bo_data, error);
+               break;
+       case TBM_MODULE_TYPE_BUFMGR_BACKEND:
+               TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5.");
+               backend = module->backend;
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend, 0, *error, TBM_ERROR_INVALID_OPERATION);
+               TBM_RETURN_VAL_SET_ERR_IF_FAIL(backend->bo_export, 0, *error, TBM_ERROR_NOT_SUPPORTED);
+
+               ret = backend->bo_export(bo_data->priv);
+               if (!ret)
+                       *error = TBM_ERROR_INVALID_OPERATION;
+               else
+                       *error = TBM_ERROR_NONE;
+               break;
+       default:
+               TBM_ERR("Wrong module type:%d", module->type);
+               ret = -1;
+               *error = TBM_ERROR_INVALID_OPERATION;
+               break;
+/* LCOV_EXCL_STOP */
+       }
+
+       return ret;
 }