On Wed, Dec 11, 2019 at 07:08:31PM +0100, Thomas Zimmermann wrote:
> TTM is an implementation detail of the VRAM helpers and therefore
> shouldn't be exposed to the callers. There's only one correct value
> for the BO device anyway, which is the one stored in the DRM device.
> 
> So remove struct ttm_bo_device from the VRAM-helper interface and
> use the device's VRAM manager unconditionally. The GEM initializer
> function fails if the VRAM manager has not been initialized.
> 
> Signed-off-by: Thomas Zimmermann <[email protected]>

If/when someone is really bored I think might be really nice to create
something like drm_device.gem (or .mm) like we have for
drm_device.mode_config ... drm_device is an unwieldy monster.

Reviewed-by: Daniel Vetter <[email protected]>

> ---
>  drivers/gpu/drm/ast/ast_mode.c              |  3 +--
>  drivers/gpu/drm/drm_gem_vram_helper.c       | 21 +++++++++------------
>  drivers/gpu/drm/hisilicon/hibmc/hibmc_ttm.c |  2 +-
>  drivers/gpu/drm/mgag200/mgag200_cursor.c    |  3 +--
>  drivers/gpu/drm/mgag200/mgag200_drv.c       |  3 +--
>  include/drm/drm_gem_vram_helper.h           |  2 --
>  6 files changed, 13 insertions(+), 21 deletions(-)
> 
> diff --git a/drivers/gpu/drm/ast/ast_mode.c b/drivers/gpu/drm/ast/ast_mode.c
> index 26336642dd59..f4fbdab29bb7 100644
> --- a/drivers/gpu/drm/ast/ast_mode.c
> +++ b/drivers/gpu/drm/ast/ast_mode.c
> @@ -1144,8 +1144,7 @@ static int ast_cursor_init(struct drm_device *dev)
>       size = roundup(AST_HWC_SIZE + AST_HWC_SIGNATURE_SIZE, PAGE_SIZE);
>  
>       for (i = 0; i < ARRAY_SIZE(ast->cursor.gbo); ++i) {
> -             gbo = drm_gem_vram_create(dev, &dev->vram_mm->bdev,
> -                                       size, 0);
> +             gbo = drm_gem_vram_create(dev, size, 0);
>               if (IS_ERR(gbo)) {
>                       ret = PTR_ERR(gbo);
>                       goto err_drm_gem_vram_put;
> diff --git a/drivers/gpu/drm/drm_gem_vram_helper.c 
> b/drivers/gpu/drm/drm_gem_vram_helper.c
> index 4908f1281002..b760fd27f3c0 100644
> --- a/drivers/gpu/drm/drm_gem_vram_helper.c
> +++ b/drivers/gpu/drm/drm_gem_vram_helper.c
> @@ -92,13 +92,18 @@ static void drm_gem_vram_placement(struct 
> drm_gem_vram_object *gbo,
>  }
>  
>  static int drm_gem_vram_init(struct drm_device *dev,
> -                          struct ttm_bo_device *bdev,
>                            struct drm_gem_vram_object *gbo,
>                            size_t size, unsigned long pg_align)
>  {
> +     struct drm_vram_mm *vmm = dev->vram_mm;
> +     struct ttm_bo_device *bdev;
>       int ret;
>       size_t acc_size;
>  
> +     if (WARN_ONCE(!vmm, "VRAM MM not initialized"))
> +             return -EINVAL;
> +     bdev = &vmm->bdev;
> +
>       gbo->bo.base.funcs = &drm_gem_vram_object_funcs;
>  
>       ret = drm_gem_object_init(dev, &gbo->bo.base, size);
> @@ -126,7 +131,6 @@ static int drm_gem_vram_init(struct drm_device *dev,
>  /**
>   * drm_gem_vram_create() - Creates a VRAM-backed GEM object
>   * @dev:             the DRM device
> - * @bdev:            the TTM BO device backing the object
>   * @size:            the buffer size in bytes
>   * @pg_align:                the buffer's alignment in multiples of the page 
> size
>   *
> @@ -135,7 +139,6 @@ static int drm_gem_vram_init(struct drm_device *dev,
>   * an ERR_PTR()-encoded error code otherwise.
>   */
>  struct drm_gem_vram_object *drm_gem_vram_create(struct drm_device *dev,
> -                                             struct ttm_bo_device *bdev,
>                                               size_t size,
>                                               unsigned long pg_align)
>  {
> @@ -146,7 +149,7 @@ struct drm_gem_vram_object *drm_gem_vram_create(struct 
> drm_device *dev,
>       if (!gbo)
>               return ERR_PTR(-ENOMEM);
>  
> -     ret = drm_gem_vram_init(dev, bdev, gbo, size, pg_align);
> +     ret = drm_gem_vram_init(dev, gbo, size, pg_align);
>       if (ret < 0)
>               goto err_kfree;
>  
> @@ -480,7 +483,6 @@ EXPORT_SYMBOL(drm_gem_vram_vunmap);
>       Helper for implementing &struct drm_driver.dumb_create
>   * @file:            the DRM file
>   * @dev:             the DRM device
> - * @bdev:            the TTM BO device managing the buffer object
>   * @pg_align:                the buffer's alignment in multiples of the page 
> size
>   * @args:            the arguments as provided to \
>                               &struct drm_driver.dumb_create
> @@ -496,7 +498,6 @@ EXPORT_SYMBOL(drm_gem_vram_vunmap);
>   */
>  int drm_gem_vram_fill_create_dumb(struct drm_file *file,
>                                 struct drm_device *dev,
> -                               struct ttm_bo_device *bdev,
>                                 unsigned long pg_align,
>                                 struct drm_mode_create_dumb *args)
>  {
> @@ -512,7 +513,7 @@ int drm_gem_vram_fill_create_dumb(struct drm_file *file,
>       if (!size)
>               return -EINVAL;
>  
> -     gbo = drm_gem_vram_create(dev, bdev, size, pg_align);
> +     gbo = drm_gem_vram_create(dev, size, pg_align);
>       if (IS_ERR(gbo))
>               return PTR_ERR(gbo);
>  
> @@ -604,11 +605,7 @@ int drm_gem_vram_driver_dumb_create(struct drm_file 
> *file,
>                                   struct drm_device *dev,
>                                   struct drm_mode_create_dumb *args)
>  {
> -     if (WARN_ONCE(!dev->vram_mm, "VRAM MM not initialized"))
> -             return -EINVAL;
> -
> -     return drm_gem_vram_fill_create_dumb(file, dev, &dev->vram_mm->bdev, 0,
> -                                          args);
> +     return drm_gem_vram_fill_create_dumb(file, dev, 0, args);
>  }
>  EXPORT_SYMBOL(drm_gem_vram_driver_dumb_create);
>  
> diff --git a/drivers/gpu/drm/hisilicon/hibmc/hibmc_ttm.c 
> b/drivers/gpu/drm/hisilicon/hibmc/hibmc_ttm.c
> index 16f5cd2c1b3b..4a5bde80045a 100644
> --- a/drivers/gpu/drm/hisilicon/hibmc/hibmc_ttm.c
> +++ b/drivers/gpu/drm/hisilicon/hibmc/hibmc_ttm.c
> @@ -58,7 +58,7 @@ int hibmc_gem_create(struct drm_device *dev, u32 size, bool 
> iskernel,
>       if (size == 0)
>               return -EINVAL;
>  
> -     gbo = drm_gem_vram_create(dev, &dev->vram_mm->bdev, size, 0);
> +     gbo = drm_gem_vram_create(dev, size, 0);
>       if (IS_ERR(gbo)) {
>               ret = PTR_ERR(gbo);
>               if (ret != -ERESTARTSYS)
> diff --git a/drivers/gpu/drm/mgag200/mgag200_cursor.c 
> b/drivers/gpu/drm/mgag200/mgag200_cursor.c
> index dd54fd507e13..d491edd317ff 100644
> --- a/drivers/gpu/drm/mgag200/mgag200_cursor.c
> +++ b/drivers/gpu/drm/mgag200/mgag200_cursor.c
> @@ -208,8 +208,7 @@ int mgag200_cursor_init(struct mga_device *mdev)
>               return -ENOMEM;
>  
>       for (i = 0; i < ncursors; ++i) {
> -             gbo = drm_gem_vram_create(dev, &dev->vram_mm->bdev,
> -                                       size, 0);
> +             gbo = drm_gem_vram_create(dev, size, 0);
>               if (IS_ERR(gbo)) {
>                       ret = PTR_ERR(gbo);
>                       goto err_drm_gem_vram_put;
> diff --git a/drivers/gpu/drm/mgag200/mgag200_drv.c 
> b/drivers/gpu/drm/mgag200/mgag200_drv.c
> index dc125838f5d1..1b5b60da2e62 100644
> --- a/drivers/gpu/drm/mgag200/mgag200_drv.c
> +++ b/drivers/gpu/drm/mgag200/mgag200_drv.c
> @@ -120,8 +120,7 @@ int mgag200_driver_dumb_create(struct drm_file *file,
>       if (mgag200_pin_bo_at_0(mdev))
>               pg_align = PFN_UP(mdev->mc.vram_size);
>  
> -     return drm_gem_vram_fill_create_dumb(file, dev, &dev->vram_mm->bdev,
> -                                          pg_align, args);
> +     return drm_gem_vram_fill_create_dumb(file, dev, pg_align, args);
>  }
>  
>  static struct drm_driver driver = {
> diff --git a/include/drm/drm_gem_vram_helper.h 
> b/include/drm/drm_gem_vram_helper.h
> index 90736427285e..9341f54383b3 100644
> --- a/include/drm/drm_gem_vram_helper.h
> +++ b/include/drm/drm_gem_vram_helper.h
> @@ -93,7 +93,6 @@ static inline struct drm_gem_vram_object 
> *drm_gem_vram_of_gem(
>  }
>  
>  struct drm_gem_vram_object *drm_gem_vram_create(struct drm_device *dev,
> -                                             struct ttm_bo_device *bdev,
>                                               size_t size,
>                                               unsigned long pg_align);
>  void drm_gem_vram_put(struct drm_gem_vram_object *gbo);
> @@ -109,7 +108,6 @@ void drm_gem_vram_vunmap(struct drm_gem_vram_object *gbo, 
> void *vaddr);
>  
>  int drm_gem_vram_fill_create_dumb(struct drm_file *file,
>                                 struct drm_device *dev,
> -                               struct ttm_bo_device *bdev,
>                                 unsigned long pg_align,
>                                 struct drm_mode_create_dumb *args);
>  
> -- 
> 2.24.0
> 

-- 
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch
_______________________________________________
dri-devel mailing list
[email protected]
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to