Hi, all: when analyzing v5.1 source code, I notice that in ttm_bo_add_move_fence, when reservation_object_reserve_shared failed and return ENOMEM, the fence's refcount increased without a pair decrement even after return to ttm_bo_add_move_fence's caller ttm_bo_mem_force_space:
static int ttm_bo_add_move_fence(struct ttm_buffer_object *bo, struct ttm_mem_type_manager *man, struct ttm_mem_reg *mem) { ...... fence = dma_fence_get(man->move); spin_unlock(&man->move_lock); if (fence) { reservation_object_add_shared_fence(bo->resv, fence); ret = reservation_object_reserve_shared(bo->resv, 1); if (unlikely(ret)) return ret; dma_fence_put(bo->moving); bo->moving = fence; } return 0; } can this lead to the imbalance of the fence's refcount? though the ENOMEN almost won't be trigger. Best Regards Lin Yi _______________________________________________ dri-devel mailing list dri-devel@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/dri-devel