Commit bfa3357e authored by Christian König's avatar Christian König

drm/ttm: allocate resource object instead of embedding it v2

To improve the handling we want the establish the resource object as base
class for the backend allocations.

v2: add missing error handling
Signed-off-by: default avatarChristian König <christian.koenig@amd.com>
Acked-by: default avatarThomas Hellström <thomas.hellstrom@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20210602100914.46246-1-christian.koenig@amd.com
parent 4e566003
...@@ -362,14 +362,14 @@ int amdgpu_bo_create_kernel_at(struct amdgpu_device *adev, ...@@ -362,14 +362,14 @@ int amdgpu_bo_create_kernel_at(struct amdgpu_device *adev,
if (cpu_addr) if (cpu_addr)
amdgpu_bo_kunmap(*bo_ptr); amdgpu_bo_kunmap(*bo_ptr);
ttm_resource_free(&(*bo_ptr)->tbo, (*bo_ptr)->tbo.resource); ttm_resource_free(&(*bo_ptr)->tbo, &(*bo_ptr)->tbo.resource);
for (i = 0; i < (*bo_ptr)->placement.num_placement; ++i) { for (i = 0; i < (*bo_ptr)->placement.num_placement; ++i) {
(*bo_ptr)->placements[i].fpfn = offset >> PAGE_SHIFT; (*bo_ptr)->placements[i].fpfn = offset >> PAGE_SHIFT;
(*bo_ptr)->placements[i].lpfn = (offset + size) >> PAGE_SHIFT; (*bo_ptr)->placements[i].lpfn = (offset + size) >> PAGE_SHIFT;
} }
r = ttm_bo_mem_space(&(*bo_ptr)->tbo, &(*bo_ptr)->placement, r = ttm_bo_mem_space(&(*bo_ptr)->tbo, &(*bo_ptr)->placement,
(*bo_ptr)->tbo.resource, &ctx); &(*bo_ptr)->tbo.resource, &ctx);
if (r) if (r)
goto error; goto error;
......
...@@ -491,7 +491,7 @@ static int amdgpu_bo_move(struct ttm_buffer_object *bo, bool evict, ...@@ -491,7 +491,7 @@ static int amdgpu_bo_move(struct ttm_buffer_object *bo, bool evict,
return r; return r;
amdgpu_ttm_backend_unbind(bo->bdev, bo->ttm); amdgpu_ttm_backend_unbind(bo->bdev, bo->ttm);
ttm_resource_free(bo, bo->resource); ttm_resource_free(bo, &bo->resource);
ttm_bo_assign_mem(bo, new_mem); ttm_bo_assign_mem(bo, new_mem);
goto out; goto out;
} }
...@@ -950,9 +950,9 @@ int amdgpu_ttm_alloc_gart(struct ttm_buffer_object *bo) ...@@ -950,9 +950,9 @@ int amdgpu_ttm_alloc_gart(struct ttm_buffer_object *bo)
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->bdev); struct amdgpu_device *adev = amdgpu_ttm_adev(bo->bdev);
struct ttm_operation_ctx ctx = { false, false }; struct ttm_operation_ctx ctx = { false, false };
struct amdgpu_ttm_tt *gtt = (void *)bo->ttm; struct amdgpu_ttm_tt *gtt = (void *)bo->ttm;
struct ttm_resource tmp;
struct ttm_placement placement; struct ttm_placement placement;
struct ttm_place placements; struct ttm_place placements;
struct ttm_resource *tmp;
uint64_t addr, flags; uint64_t addr, flags;
int r; int r;
...@@ -962,37 +962,37 @@ int amdgpu_ttm_alloc_gart(struct ttm_buffer_object *bo) ...@@ -962,37 +962,37 @@ int amdgpu_ttm_alloc_gart(struct ttm_buffer_object *bo)
addr = amdgpu_gmc_agp_addr(bo); addr = amdgpu_gmc_agp_addr(bo);
if (addr != AMDGPU_BO_INVALID_OFFSET) { if (addr != AMDGPU_BO_INVALID_OFFSET) {
bo->resource->start = addr >> PAGE_SHIFT; bo->resource->start = addr >> PAGE_SHIFT;
} else { return 0;
}
/* allocate GART space */ /* allocate GART space */
placement.num_placement = 1; placement.num_placement = 1;
placement.placement = &placements; placement.placement = &placements;
placement.num_busy_placement = 1; placement.num_busy_placement = 1;
placement.busy_placement = &placements; placement.busy_placement = &placements;
placements.fpfn = 0; placements.fpfn = 0;
placements.lpfn = adev->gmc.gart_size >> PAGE_SHIFT; placements.lpfn = adev->gmc.gart_size >> PAGE_SHIFT;
placements.mem_type = TTM_PL_TT; placements.mem_type = TTM_PL_TT;
placements.flags = bo->resource->placement; placements.flags = bo->resource->placement;
r = ttm_bo_mem_space(bo, &placement, &tmp, &ctx);
if (unlikely(r))
return r;
/* compute PTE flags for this buffer object */ r = ttm_bo_mem_space(bo, &placement, &tmp, &ctx);
flags = amdgpu_ttm_tt_pte_flags(adev, bo->ttm, &tmp); if (unlikely(r))
return r;
/* Bind pages */ /* compute PTE flags for this buffer object */
gtt->offset = (u64)tmp.start << PAGE_SHIFT; flags = amdgpu_ttm_tt_pte_flags(adev, bo->ttm, tmp);
r = amdgpu_ttm_gart_bind(adev, bo, flags);
if (unlikely(r)) {
ttm_resource_free(bo, &tmp);
return r;
}
ttm_resource_free(bo, bo->resource); /* Bind pages */
ttm_bo_assign_mem(bo, &tmp); gtt->offset = (u64)tmp->start << PAGE_SHIFT;
r = amdgpu_ttm_gart_bind(adev, bo, flags);
if (unlikely(r)) {
ttm_resource_free(bo, &tmp);
return r;
} }
ttm_resource_free(bo, &bo->resource);
ttm_bo_assign_mem(bo, tmp);
return 0; return 0;
} }
......
...@@ -1009,7 +1009,7 @@ nouveau_bo_move(struct ttm_buffer_object *bo, bool evict, ...@@ -1009,7 +1009,7 @@ nouveau_bo_move(struct ttm_buffer_object *bo, bool evict,
if (old_reg->mem_type == TTM_PL_TT && if (old_reg->mem_type == TTM_PL_TT &&
new_reg->mem_type == TTM_PL_SYSTEM) { new_reg->mem_type == TTM_PL_SYSTEM) {
nouveau_ttm_tt_unbind(bo->bdev, bo->ttm); nouveau_ttm_tt_unbind(bo->bdev, bo->ttm);
ttm_resource_free(bo, bo->resource); ttm_resource_free(bo, &bo->resource);
ttm_bo_assign_mem(bo, new_reg); ttm_bo_assign_mem(bo, new_reg);
goto out; goto out;
} }
......
...@@ -229,7 +229,7 @@ static int radeon_bo_move(struct ttm_buffer_object *bo, bool evict, ...@@ -229,7 +229,7 @@ static int radeon_bo_move(struct ttm_buffer_object *bo, bool evict,
if (old_mem->mem_type == TTM_PL_TT && if (old_mem->mem_type == TTM_PL_TT &&
new_mem->mem_type == TTM_PL_SYSTEM) { new_mem->mem_type == TTM_PL_SYSTEM) {
radeon_ttm_tt_unbind(bo->bdev, bo->ttm); radeon_ttm_tt_unbind(bo->bdev, bo->ttm);
ttm_resource_free(bo, bo->resource); ttm_resource_free(bo, &bo->resource);
ttm_bo_assign_mem(bo, new_mem); ttm_bo_assign_mem(bo, new_mem);
goto out; goto out;
} }
......
...@@ -223,7 +223,7 @@ static void ttm_bo_cleanup_memtype_use(struct ttm_buffer_object *bo) ...@@ -223,7 +223,7 @@ static void ttm_bo_cleanup_memtype_use(struct ttm_buffer_object *bo)
bo->bdev->funcs->delete_mem_notify(bo); bo->bdev->funcs->delete_mem_notify(bo);
ttm_bo_tt_destroy(bo); ttm_bo_tt_destroy(bo);
ttm_resource_free(bo, bo->resource); ttm_resource_free(bo, &bo->resource);
} }
static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo) static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
...@@ -489,7 +489,7 @@ static int ttm_bo_evict(struct ttm_buffer_object *bo, ...@@ -489,7 +489,7 @@ static int ttm_bo_evict(struct ttm_buffer_object *bo,
struct ttm_operation_ctx *ctx) struct ttm_operation_ctx *ctx)
{ {
struct ttm_device *bdev = bo->bdev; struct ttm_device *bdev = bo->bdev;
struct ttm_resource evict_mem; struct ttm_resource *evict_mem;
struct ttm_placement placement; struct ttm_placement placement;
struct ttm_place hop; struct ttm_place hop;
int ret = 0; int ret = 0;
...@@ -519,7 +519,7 @@ static int ttm_bo_evict(struct ttm_buffer_object *bo, ...@@ -519,7 +519,7 @@ static int ttm_bo_evict(struct ttm_buffer_object *bo,
goto out; goto out;
} }
ret = ttm_bo_handle_move_mem(bo, &evict_mem, true, ctx, &hop); ret = ttm_bo_handle_move_mem(bo, evict_mem, true, ctx, &hop);
if (unlikely(ret)) { if (unlikely(ret)) {
WARN(ret == -EMULTIHOP, "Unexpected multihop in eviction - likely driver bug\n"); WARN(ret == -EMULTIHOP, "Unexpected multihop in eviction - likely driver bug\n");
if (ret != -ERESTARTSYS) if (ret != -ERESTARTSYS)
...@@ -728,14 +728,15 @@ static int ttm_bo_add_move_fence(struct ttm_buffer_object *bo, ...@@ -728,14 +728,15 @@ static int ttm_bo_add_move_fence(struct ttm_buffer_object *bo,
*/ */
static int ttm_bo_mem_force_space(struct ttm_buffer_object *bo, static int ttm_bo_mem_force_space(struct ttm_buffer_object *bo,
const struct ttm_place *place, const struct ttm_place *place,
struct ttm_resource *mem, struct ttm_resource **mem,
struct ttm_operation_ctx *ctx) struct ttm_operation_ctx *ctx)
{ {
struct ttm_device *bdev = bo->bdev; struct ttm_device *bdev = bo->bdev;
struct ttm_resource_manager *man = ttm_manager_type(bdev, mem->mem_type); struct ttm_resource_manager *man;
struct ww_acquire_ctx *ticket; struct ww_acquire_ctx *ticket;
int ret; int ret;
man = ttm_manager_type(bdev, (*mem)->mem_type);
ticket = dma_resv_locking_ctx(bo->base.resv); ticket = dma_resv_locking_ctx(bo->base.resv);
do { do {
ret = ttm_resource_alloc(bo, place, mem); ret = ttm_resource_alloc(bo, place, mem);
...@@ -749,37 +750,7 @@ static int ttm_bo_mem_force_space(struct ttm_buffer_object *bo, ...@@ -749,37 +750,7 @@ static int ttm_bo_mem_force_space(struct ttm_buffer_object *bo,
return ret; return ret;
} while (1); } while (1);
return ttm_bo_add_move_fence(bo, man, mem, ctx->no_wait_gpu); return ttm_bo_add_move_fence(bo, man, *mem, ctx->no_wait_gpu);
}
/**
* ttm_bo_mem_placement - check if placement is compatible
* @bo: BO to find memory for
* @place: where to search
* @mem: the memory object to fill in
*
* Check if placement is compatible and fill in mem structure.
* Returns -EBUSY if placement won't work or negative error code.
* 0 when placement can be used.
*/
static int ttm_bo_mem_placement(struct ttm_buffer_object *bo,
const struct ttm_place *place,
struct ttm_resource *mem)
{
struct ttm_device *bdev = bo->bdev;
struct ttm_resource_manager *man;
man = ttm_manager_type(bdev, place->mem_type);
if (!man || !ttm_resource_manager_used(man))
return -EBUSY;
mem->mem_type = place->mem_type;
mem->placement = place->flags;
spin_lock(&bo->bdev->lru_lock);
ttm_bo_move_to_lru_tail(bo, mem, NULL);
spin_unlock(&bo->bdev->lru_lock);
return 0;
} }
/* /*
...@@ -792,7 +763,7 @@ static int ttm_bo_mem_placement(struct ttm_buffer_object *bo, ...@@ -792,7 +763,7 @@ static int ttm_bo_mem_placement(struct ttm_buffer_object *bo,
*/ */
int ttm_bo_mem_space(struct ttm_buffer_object *bo, int ttm_bo_mem_space(struct ttm_buffer_object *bo,
struct ttm_placement *placement, struct ttm_placement *placement,
struct ttm_resource *mem, struct ttm_resource **mem,
struct ttm_operation_ctx *ctx) struct ttm_operation_ctx *ctx)
{ {
struct ttm_device *bdev = bo->bdev; struct ttm_device *bdev = bo->bdev;
...@@ -807,8 +778,8 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo, ...@@ -807,8 +778,8 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
const struct ttm_place *place = &placement->placement[i]; const struct ttm_place *place = &placement->placement[i];
struct ttm_resource_manager *man; struct ttm_resource_manager *man;
ret = ttm_bo_mem_placement(bo, place, mem); man = ttm_manager_type(bdev, place->mem_type);
if (ret) if (!man || !ttm_resource_manager_used(man))
continue; continue;
type_found = true; type_found = true;
...@@ -818,8 +789,7 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo, ...@@ -818,8 +789,7 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
if (unlikely(ret)) if (unlikely(ret))
goto error; goto error;
man = ttm_manager_type(bdev, mem->mem_type); ret = ttm_bo_add_move_fence(bo, man, *mem, ctx->no_wait_gpu);
ret = ttm_bo_add_move_fence(bo, man, mem, ctx->no_wait_gpu);
if (unlikely(ret)) { if (unlikely(ret)) {
ttm_resource_free(bo, mem); ttm_resource_free(bo, mem);
if (ret == -EBUSY) if (ret == -EBUSY)
...@@ -832,9 +802,10 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo, ...@@ -832,9 +802,10 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
for (i = 0; i < placement->num_busy_placement; ++i) { for (i = 0; i < placement->num_busy_placement; ++i) {
const struct ttm_place *place = &placement->busy_placement[i]; const struct ttm_place *place = &placement->busy_placement[i];
struct ttm_resource_manager *man;
ret = ttm_bo_mem_placement(bo, place, mem); man = ttm_manager_type(bdev, place->mem_type);
if (ret) if (!man || !ttm_resource_manager_used(man))
continue; continue;
type_found = true; type_found = true;
...@@ -861,12 +832,12 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo, ...@@ -861,12 +832,12 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
EXPORT_SYMBOL(ttm_bo_mem_space); EXPORT_SYMBOL(ttm_bo_mem_space);
static int ttm_bo_bounce_temp_buffer(struct ttm_buffer_object *bo, static int ttm_bo_bounce_temp_buffer(struct ttm_buffer_object *bo,
struct ttm_resource *mem, struct ttm_resource **mem,
struct ttm_operation_ctx *ctx, struct ttm_operation_ctx *ctx,
struct ttm_place *hop) struct ttm_place *hop)
{ {
struct ttm_placement hop_placement; struct ttm_placement hop_placement;
struct ttm_resource hop_mem; struct ttm_resource *hop_mem;
int ret; int ret;
hop_placement.num_placement = hop_placement.num_busy_placement = 1; hop_placement.num_placement = hop_placement.num_busy_placement = 1;
...@@ -877,7 +848,7 @@ static int ttm_bo_bounce_temp_buffer(struct ttm_buffer_object *bo, ...@@ -877,7 +848,7 @@ static int ttm_bo_bounce_temp_buffer(struct ttm_buffer_object *bo,
if (ret) if (ret)
return ret; return ret;
/* move to the bounce domain */ /* move to the bounce domain */
ret = ttm_bo_handle_move_mem(bo, &hop_mem, false, ctx, NULL); ret = ttm_bo_handle_move_mem(bo, hop_mem, false, ctx, NULL);
if (ret) { if (ret) {
ttm_resource_free(bo, &hop_mem); ttm_resource_free(bo, &hop_mem);
return ret; return ret;
...@@ -889,14 +860,12 @@ static int ttm_bo_move_buffer(struct ttm_buffer_object *bo, ...@@ -889,14 +860,12 @@ static int ttm_bo_move_buffer(struct ttm_buffer_object *bo,
struct ttm_placement *placement, struct ttm_placement *placement,
struct ttm_operation_ctx *ctx) struct ttm_operation_ctx *ctx)
{ {
struct ttm_resource *mem;
struct ttm_place hop; struct ttm_place hop;
struct ttm_resource mem;
int ret; int ret;
dma_resv_assert_held(bo->base.resv); dma_resv_assert_held(bo->base.resv);
memset(&hop, 0, sizeof(hop));
/* /*
* Determine where to move the buffer. * Determine where to move the buffer.
* *
...@@ -910,7 +879,7 @@ static int ttm_bo_move_buffer(struct ttm_buffer_object *bo, ...@@ -910,7 +879,7 @@ static int ttm_bo_move_buffer(struct ttm_buffer_object *bo,
if (ret) if (ret)
return ret; return ret;
bounce: bounce:
ret = ttm_bo_handle_move_mem(bo, &mem, false, ctx, &hop); ret = ttm_bo_handle_move_mem(bo, mem, false, ctx, &hop);
if (ret == -EMULTIHOP) { if (ret == -EMULTIHOP) {
ret = ttm_bo_bounce_temp_buffer(bo, &mem, ctx, &hop); ret = ttm_bo_bounce_temp_buffer(bo, &mem, ctx, &hop);
if (ret) if (ret)
...@@ -1019,7 +988,7 @@ int ttm_bo_init_reserved(struct ttm_device *bdev, ...@@ -1019,7 +988,7 @@ int ttm_bo_init_reserved(struct ttm_device *bdev,
{ {
static const struct ttm_place sys_mem = { .mem_type = TTM_PL_SYSTEM }; static const struct ttm_place sys_mem = { .mem_type = TTM_PL_SYSTEM };
bool locked; bool locked;
int ret = 0; int ret;
bo->destroy = destroy ? destroy : ttm_bo_default_destroy; bo->destroy = destroy ? destroy : ttm_bo_default_destroy;
...@@ -1029,8 +998,6 @@ int ttm_bo_init_reserved(struct ttm_device *bdev, ...@@ -1029,8 +998,6 @@ int ttm_bo_init_reserved(struct ttm_device *bdev,
bo->bdev = bdev; bo->bdev = bdev;
bo->type = type; bo->type = type;
bo->page_alignment = page_alignment; bo->page_alignment = page_alignment;
bo->resource = &bo->_mem;
ttm_resource_alloc(bo, &sys_mem, bo->resource);
bo->moving = NULL; bo->moving = NULL;
bo->pin_count = 0; bo->pin_count = 0;
bo->sg = sg; bo->sg = sg;
...@@ -1042,6 +1009,12 @@ int ttm_bo_init_reserved(struct ttm_device *bdev, ...@@ -1042,6 +1009,12 @@ int ttm_bo_init_reserved(struct ttm_device *bdev,
} }
atomic_inc(&ttm_glob.bo_count); atomic_inc(&ttm_glob.bo_count);
ret = ttm_resource_alloc(bo, &sys_mem, &bo->resource);
if (unlikely(ret)) {
ttm_bo_put(bo);
return ret;
}
/* /*
* For ttm_bo_type_device buffers, allocate * For ttm_bo_type_device buffers, allocate
* address space from the device. * address space from the device.
...@@ -1170,7 +1143,7 @@ int ttm_bo_swapout(struct ttm_buffer_object *bo, struct ttm_operation_ctx *ctx, ...@@ -1170,7 +1143,7 @@ int ttm_bo_swapout(struct ttm_buffer_object *bo, struct ttm_operation_ctx *ctx,
*/ */
if (bo->resource->mem_type != TTM_PL_SYSTEM) { if (bo->resource->mem_type != TTM_PL_SYSTEM) {
struct ttm_operation_ctx ctx = { false, false }; struct ttm_operation_ctx ctx = { false, false };
struct ttm_resource evict_mem; struct ttm_resource *evict_mem;
struct ttm_place place, hop; struct ttm_place place, hop;
memset(&place, 0, sizeof(place)); memset(&place, 0, sizeof(place));
...@@ -1182,7 +1155,7 @@ int ttm_bo_swapout(struct ttm_buffer_object *bo, struct ttm_operation_ctx *ctx, ...@@ -1182,7 +1155,7 @@ int ttm_bo_swapout(struct ttm_buffer_object *bo, struct ttm_operation_ctx *ctx,
if (unlikely(ret)) if (unlikely(ret))
goto out; goto out;
ret = ttm_bo_handle_move_mem(bo, &evict_mem, true, &ctx, &hop); ret = ttm_bo_handle_move_mem(bo, evict_mem, true, &ctx, &hop);
if (unlikely(ret != 0)) { if (unlikely(ret != 0)) {
WARN(ret == -EMULTIHOP, "Unexpected multihop in swaput - likely driver bug.\n"); WARN(ret == -EMULTIHOP, "Unexpected multihop in swaput - likely driver bug.\n");
goto out; goto out;
......
...@@ -176,16 +176,17 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo, ...@@ -176,16 +176,17 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo,
struct ttm_operation_ctx *ctx, struct ttm_operation_ctx *ctx,
struct ttm_resource *new_mem) struct ttm_resource *new_mem)
{ {
struct ttm_resource *old_mem = bo->resource;
struct ttm_device *bdev = bo->bdev; struct ttm_device *bdev = bo->bdev;
struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type); struct ttm_resource_manager *man;
struct ttm_tt *ttm = bo->ttm; struct ttm_tt *ttm = bo->ttm;
struct ttm_resource *old_mem = bo->resource;
struct ttm_resource old_copy = *old_mem;
void *old_iomap; void *old_iomap;
void *new_iomap; void *new_iomap;
int ret; int ret;
unsigned long i; unsigned long i;
man = ttm_manager_type(bdev, new_mem->mem_type);
ret = ttm_bo_wait_ctx(bo, ctx); ret = ttm_bo_wait_ctx(bo, ctx);
if (ret) if (ret)
return ret; return ret;
...@@ -201,7 +202,7 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo, ...@@ -201,7 +202,7 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo,
* Single TTM move. NOP. * Single TTM move. NOP.
*/ */
if (old_iomap == NULL && new_iomap == NULL) if (old_iomap == NULL && new_iomap == NULL)
goto out2; goto out1;
/* /*
* Don't move nonexistent data. Clear destination instead. * Don't move nonexistent data. Clear destination instead.
...@@ -210,7 +211,7 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo, ...@@ -210,7 +211,7 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo,
(ttm == NULL || (!ttm_tt_is_populated(ttm) && (ttm == NULL || (!ttm_tt_is_populated(ttm) &&
!(ttm->page_flags & TTM_PAGE_FLAG_SWAPPED)))) { !(ttm->page_flags & TTM_PAGE_FLAG_SWAPPED)))) {
memset_io(new_iomap, 0, new_mem->num_pages*PAGE_SIZE); memset_io(new_iomap, 0, new_mem->num_pages*PAGE_SIZE);
goto out2; goto out1;
} }
/* /*
...@@ -235,27 +236,25 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo, ...@@ -235,27 +236,25 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo,
ret = ttm_copy_io_page(new_iomap, old_iomap, i); ret = ttm_copy_io_page(new_iomap, old_iomap, i);
} }
if (ret) if (ret)
goto out1; break;
} }
mb(); mb();
out2: out1:
old_copy = *old_mem; ttm_resource_iounmap(bdev, new_mem, new_iomap);
out:
ttm_resource_iounmap(bdev, old_mem, old_iomap);
if (ret) {
ttm_resource_free(bo, &new_mem);
return ret;
}
ttm_resource_free(bo, &bo->resource);
ttm_bo_assign_mem(bo, new_mem); ttm_bo_assign_mem(bo, new_mem);
if (!man->use_tt) if (!man->use_tt)
ttm_bo_tt_destroy(bo); ttm_bo_tt_destroy(bo);
out1:
ttm_resource_iounmap(bdev, old_mem, new_iomap);
out:
ttm_resource_iounmap(bdev, &old_copy, old_iomap);
/*
* On error, keep the mm node!
*/
if (!ret)
ttm_resource_free(bo, &old_copy);
return ret; return ret;
} }
EXPORT_SYMBOL(ttm_bo_move_memcpy); EXPORT_SYMBOL(ttm_bo_move_memcpy);
...@@ -566,7 +565,7 @@ static int ttm_bo_wait_free_node(struct ttm_buffer_object *bo, ...@@ -566,7 +565,7 @@ static int ttm_bo_wait_free_node(struct ttm_buffer_object *bo,
if (!dst_use_tt) if (!dst_use_tt)
ttm_bo_tt_destroy(bo); ttm_bo_tt_destroy(bo);
ttm_resource_free(bo, bo->resource); ttm_resource_free(bo, &bo->resource);
return 0; return 0;
} }
...@@ -629,7 +628,7 @@ static void ttm_bo_move_pipeline_evict(struct ttm_buffer_object *bo, ...@@ -629,7 +628,7 @@ static void ttm_bo_move_pipeline_evict(struct ttm_buffer_object *bo,
} }
spin_unlock(&from->move_lock); spin_unlock(&from->move_lock);
ttm_resource_free(bo, bo->resource); ttm_resource_free(bo, &bo->resource);
dma_fence_put(bo->moving); dma_fence_put(bo->moving);
bo->moving = dma_fence_get(fence); bo->moving = dma_fence_get(fence);
...@@ -678,11 +677,11 @@ int ttm_bo_pipeline_gutting(struct ttm_buffer_object *bo) ...@@ -678,11 +677,11 @@ int ttm_bo_pipeline_gutting(struct ttm_buffer_object *bo)
if (ret) if (ret)
ttm_bo_wait(bo, false, false); ttm_bo_wait(bo, false, false);
ttm_resource_alloc(bo, &sys_mem, bo->resource); ret = ttm_resource_alloc(bo, &sys_mem, &bo->resource);
bo->ttm = NULL; bo->ttm = NULL;
dma_resv_unlock(&ghost->base._resv); dma_resv_unlock(&ghost->base._resv);
ttm_bo_put(ghost); ttm_bo_put(ghost);
return 0; return ret;
} }
...@@ -27,10 +27,16 @@ ...@@ -27,10 +27,16 @@
int ttm_resource_alloc(struct ttm_buffer_object *bo, int ttm_resource_alloc(struct ttm_buffer_object *bo,
const struct ttm_place *place, const struct ttm_place *place,
struct ttm_resource *res) struct ttm_resource **res_ptr)
{ {
struct ttm_resource_manager *man = struct ttm_resource_manager *man =
ttm_manager_type(bo->bdev, place->mem_type); ttm_manager_type(bo->bdev, place->mem_type);
struct ttm_resource *res;
int r;
res = kmalloc(sizeof(*res), GFP_KERNEL);
if (!res)
return -ENOMEM;
res->mm_node = NULL; res->mm_node = NULL;
res->start = 0; res->start = 0;
...@@ -41,18 +47,27 @@ int ttm_resource_alloc(struct ttm_buffer_object *bo, ...@@ -41,18 +47,27 @@ int ttm_resource_alloc(struct ttm_buffer_object *bo,
res->bus.offset = 0; res->bus.offset = 0;
res->bus.is_iomem = false; res->bus.is_iomem = false;
res->bus.caching = ttm_cached; res->bus.caching = ttm_cached;
r = man->func->alloc(man, bo, place, res);
if (r) {
kfree(res);
return r;
}
return man->func->alloc(man, bo, place, res); *res_ptr = res;
return 0;
} }
void ttm_resource_free(struct ttm_buffer_object *bo, struct ttm_resource *res) void ttm_resource_free(struct ttm_buffer_object *bo, struct ttm_resource **res)
{ {
struct ttm_resource_manager *man = struct ttm_resource_manager *man;
ttm_manager_type(bo->bdev, res->mem_type);
man->func->free(man, res); if (!*res)
res->mm_node = NULL; return;
res->mem_type = TTM_PL_SYSTEM;
man = ttm_manager_type(bo->bdev, (*res)->mem_type);
man->func->free(man, *res);
kfree(*res);
*res = NULL;
} }
EXPORT_SYMBOL(ttm_resource_free); EXPORT_SYMBOL(ttm_resource_free);
......
...@@ -741,7 +741,7 @@ static int vmw_move(struct ttm_buffer_object *bo, ...@@ -741,7 +741,7 @@ static int vmw_move(struct ttm_buffer_object *bo,
goto fail; goto fail;
vmw_ttm_unbind(bo->bdev, bo->ttm); vmw_ttm_unbind(bo->bdev, bo->ttm);
ttm_resource_free(bo, bo->resource); ttm_resource_free(bo, &bo->resource);
ttm_bo_assign_mem(bo, new_mem); ttm_bo_assign_mem(bo, new_mem);
return 0; return 0;
} else { } else {
......
...@@ -137,7 +137,6 @@ struct ttm_buffer_object { ...@@ -137,7 +137,6 @@ struct ttm_buffer_object {
*/ */
struct ttm_resource *resource; struct ttm_resource *resource;
struct ttm_resource _mem;
struct ttm_tt *ttm; struct ttm_tt *ttm;
bool deleted; bool deleted;
......
...@@ -96,7 +96,7 @@ struct ttm_lru_bulk_move { ...@@ -96,7 +96,7 @@ struct ttm_lru_bulk_move {
*/ */
int ttm_bo_mem_space(struct ttm_buffer_object *bo, int ttm_bo_mem_space(struct ttm_buffer_object *bo,
struct ttm_placement *placement, struct ttm_placement *placement,
struct ttm_resource *mem, struct ttm_resource **mem,
struct ttm_operation_ctx *ctx); struct ttm_operation_ctx *ctx);
/** /**
...@@ -188,8 +188,8 @@ ttm_bo_move_to_lru_tail_unlocked(struct ttm_buffer_object *bo) ...@@ -188,8 +188,8 @@ ttm_bo_move_to_lru_tail_unlocked(struct ttm_buffer_object *bo)
static inline void ttm_bo_assign_mem(struct ttm_buffer_object *bo, static inline void ttm_bo_assign_mem(struct ttm_buffer_object *bo,
struct ttm_resource *new_mem) struct ttm_resource *new_mem)
{ {
bo->_mem = *new_mem; WARN_ON(bo->resource);
new_mem->mm_node = NULL; bo->resource = new_mem;
} }
/** /**
...@@ -202,9 +202,7 @@ static inline void ttm_bo_assign_mem(struct ttm_buffer_object *bo, ...@@ -202,9 +202,7 @@ static inline void ttm_bo_assign_mem(struct ttm_buffer_object *bo,
static inline void ttm_bo_move_null(struct ttm_buffer_object *bo, static inline void ttm_bo_move_null(struct ttm_buffer_object *bo,
struct ttm_resource *new_mem) struct ttm_resource *new_mem)
{ {
struct ttm_resource *old_mem = bo->resource; ttm_resource_free(bo, &bo->resource);
WARN_ON(old_mem->mm_node != NULL);
ttm_bo_assign_mem(bo, new_mem); ttm_bo_assign_mem(bo, new_mem);
} }
......
...@@ -225,8 +225,8 @@ ttm_resource_manager_cleanup(struct ttm_resource_manager *man) ...@@ -225,8 +225,8 @@ ttm_resource_manager_cleanup(struct ttm_resource_manager *man)
int ttm_resource_alloc(struct ttm_buffer_object *bo, int ttm_resource_alloc(struct ttm_buffer_object *bo,
const struct ttm_place *place, const struct ttm_place *place,
struct ttm_resource *res); struct ttm_resource **res);
void ttm_resource_free(struct ttm_buffer_object *bo, struct ttm_resource *res); void ttm_resource_free(struct ttm_buffer_object *bo, struct ttm_resource **res);
void ttm_resource_manager_init(struct ttm_resource_manager *man, void ttm_resource_manager_init(struct ttm_resource_manager *man,
unsigned long p_size); unsigned long p_size);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment