From: Matthew Wilcox <mawilcox@xxxxxxxxxxxxx> These IDRs were only being used to allocate unique numbers, not to look up pointers, so they can use the more space-efficient IDA instead. Signed-off-by: Matthew Wilcox <mawilcox@xxxxxxxxxxxxx> --- drivers/gpu/drm/vmwgfx/vmwgfx_drv.c | 6 +++--- drivers/gpu/drm/vmwgfx/vmwgfx_drv.h | 2 +- drivers/gpu/drm/vmwgfx/vmwgfx_resource.c | 28 ++++++++++------------------ 3 files changed, 14 insertions(+), 22 deletions(-) diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c index 184340d486c3..fc6e04cf071e 100644 --- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c @@ -652,7 +652,7 @@ static int vmw_driver_load(struct drm_device *dev, unsigned long chipset) spin_lock_init(&dev_priv->cursor_lock); for (i = vmw_res_context; i < vmw_res_max; ++i) { - idr_init(&dev_priv->res_idr[i]); + ida_init(&dev_priv->res_ida[i]); INIT_LIST_HEAD(&dev_priv->res_lru[i]); } @@ -950,7 +950,7 @@ static int vmw_driver_load(struct drm_device *dev, unsigned long chipset) vmw_ttm_global_release(dev_priv); out_err0: for (i = vmw_res_context; i < vmw_res_max; ++i) - idr_destroy(&dev_priv->res_idr[i]); + ida_destroy(&dev_priv->res_ida[i]); if (dev_priv->ctx.staged_bindings) vmw_binding_state_free(dev_priv->ctx.staged_bindings); @@ -1002,7 +1002,7 @@ static void vmw_driver_unload(struct drm_device *dev) vmw_ttm_global_release(dev_priv); for (i = vmw_res_context; i < vmw_res_max; ++i) - idr_destroy(&dev_priv->res_idr[i]); + ida_destroy(&dev_priv->res_ida[i]); kfree(dev_priv); } diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h index 7e5f30e234b1..96866a1e3547 100644 --- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h @@ -429,7 +429,7 @@ struct vmw_private { */ rwlock_t resource_lock; - struct idr res_idr[vmw_res_max]; + struct ida res_ida[vmw_res_max]; /* * Block lastclose from racing with firstopen. */ diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c b/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c index a96f90f017d1..ca0e2a1fd0c5 100644 --- a/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c @@ -80,13 +80,11 @@ vmw_resource_reference_unless_doomed(struct vmw_resource *res) void vmw_resource_release_id(struct vmw_resource *res) { struct vmw_private *dev_priv = res->dev_priv; - struct idr *idr = &dev_priv->res_idr[res->func->res_type]; + struct ida *ida = &dev_priv->res_ida[res->func->res_type]; - write_lock(&dev_priv->resource_lock); if (res->id != -1) - idr_remove(idr, res->id); + ida_simple_remove(ida, res->id); res->id = -1; - write_unlock(&dev_priv->resource_lock); } static void vmw_resource_release(struct kref *kref) @@ -95,7 +93,7 @@ static void vmw_resource_release(struct kref *kref) container_of(kref, struct vmw_resource, kref); struct vmw_private *dev_priv = res->dev_priv; int id; - struct idr *idr = &dev_priv->res_idr[res->func->res_type]; + struct ida *ida = &dev_priv->res_ida[res->func->res_type]; write_lock(&dev_priv->resource_lock); res->avail = false; @@ -132,10 +130,8 @@ static void vmw_resource_release(struct kref *kref) else kfree(res); - write_lock(&dev_priv->resource_lock); if (id != -1) - idr_remove(idr, id); - write_unlock(&dev_priv->resource_lock); + ida_simple_remove(ida, id); } void vmw_resource_unreference(struct vmw_resource **p_res) @@ -159,20 +155,16 @@ int vmw_resource_alloc_id(struct vmw_resource *res) { struct vmw_private *dev_priv = res->dev_priv; int ret; - struct idr *idr = &dev_priv->res_idr[res->func->res_type]; + struct ida *ida = &dev_priv->res_ida[res->func->res_type]; BUG_ON(res->id != -1); - idr_preload(GFP_KERNEL); - write_lock(&dev_priv->resource_lock); - - ret = idr_alloc(idr, res, 1, 0, GFP_NOWAIT); - if (ret >= 0) - res->id = ret; + ret = ida_simple_get(ida, 1, 0, GFP_KERNEL); + if (ret < 0) + return ret; - write_unlock(&dev_priv->resource_lock); - idr_preload_end(); - return ret < 0 ? ret : 0; + res->id = ret; + return 0; } /** -- 2.15.0