X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2Ftbm_module.c;h=16beb7f01911c6cf785f7cc694060a607711a8b1;hb=5d6f1d8855f0301ac781a5e66068344ed636a0b0;hp=803138536a0166448a9296365bc2137717fbf2a7;hpb=a6e9f8dc1ea300c3c473938de6d6e7e796b36783;p=platform%2Fcore%2Fuifw%2Flibtbm.git diff --git a/src/tbm_module.c b/src/tbm_module.c index 8031385..16beb7f 100644 --- a/src/tbm_module.c +++ b/src/tbm_module.c @@ -52,12 +52,10 @@ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. #define GET_MODULE_PATCHLEVEL(vers) ((vers) & 0xFFFF) /* LCOV_EXCL_START */ - static int -_tbm_backend_load_hal_tbm(tbm_bufmgr bufmgr) +_tbm_backend_load_hal_tbm(tbm_module *module) { hal_tbm_backend *hal_backend = NULL; - hal_tbm_bufmgr_capability capability; hal_tbm_bufmgr *hal_bufmgr; hal_tbm_error ret = HAL_TBM_ERROR_NONE; hal_tbm_fd auth_drm_fd = -1; @@ -104,28 +102,10 @@ _tbm_backend_load_hal_tbm(tbm_bufmgr bufmgr) tbm_drm_helper_set_fd(auth_drm_fd); } - capability = hal_tbm_bufmgr_get_capabilities(hal_bufmgr, &ret); - if (ret != HAL_TBM_ERROR_NONE) { - TBM_ERR("hal_tbm_bufmgr_get_capabilities fail."); - goto get_backend_fail; - } - - if (capability == HAL_TBM_BUFMGR_CAPABILITY_NONE) { - TBM_ERR("The capabilities of the backend module is TBM_BUFMGR_CAPABILITY_NONE."); - TBM_ERR("TBM_BUFMGR_CAPABILITY_SHARE_FD is the essential capability."); - goto get_backend_fail; - } - if (!(capability & HAL_TBM_BUFMGR_CAPABILITY_SHARE_FD)) { - TBM_ERR("The capabilities of the backend module had no TBM_BUFMGR_CAPABILITY_SHARE_FD."); - TBM_ERR("The tbm backend has to get TBM_BUFMGR_CAPABILITY_SHARE_FD. "); - goto get_backend_fail; - } - bufmgr->capabilities = capability; - - bufmgr->hal_backend = hal_backend; - bufmgr->hal_bufmgr = hal_bufmgr; + module->hal_backend = hal_backend; + module->hal_bufmgr = hal_bufmgr; - bufmgr->use_hal_tbm = 1; + module->use_hal_tbm = 1; TBM_INFO("use HAL-TBM_API"); @@ -210,7 +190,7 @@ _tbm_backend_check_bufmgr_bo(tbm_backend_bo_func *bo_func) } static int -_tbm_backend_load_module(tbm_bufmgr bufmgr, const char *file) +_tbm_backend_load_module(tbm_module *module, const char *file) { char path[PATH_MAX] = {0, }; void *module_data = NULL; @@ -266,40 +246,26 @@ _tbm_backend_load_module(tbm_bufmgr bufmgr, const char *file) goto err; } - bufmgr_data = backend_module_data->init(bufmgr, &error); + bufmgr_data = backend_module_data->init((tbm_bufmgr)module, &error); if (!bufmgr_data) { TBM_ERR("Fail to init module(%s)\n", file); goto err; } /* check the mandatory symbols of the backend module */ - if (!_tbm_backend_check_bufmgr_func(bufmgr->bufmgr_func)) { + if (!_tbm_backend_check_bufmgr_func(module->bufmgr_func)) { TBM_ERR("Fail to check the bufmgr_func symboles."); goto err; } - if (!_tbm_backend_check_bufmgr_bo(bufmgr->bo_func)) { + if (!_tbm_backend_check_bufmgr_bo(module->bo_func)) { TBM_ERR("Fail to check the bufmgr_bo symboles."); goto err; } - /* get the capability */ - bufmgr->capabilities = bufmgr->bufmgr_func->bufmgr_get_capabilities(bufmgr_data, &error); - if (bufmgr->capabilities == TBM_BUFMGR_CAPABILITY_NONE) { - TBM_ERR("The capabilities of the backend module is TBM_BUFMGR_CAPABILITY_NONE."); - TBM_ERR("TBM_BUFMGR_CAPABILITY_SHARE_FD is the essential capability."); - goto err; - } - - if (!(bufmgr->capabilities & TBM_BUFMGR_CAPABILITY_SHARE_FD)) { - TBM_ERR("The capabilities of the backend module had no TBM_BUFMGR_CAPABILITY_SHARE_FD."); - TBM_ERR("The tbm backend has to get TBM_BUFMGR_CAPABILITY_SHARE_FD. "); - goto err; - } - - bufmgr->module_data = module_data; - bufmgr->backend_module_data = backend_module_data; - bufmgr->bufmgr_data = bufmgr_data; + module->module_data = module_data; + module->backend_module_data = backend_module_data; + module->bufmgr_data = bufmgr_data; TBM_INFO("Success to load module(%s)\n", file); @@ -307,7 +273,7 @@ _tbm_backend_load_module(tbm_bufmgr bufmgr, const char *file) err: if (bufmgr_data) - bufmgr->backend_module_data->deinit(bufmgr_data); + module->backend_module_data->deinit(bufmgr_data); if (module_data) dlclose(module_data); @@ -315,7 +281,7 @@ err: } static int -_tbm_bufmgr_load_module(tbm_bufmgr bufmgr, int fd, const char *file) +_tbm_backend_load_bufmgr_module(tbm_module *module, int fd, const char *file) { char path[PATH_MAX] = {0, }; TBMModuleVersionInfo *vers; @@ -354,17 +320,17 @@ _tbm_bufmgr_load_module(tbm_bufmgr bufmgr, int fd, const char *file) goto err; } - if (!init(bufmgr, fd)) { + if (!init((tbm_bufmgr)module, fd)) { TBM_ERR("Fail to init module(%s)\n", file); goto err; } - if (!bufmgr->backend || !bufmgr->backend->priv) { + if (!module->backend || !module->backend->priv) { TBM_ERR("Error: module(%s) wrong operation. Check backend or backend's priv.\n", file); goto err; } - bufmgr->module_data = module_data; + module->module_data = module_data; TBM_DBG("Success to load module(%s)\n", file); @@ -374,11 +340,10 @@ err: dlclose(module_data); return 0; } - /* LCOV_EXCL_STOP */ tbm_module * -tbm_module_load(tbm_bufmgr bufmgr, int fd) +tbm_module_load(int fd) { tbm_module *module; struct dirent **namelist; @@ -389,34 +354,35 @@ tbm_module_load(tbm_bufmgr bufmgr, int fd) TBM_ERR("fail to allocate the memory"); return NULL; } - module->bufmgr = bufmgr; /* try to load the hal-tbm backend module */ - ret = _tbm_backend_load_hal_tbm(bufmgr); + ret = _tbm_backend_load_hal_tbm(module); if (ret) { module->type = TBM_MODULE_TYPE_HAL_TBM; - return module; + goto done; } +/* LCOV_EXCL_START */ /* try to load the new backend module */ - ret = _tbm_backend_load_module(bufmgr, DEFAULT_LIB); + ret = _tbm_backend_load_module(module, DEFAULT_LIB); if (ret) { module->type = TBM_MODULE_TYPE_TBM_BACKEND; - return module; + goto done; } /* try to load the old(deprecated) backend mdoule */ - ret = _tbm_bufmgr_load_module(bufmgr, fd, DEFAULT_LIB); + ret = _tbm_backend_load_bufmgr_module(module, fd, DEFAULT_LIB); if (ret) { module->type = TBM_MODULE_TYPE_BUFMGR_BACKEND; return module; } - /* load bufmgr priv from configured path */ + /* load backend_module from configured path */ n = scandir(BUFMGR_MODULE_DIR, &namelist, 0, alphasort); if (n < 0) { TBM_ERR("no files : %s\n", BUFMGR_MODULE_DIR); - return 0; + tbm_module_unload(module); + return NULL; } while (n--) { @@ -424,11 +390,11 @@ tbm_module_load(tbm_bufmgr bufmgr, int fd) const char *p = strstr(namelist[n]->d_name, SUFFIX_LIB); if (p && !strcmp(p, SUFFIX_LIB)) { - ret = _tbm_backend_load_module(bufmgr, namelist[n]->d_name); + ret = _tbm_backend_load_module(module, namelist[n]->d_name); if (ret) module->type = TBM_MODULE_TYPE_TBM_BACKEND; else { - ret = _tbm_bufmgr_load_module(bufmgr, fd, namelist[n]->d_name); + ret = _tbm_backend_load_bufmgr_module(module, fd, namelist[n]->d_name); module->type = TBM_MODULE_TYPE_BUFMGR_BACKEND; } } @@ -443,46 +409,1169 @@ tbm_module_load(tbm_bufmgr bufmgr, int fd) free(module); module = NULL; } +/* LCOV_EXCL_STOP */ +done: return module; } void tbm_module_unload(tbm_module *module) { - tbm_bufmgr bufmgr = module->bufmgr; - - if (bufmgr->use_hal_tbm) { - if (bufmgr->auth_wl_socket_created) { + switch (module->type) { + case TBM_MODULE_TYPE_HAL_TBM: + if (module->auth_wl_socket_created) { tbm_drm_helper_wl_auth_server_deinit(); - close(bufmgr->auth_fd); - tbm_drm_helper_unset_tbm_master_fd(); + close(module->auth_fd); } + tbm_drm_helper_unset_tbm_master_fd(); tbm_drm_helper_unset_fd(); - hal_tbm_put_backend(bufmgr->hal_backend); - bufmgr->hal_backend = NULL; - bufmgr->hal_bufmgr = NULL; - bufmgr->use_hal_tbm = 0; - } else { - if (bufmgr->backend_module_data) { - /* deinit and backend destroys the backend func and data */ - bufmgr->backend_module_data->deinit(bufmgr->bufmgr_data); - bufmgr->bo_func = NULL; - bufmgr->bufmgr_func = NULL; - bufmgr->bufmgr_data = NULL; - bufmgr->backend_module_data = NULL; + hal_tbm_put_backend(module->hal_backend); + module->hal_backend = NULL; + module->hal_bufmgr = NULL; + module->use_hal_tbm = 0; + break; +/* LCOV_EXCL_START */ + case TBM_MODULE_TYPE_TBM_BACKEND: + module->backend_module_data->deinit(module->bufmgr_data); + module->bo_func = NULL; + module->bufmgr_func = NULL; + module->bufmgr_data = NULL; + module->backend_module_data = NULL; + + dlclose(module->module_data); + break; + case TBM_MODULE_TYPE_BUFMGR_BACKEND: + module->backend->bufmgr_deinit(module->backend->priv); + module->backend->priv = NULL; + tbm_backend_free(module->backend); + module->backend = NULL; + + dlclose(module->module_data); + break; + default: + TBM_ERR("Wrong module type:%d", module->type); + break; +/* LCOV_EXCL_STOP */ + } + + free(module); +} + +int +tbm_module_get_capabilities(tbm_module *module, tbm_error_e *error) +{ + int capabilities = 0; + tbm_backend_bufmgr_func *bufmgr_func = NULL; + + TBM_RETURN_VAL_SET_ERR_IF_FAIL(module, TBM_BUFMGR_CAPABILITY_NONE, *error, TBM_ERROR_INVALID_PARAMETER); + + switch (module->type) { + case TBM_MODULE_TYPE_HAL_TBM: + capabilities = hal_tbm_bufmgr_get_capabilities(module->hal_bufmgr, (hal_tbm_error *)error); + break; +/* LCOV_EXCL_START */ + case TBM_MODULE_TYPE_TBM_BACKEND: + bufmgr_func = module->bufmgr_func; + TBM_RETURN_VAL_SET_ERR_IF_FAIL(bufmgr_func, 0, *error, TBM_ERROR_INVALID_OPERATION); + TBM_RETURN_VAL_SET_ERR_IF_FAIL(bufmgr_func->bufmgr_get_capabilities, 0, *error, TBM_ERROR_NOT_SUPPORTED); + + capabilities = module->bufmgr_func->bufmgr_get_capabilities(module->bufmgr_data, error); + break; + case TBM_MODULE_TYPE_BUFMGR_BACKEND: + TBM_WRN("!!WARNING: This backend interface will be DEPRECATED after Tizen 6.5."); + TBM_ERR("Do not support at tbm_bufmgr_backend."); + + *error = TBM_ERROR_NOT_SUPPORTED; + break; + default: + TBM_ERR("Wrong module type:%d", module->type); + *error = TBM_ERROR_INVALID_OPERATION; + break; +/* LCOV_EXCL_STOP */ + } + + return capabilities; +} + +tbm_error_e +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; + tbm_bufmgr_backend backend = NULL; + int ret = 0; + + TBM_RETURN_VAL_IF_FAIL(module, TBM_ERROR_INVALID_PARAMETER); + + switch (module->type) { + 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 < 0) { + TBM_ERR("error: module(%p) native_display(%p)\n", module, native_display); + return TBM_ERROR_INVALID_OPERATION; + } + + // make the wayland server socket for sending the authenticated drm_fd to wayland clients. + if (!tbm_drm_helper_wl_auth_server_init(native_display, fd, NULL, 0)) { + TBM_ERR("error: tbm_drm_helper_wl_auth_server_init failed\n", module, native_display); + close(fd); + return TBM_ERROR_INVALID_OPERATION; + } + TBM_INFO("tbm creates a wayland socket for authentication of drm_fd."); + + module->auth_wl_socket_created = 1; + module->auth_fd = fd; } else { - /* destroy bufmgr priv */ - bufmgr->backend->bufmgr_deinit(bufmgr->backend->priv); - bufmgr->backend->priv = NULL; - tbm_backend_free(bufmgr->backend); - bufmgr->backend = NULL; + TBM_INFO("tbm_module has no drm device."); + error = TBM_ERROR_NONE; } + break; +/* LCOV_EXCL_START */ + case TBM_MODULE_TYPE_TBM_BACKEND: + bufmgr_func = module->bufmgr_func; + TBM_RETURN_VAL_IF_FAIL(bufmgr_func, TBM_ERROR_INVALID_OPERATION); + TBM_RETURN_VAL_IF_FAIL(bufmgr_func->bufmgr_bind_native_display, TBM_ERROR_NOT_SUPPORTED); + + error = bufmgr_func->bufmgr_bind_native_display(module->bufmgr_data, (tbm_native_display *)native_display); + 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->bufmgr_bind_native_display, TBM_ERROR_NOT_SUPPORTED); + + ret = backend->bufmgr_bind_native_display((tbm_bufmgr)module, native_display); + if (!ret) + error = TBM_ERROR_INVALID_OPERATION; + + break; + default: + TBM_ERR("Wrong module type:%d", module->type); + error = TBM_ERROR_INVALID_OPERATION; + break; +/* LCOV_EXCL_STOP */ + } - dlclose(bufmgr->module_data); + return error; +} + +tbm_error_e +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; + tbm_bufmgr_backend backend = NULL; + int ret = 0; + + TBM_RETURN_VAL_IF_FAIL(module, TBM_ERROR_INVALID_PARAMETER); + + switch (module->type) { + case TBM_MODULE_TYPE_HAL_TBM: + error = (tbm_error_e)hal_tbm_bufmgr_get_supported_formats(module->hal_bufmgr, formats, num); + break; +/* LCOV_EXCL_START */ + case TBM_MODULE_TYPE_TBM_BACKEND: + bufmgr_func = module->bufmgr_func; + TBM_RETURN_VAL_IF_FAIL(bufmgr_func, TBM_ERROR_INVALID_OPERATION); + TBM_RETURN_VAL_IF_FAIL(bufmgr_func->bufmgr_get_supported_formats, TBM_ERROR_NOT_SUPPORTED); + + error = bufmgr_func->bufmgr_get_supported_formats(module->bufmgr_data, formats, num); + 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->surface_supported_format, TBM_ERROR_NOT_SUPPORTED); + + ret = backend->surface_supported_format(formats, num); + if (!ret) + error = TBM_ERROR_INVALID_OPERATION; + + break; + default: + TBM_ERR("Wrong module type:%d", module->type); + error = TBM_ERROR_INVALID_OPERATION; + break; +/* LCOV_EXCL_STOP */ } - free(module); + return error; +} + +tbm_error_e +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; + tbm_backend_bufmgr_func *bufmgr_func = NULL; + tbm_bufmgr_backend backend = NULL; + int ret = 0; + + TBM_RETURN_VAL_IF_FAIL(module, TBM_ERROR_INVALID_PARAMETER); + + switch (module->type) { + case TBM_MODULE_TYPE_HAL_TBM: + error = (tbm_error_e)hal_tbm_bufmgr_get_plane_data(module->hal_bufmgr, format, plane_idx, w, h, size, offset, pitch, bo_idx); + break; +/* LCOV_EXCL_START */ + case TBM_MODULE_TYPE_TBM_BACKEND: + bufmgr_func = module->bufmgr_func; + TBM_RETURN_VAL_IF_FAIL(bufmgr_func, TBM_ERROR_INVALID_OPERATION); + TBM_RETURN_VAL_IF_FAIL(bufmgr_func->bufmgr_get_plane_data, TBM_ERROR_NOT_SUPPORTED); + + error = bufmgr_func->bufmgr_get_plane_data(module->bufmgr_data, format, plane_idx, w, h, size, offset, pitch, bo_idx); + 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->surface_get_plane_data, TBM_ERROR_NOT_SUPPORTED); + + ret = backend->surface_get_plane_data(w, h, format, plane_idx, size, offset, pitch, bo_idx); + if (!ret) + error = TBM_ERROR_INVALID_OPERATION; + break; + default: + TBM_ERR("Wrong module type:%d", module->type); + error = TBM_ERROR_INVALID_OPERATION; + break; +/* LCOV_EXCL_STOP */ + } + + return 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_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->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_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->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_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); + + *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_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_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->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_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->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_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; +}