Commit 94e89532 authored by Daniel Vetter's avatar Daniel Vetter

drm/sman: kill user_hash_tab

No longer used.
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
parent 6de8a748
...@@ -47,7 +47,6 @@ struct drm_owner_item { ...@@ -47,7 +47,6 @@ struct drm_owner_item {
void drm_sman_takedown(struct drm_sman * sman) void drm_sman_takedown(struct drm_sman * sman)
{ {
drm_ht_remove(&sman->user_hash_tab);
kfree(sman->mm); kfree(sman->mm);
} }
...@@ -62,16 +61,11 @@ drm_sman_init(struct drm_sman * sman, unsigned int num_managers, ...@@ -62,16 +61,11 @@ drm_sman_init(struct drm_sman * sman, unsigned int num_managers,
sman->mm = kcalloc(num_managers, sizeof(*sman->mm), GFP_KERNEL); sman->mm = kcalloc(num_managers, sizeof(*sman->mm), GFP_KERNEL);
if (!sman->mm) { if (!sman->mm) {
ret = -ENOMEM; ret = -ENOMEM;
goto out; return ret;
} }
sman->num_managers = num_managers; sman->num_managers = num_managers;
ret = drm_ht_create(&sman->user_hash_tab, user_order);
if (!ret)
goto out;
kfree(sman->mm); return 0;
out:
return ret;
} }
EXPORT_SYMBOL(drm_sman_init); EXPORT_SYMBOL(drm_sman_init);
...@@ -180,15 +174,8 @@ struct drm_memblock_item *drm_sman_alloc(struct drm_sman *sman, unsigned int man ...@@ -180,15 +174,8 @@ struct drm_memblock_item *drm_sman_alloc(struct drm_sman *sman, unsigned int man
memblock->mm = sman_mm; memblock->mm = sman_mm;
memblock->sman = sman; memblock->sman = sman;
if (drm_ht_just_insert_please
(&sman->user_hash_tab, &memblock->user_hash,
(unsigned long)memblock, 32, 0, 0))
goto out1;
return memblock; return memblock;
out1:
kfree(memblock);
out: out:
sman_mm->free(sman_mm->private, tmp); sman_mm->free(sman_mm->private, tmp);
...@@ -199,31 +186,12 @@ EXPORT_SYMBOL(drm_sman_alloc); ...@@ -199,31 +186,12 @@ EXPORT_SYMBOL(drm_sman_alloc);
void drm_sman_free(struct drm_memblock_item *item) void drm_sman_free(struct drm_memblock_item *item)
{ {
struct drm_sman *sman = item->sman;
list_del(&item->owner_list); list_del(&item->owner_list);
drm_ht_remove_item(&sman->user_hash_tab, &item->user_hash);
item->mm->free(item->mm->private, item->mm_info); item->mm->free(item->mm->private, item->mm_info);
kfree(item); kfree(item);
} }
EXPORT_SYMBOL(drm_sman_free); EXPORT_SYMBOL(drm_sman_free);
int drm_sman_free_key(struct drm_sman *sman, unsigned int key)
{
struct drm_hash_item *hash_item;
struct drm_memblock_item *memblock_item;
if (drm_ht_find_item(&sman->user_hash_tab, key, &hash_item))
return -EINVAL;
memblock_item = drm_hash_entry(hash_item, struct drm_memblock_item,
user_hash);
drm_sman_free(memblock_item);
return 0;
}
EXPORT_SYMBOL(drm_sman_free_key);
void drm_sman_cleanup(struct drm_sman *sman) void drm_sman_cleanup(struct drm_sman *sman)
{ {
unsigned int i; unsigned int i;
......
...@@ -87,7 +87,6 @@ struct drm_memblock_item { ...@@ -87,7 +87,6 @@ struct drm_memblock_item {
struct drm_sman { struct drm_sman {
struct drm_sman_mm *mm; struct drm_sman_mm *mm;
int num_managers; int num_managers;
struct drm_open_hash user_hash_tab;
}; };
/* /*
...@@ -139,11 +138,7 @@ extern struct drm_memblock_item *drm_sman_alloc(struct drm_sman * sman, ...@@ -139,11 +138,7 @@ extern struct drm_memblock_item *drm_sman_alloc(struct drm_sman * sman,
unsigned long size, unsigned long size,
unsigned alignment, unsigned alignment,
unsigned long owner); unsigned long owner);
/*
* Free a memory block identified by its user hash key.
*/
extern int drm_sman_free_key(struct drm_sman * sman, unsigned int key);
extern void drm_sman_free(struct drm_memblock_item *item); extern void drm_sman_free(struct drm_memblock_item *item);
/* /*
......
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