OSDN Git Service

freedreno: simplify device creation
authorRob Clark <robclark@freedesktop.org>
Fri, 28 Feb 2014 14:24:39 +0000 (09:24 -0500)
committerRob Clark <robclark@freedesktop.org>
Wed, 5 Mar 2014 14:39:35 +0000 (09:39 -0500)
Signed-off-by: Rob Clark <robclark@freedesktop.org>
freedreno/freedreno_device.c
freedreno/kgsl/kgsl_bo.c

index 23e086b..532e65b 100644 (file)
@@ -34,7 +34,6 @@
 #include "freedreno_priv.h"
 
 static pthread_mutex_t table_lock = PTHREAD_MUTEX_INITIALIZER;
-static void * dev_table;
 
 struct fd_device * kgsl_device_new(int fd);
 struct fd_device * msm_device_new(int fd);
@@ -77,7 +76,7 @@ init_cache_buckets(struct fd_device *dev)
        }
 }
 
-static struct fd_device * fd_device_new_impl(int fd)
+struct fd_device * fd_device_new(int fd)
 {
        struct fd_device *dev;
        drmVersionPtr version;
@@ -112,29 +111,6 @@ static struct fd_device * fd_device_new_impl(int fd)
        return dev;
 }
 
-struct fd_device * fd_device_new(int fd)
-{
-       struct fd_device *dev = NULL;
-       int key = fd;
-
-       pthread_mutex_lock(&table_lock);
-
-       if (!dev_table)
-               dev_table = drmHashCreate();
-
-       if (drmHashLookup(dev_table, key, (void **)&dev)) {
-               dev = fd_device_new_impl(fd);
-               if (dev)
-                       drmHashInsert(dev_table, key, dev);
-       } else {
-               dev = fd_device_ref(dev);
-       }
-
-       pthread_mutex_unlock(&table_lock);
-
-       return dev;
-}
-
 /* like fd_device_new() but creates it's own private dup() of the fd
  * which is close()d when the device is finalized.
  */
@@ -156,7 +132,6 @@ static void fd_device_del_impl(struct fd_device *dev)
        fd_cleanup_bo_cache(dev, 0);
        drmHashDestroy(dev->handle_table);
        drmHashDestroy(dev->name_table);
-       drmHashDelete(dev_table, dev->fd);
        if (dev->closefd)
                close(dev->fd);
        dev->funcs->destroy(dev);
index 76d1f27..dd7b612 100644 (file)
@@ -222,7 +222,6 @@ fail:
        return NULL;
 }
 
-
 uint32_t kgsl_bo_gpuaddr(struct kgsl_bo *kgsl_bo, uint32_t offset)
 {
        struct fd_bo *bo = &kgsl_bo->base;