-
-alloc_fail:
- TBM_ERR("error: fail to create of tbm_bo size(%d) flag(%s)\n", size, _tbm_flag_to_str(flags));
- free(bo);
- _tbm_bufmgr_mutex_unlock();
- return NULL;
-}
-
-/* LCOV_EXCL_START */
-tbm_bo
-tbm_bo_alloc_with_bo_data(tbm_bufmgr bufmgr, tbm_backend_bo_data *bo_data, int flags)
-{
- tbm_bo bo, bo2 = NULL;
-
- _tbm_bufmgr_mutex_lock();
- _tbm_set_last_result(TBM_ERROR_NONE);
-
- TBM_BO_RETURN_VAL_IF_FAIL(TBM_BUFMGR_IS_VALID(bufmgr), NULL);
- TBM_BO_RETURN_VAL_IF_FAIL(bo_data, NULL);
-
- // return an existed bo if the bo is already created with the same bo_data.
- if (!LIST_IS_EMPTY(&bufmgr->bo_list)) {
- LIST_FOR_EACH_ENTRY(bo2, &bufmgr->bo_list, item_link) {
- if (bo2->bo_data == bo_data) {
- TBM_ERR("find bo(%p) ref(%d) flag(%s) in list\n",
- bo2, bo2->ref_cnt, _tbm_flag_to_str(bo2->flags));
- bo2->ref_cnt++;
- _tbm_bufmgr_mutex_unlock();
- return bo2;
- }
- }
- }
-
- bo = calloc(1, sizeof(struct _tbm_bo));
- if (!bo) {
- /* LCOV_EXCL_START */
- _tbm_set_last_result(TBM_ERROR_OUT_OF_MEMORY);
- _tbm_bufmgr_mutex_unlock();
- return NULL;
- /* LCOV_EXCL_STOP */
- }
-
- _tbm_util_check_bo_cnt(bufmgr);
-
- bo->get_from_hal_surface = 1;
- bo->bo_data = bo_data;
-
- _tbm_bo_init(bufmgr, bo, flags);
-
- TBM_TRACE_BO("bo(%p) refcnt(%d), flag(%s)\n", bo, bo->ref_cnt, _tbm_flag_to_str(bo->flags));
-
- _tbm_bufmgr_mutex_unlock();
-
- return bo;