[PATCH 02/11] drm/ttm: cleanup io_mem interface with nouveau

daniel at ffwll.ch daniel at ffwll.ch
Tue Jul 21 08:50:32 UTC 2020


On Tue, Jul 21, 2020 at 09:32:36AM +0200, Christian König wrote:
> Nouveau is the only user of this functionality and evicting io space
> on -EAGAIN is really a misuse of the return code.
> 
> Instead switch to using -ENOSPC here which makes much more sense and
> simplifies the code.
> 
> Signed-off-by: Christian König <christian.koenig at amd.com>

Going from EAGAIN to something else could unbreak something that's held
together as a almost livelock restarting ioctls or whatever. So I looked
for that a bit:

- mmap path seems fine, all errors from the io_reserve stuff here get
  remapped to sigbus

- but everywhere else we just pass down the errno it seems, and nouveau
  has a bunch of kmaps all around (gpu relocs on pre-nv50 is probably the
  big one, if we ignore the memcpy bo move fallback). I haven't found
  anything that indicates those chips don't have the ioremapping hw, so
  there's some risk I think. Otoh I also don't see anything that would
  unbreak the lifelook, so feels minimally.

With that impact to pushbuf ioctl documented in the commit message somehow
this is Reviewed-by: Daniel Vetter <daniel.vetter at ffwll.ch>

> ---
>  drivers/gpu/drm/nouveau/nouveau_bo.c | 2 --
>  drivers/gpu/drm/ttm/ttm_bo_util.c    | 4 ++--
>  2 files changed, 2 insertions(+), 4 deletions(-)
> 
> diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.c b/drivers/gpu/drm/nouveau/nouveau_bo.c
> index 61355cfb7335..a48652826f67 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_bo.c
> +++ b/drivers/gpu/drm/nouveau/nouveau_bo.c
> @@ -1505,8 +1505,6 @@ nouveau_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_mem_reg *reg)
>  			if (ret != 1) {
>  				if (WARN_ON(ret == 0))
>  					return -EINVAL;
> -				if (ret == -ENOSPC)
> -					return -EAGAIN;
>  				return ret;
>  			}
>  
> diff --git a/drivers/gpu/drm/ttm/ttm_bo_util.c b/drivers/gpu/drm/ttm/ttm_bo_util.c
> index 5e0f3a9caedc..7d2c50fef456 100644
> --- a/drivers/gpu/drm/ttm/ttm_bo_util.c
> +++ b/drivers/gpu/drm/ttm/ttm_bo_util.c
> @@ -116,7 +116,7 @@ static int ttm_mem_io_evict(struct ttm_mem_type_manager *man)
>  	struct ttm_buffer_object *bo;
>  
>  	if (!man->use_io_reserve_lru || list_empty(&man->io_reserve_lru))
> -		return -EAGAIN;
> +		return -ENOSPC;
>  
>  	bo = list_first_entry(&man->io_reserve_lru,
>  			      struct ttm_buffer_object,
> @@ -143,7 +143,7 @@ int ttm_mem_io_reserve(struct ttm_bo_device *bdev,
>  	    mem->bus.io_reserved_count++ == 0) {
>  retry:
>  		ret = bdev->driver->io_mem_reserve(bdev, mem);
> -		if (ret == -EAGAIN) {
> +		if (ret == -ENOSPC) {
>  			ret = ttm_mem_io_evict(man);
>  			if (ret == 0)
>  				goto retry;
> -- 
> 2.17.1
> 
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/dri-devel

-- 
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch


More information about the dri-devel mailing list