*/
        replacement = dma_fence_get_stub();
        dma_resv_replace_fences(bo->tbo.base.resv, ef->base.context,
-                               replacement, DMA_RESV_USAGE_READ);
+                               replacement, DMA_RESV_USAGE_BOOKKEEP);
        dma_fence_put(replacement);
        return 0;
 }
        ret = dma_resv_reserve_fences(vm->root.bo->tbo.base.resv, 1);
        if (ret)
                goto reserve_shared_fail;
-       amdgpu_bo_fence(vm->root.bo,
-                       &vm->process_info->eviction_fence->base, true);
+       dma_resv_add_fence(vm->root.bo->tbo.base.resv,
+                          &vm->process_info->eviction_fence->base,
+                          DMA_RESV_USAGE_BOOKKEEP);
        amdgpu_bo_unreserve(vm->root.bo);
 
        /* Update process info */
        }
 
        if (!amdgpu_ttm_tt_get_usermm(bo->tbo.ttm) && !bo->tbo.pin_count)
-               amdgpu_bo_fence(bo,
-                               &avm->process_info->eviction_fence->base,
-                               true);
+               dma_resv_add_fence(bo->tbo.base.resv,
+                                  &avm->process_info->eviction_fence->base,
+                                  DMA_RESV_USAGE_BOOKKEEP);
        ret = unreserve_bo_and_vms(&ctx, false, false);
 
        goto out;
                if (mem->bo->tbo.pin_count)
                        continue;
 
-               amdgpu_bo_fence(mem->bo,
-                       &process_info->eviction_fence->base, true);
+               dma_resv_add_fence(mem->bo->tbo.base.resv,
+                                  &process_info->eviction_fence->base,
+                                  DMA_RESV_USAGE_BOOKKEEP);
        }
        /* Attach eviction fence to PD / PT BOs */
        list_for_each_entry(peer_vm, &process_info->vm_list_head,
                            vm_list_node) {
                struct amdgpu_bo *bo = peer_vm->root.bo;
 
-               amdgpu_bo_fence(bo, &process_info->eviction_fence->base, true);
+               dma_resv_add_fence(bo->tbo.base.resv,
+                                  &process_info->eviction_fence->base,
+                                  DMA_RESV_USAGE_BOOKKEEP);
        }
 
 validate_map_fail:
        ret = dma_resv_reserve_fences(gws_bo->tbo.base.resv, 1);
        if (ret)
                goto reserve_shared_fail;
-       amdgpu_bo_fence(gws_bo, &process_info->eviction_fence->base, true);
+       dma_resv_add_fence(gws_bo->tbo.base.resv,
+                          &process_info->eviction_fence->base,
+                          DMA_RESV_USAGE_BOOKKEEP);
        amdgpu_bo_unreserve(gws_bo);
        mutex_unlock(&(*mem)->process_info->lock);