From: Sui Jingfeng <suijingf...@loongson.cn>

The instance of struct drm_device and struct etnaviv_drm_private are
intended to be shared by all GPU cores. Embedding struct drm_device into
struct etnaviv_drm_private allow us to allocate storage for them togather.
And use container_of() to retrieve pointer for the containing structure.

Signed-off-by: Sui Jingfeng <suijingf...@loongson.cn>
---
 drivers/gpu/drm/etnaviv/etnaviv_drv.c        | 73 +++++++++-----------
 drivers/gpu/drm/etnaviv/etnaviv_drv.h        |  8 ++-
 drivers/gpu/drm/etnaviv/etnaviv_gem.c        |  6 +-
 drivers/gpu/drm/etnaviv/etnaviv_gem_submit.c |  2 +-
 drivers/gpu/drm/etnaviv/etnaviv_gpu.c        |  6 +-
 drivers/gpu/drm/etnaviv/etnaviv_mmu.c        |  4 +-
 6 files changed, 47 insertions(+), 52 deletions(-)

diff --git a/drivers/gpu/drm/etnaviv/etnaviv_drv.c 
b/drivers/gpu/drm/etnaviv/etnaviv_drv.c
index 883352aded32..4a7a451237d5 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_drv.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_drv.c
@@ -45,14 +45,9 @@ static struct device_node 
*etnaviv_of_first_available_node(void)
        return NULL;
 }
 
-static struct etnaviv_drm_private *etnaviv_alloc_private(struct device *dev)
+static int etnaviv_private_init(struct device *dev,
+                               struct etnaviv_drm_private *priv)
 {
-       struct etnaviv_drm_private *priv;
-
-       priv = kzalloc(sizeof(*priv), GFP_KERNEL);
-       if (!priv)
-               return ERR_PTR(-ENOMEM);
-
        xa_init_flags(&priv->active_contexts, XA_FLAGS_ALLOC);
 
        mutex_init(&priv->gem_lock);
@@ -62,17 +57,16 @@ static struct etnaviv_drm_private 
*etnaviv_alloc_private(struct device *dev)
 
        priv->cmdbuf_suballoc = etnaviv_cmdbuf_suballoc_new(dev);
        if (IS_ERR(priv->cmdbuf_suballoc)) {
-               kfree(priv);
                dev_err(dev, "Failed to create cmdbuf suballocator\n");
-               return ERR_PTR(-ENOMEM);
+               return -ENOMEM;
        }
 
        priv->cached_coherent = dev_is_dma_coherent(dev);
 
-       return priv;
+       return 0;
 }
 
-static void etnaviv_free_private(struct etnaviv_drm_private *priv)
+static void etnaviv_private_fini(struct etnaviv_drm_private *priv)
 {
        if (!priv)
                return;
@@ -80,13 +74,11 @@ static void etnaviv_free_private(struct etnaviv_drm_private 
*priv)
        etnaviv_cmdbuf_suballoc_destroy(priv->cmdbuf_suballoc);
 
        xa_destroy(&priv->active_contexts);
-
-       kfree(priv);
 }
 
 static void load_gpu(struct drm_device *dev)
 {
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        unsigned int i;
 
        for (i = 0; i < ETNA_MAX_PIPES; i++) {
@@ -104,7 +96,7 @@ static void load_gpu(struct drm_device *dev)
 
 static int etnaviv_open(struct drm_device *dev, struct drm_file *file)
 {
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        struct etnaviv_file_private *ctx;
        int ret, i;
 
@@ -147,7 +139,7 @@ static int etnaviv_open(struct drm_device *dev, struct 
drm_file *file)
 
 static void etnaviv_postclose(struct drm_device *dev, struct drm_file *file)
 {
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        struct etnaviv_file_private *ctx = file->driver_priv;
        unsigned int i;
 
@@ -172,7 +164,7 @@ static void etnaviv_postclose(struct drm_device *dev, 
struct drm_file *file)
 #ifdef CONFIG_DEBUG_FS
 static int etnaviv_gem_show(struct drm_device *dev, struct seq_file *m)
 {
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
 
        etnaviv_gem_describe_objects(priv, m);
 
@@ -266,7 +258,7 @@ static int show_each_gpu(struct seq_file *m, void *arg)
 {
        struct drm_info_node *node = (struct drm_info_node *) m->private;
        struct drm_device *dev = node->minor->dev;
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        struct etnaviv_gpu *gpu;
        int (*show)(struct etnaviv_gpu *gpu, struct seq_file *m) =
                        node->info_ent->data;
@@ -309,7 +301,7 @@ static void etnaviv_debugfs_init(struct drm_minor *minor)
 static int etnaviv_ioctl_get_param(struct drm_device *dev, void *data,
                struct drm_file *file)
 {
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        struct drm_etnaviv_param *args = data;
        struct etnaviv_gpu *gpu;
 
@@ -402,7 +394,7 @@ static int etnaviv_ioctl_wait_fence(struct drm_device *dev, 
void *data,
                struct drm_file *file)
 {
        struct drm_etnaviv_wait_fence *args = data;
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        struct drm_etnaviv_timespec *timeout = &args->timeout;
        struct etnaviv_gpu *gpu;
 
@@ -450,7 +442,7 @@ static int etnaviv_ioctl_gem_userptr(struct drm_device 
*dev, void *data,
 static int etnaviv_ioctl_gem_wait(struct drm_device *dev, void *data,
        struct drm_file *file)
 {
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        struct drm_etnaviv_gem_wait *args = data;
        struct drm_etnaviv_timespec *timeout = &args->timeout;
        struct drm_gem_object *obj;
@@ -484,7 +476,7 @@ static int etnaviv_ioctl_gem_wait(struct drm_device *dev, 
void *data,
 static int etnaviv_ioctl_pm_query_dom(struct drm_device *dev, void *data,
        struct drm_file *file)
 {
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        struct drm_etnaviv_pm_domain *args = data;
        struct etnaviv_gpu *gpu;
 
@@ -501,7 +493,7 @@ static int etnaviv_ioctl_pm_query_dom(struct drm_device 
*dev, void *data,
 static int etnaviv_ioctl_pm_query_sig(struct drm_device *dev, void *data,
        struct drm_file *file)
 {
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        struct drm_etnaviv_pm_signal *args = data;
        struct etnaviv_gpu *gpu;
 
@@ -557,20 +549,18 @@ int etnaviv_drm_bind(struct device *dev, bool component)
        struct drm_device *drm;
        int ret;
 
-       drm = drm_dev_alloc(&etnaviv_drm_driver, dev);
-       if (IS_ERR(drm))
-               return PTR_ERR(drm);
+       priv = devm_drm_dev_alloc(dev, &etnaviv_drm_driver,
+                                 struct etnaviv_drm_private, drm);
 
-       priv = etnaviv_alloc_private(dev);
-       if (IS_ERR(priv)) {
-               ret = PTR_ERR(priv);
-               goto out_put;
-       }
+       if (IS_ERR(priv))
+               return PTR_ERR(priv);
+
+       etnaviv_private_init(dev, priv);
 
-       priv->drm = drm;
-       drm->dev_private = priv;
        etna_drm_priv_ptr = priv;
 
+       drm = &priv->drm;
+
        dma_set_max_seg_size(dev, SZ_2G);
 
        if (component)
@@ -595,9 +585,7 @@ int etnaviv_drm_bind(struct device *dev, bool component)
        else
                etnaviv_gpu_unbind(dev, NULL, drm);
 out_free_priv:
-       etnaviv_free_private(priv);
-out_put:
-       drm_dev_put(drm);
+       etnaviv_private_fini(priv);
 
        return ret;
 }
@@ -605,7 +593,12 @@ int etnaviv_drm_bind(struct device *dev, bool component)
 void etnaviv_drm_unbind(struct device *dev, bool component)
 {
        struct etnaviv_drm_private *priv = etna_drm_priv_ptr;
-       struct drm_device *drm = priv->drm;
+       struct drm_device *drm;
+
+       if (!priv)
+               return;
+
+       drm = &priv->drm;
 
        drm_dev_unregister(drm);
 
@@ -614,11 +607,7 @@ void etnaviv_drm_unbind(struct device *dev, bool component)
        else
                etnaviv_gpu_unbind(dev, NULL, drm);
 
-       etnaviv_free_private(priv);
-
-       drm->dev_private = NULL;
-
-       drm_dev_put(drm);
+       etnaviv_private_fini(priv);
 }
 
 /*
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_drv.h 
b/drivers/gpu/drm/etnaviv/etnaviv_drv.h
index acc2e77ad2db..6c9d934cbcbd 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_drv.h
+++ b/drivers/gpu/drm/etnaviv/etnaviv_drv.h
@@ -35,7 +35,7 @@ struct etnaviv_file_private {
 };
 
 struct etnaviv_drm_private {
-       struct drm_device *drm;
+       struct drm_device drm;
        int num_gpus;
        struct etnaviv_gpu *gpu[ETNA_MAX_PIPES];
        gfp_t shm_gfp_mask;
@@ -60,6 +60,12 @@ struct etnaviv_drm_private {
        struct list_head gem_list;
 };
 
+static inline struct etnaviv_drm_private *
+to_etnaviv_priv(struct drm_device *ddev)
+{
+       return container_of(ddev, struct etnaviv_drm_private, drm);
+}
+
 int etnaviv_ioctl_gem_submit(struct drm_device *dev, void *data,
                struct drm_file *file);
 
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_gem.c 
b/drivers/gpu/drm/etnaviv/etnaviv_gem.c
index a72ca0a6883e..eed98bb9e446 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_gem.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_gem.c
@@ -498,7 +498,7 @@ static const struct etnaviv_gem_ops etnaviv_gem_shmem_ops = 
{
 void etnaviv_gem_free_object(struct drm_gem_object *obj)
 {
        struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
-       struct etnaviv_drm_private *priv = obj->dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(obj->dev);
        struct etnaviv_vram_mapping *mapping, *tmp;
 
        /* object should not be active */
@@ -529,7 +529,7 @@ void etnaviv_gem_free_object(struct drm_gem_object *obj)
 
 void etnaviv_gem_obj_add(struct drm_device *dev, struct drm_gem_object *obj)
 {
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
 
        mutex_lock(&priv->gem_lock);
@@ -596,7 +596,7 @@ static int etnaviv_gem_new_impl(struct drm_device *dev, u32 
flags,
 int etnaviv_gem_new_handle(struct drm_device *dev, struct drm_file *file,
        u32 size, u32 flags, u32 *handle)
 {
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        struct drm_gem_object *obj = NULL;
        int ret;
 
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_gem_submit.c 
b/drivers/gpu/drm/etnaviv/etnaviv_gem_submit.c
index 3d0f8d182506..6b40a39fb8cd 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_gem_submit.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_gem_submit.c
@@ -413,7 +413,7 @@ int etnaviv_ioctl_gem_submit(struct drm_device *dev, void 
*data,
                struct drm_file *file)
 {
        struct etnaviv_file_private *ctx = file->driver_priv;
-       struct etnaviv_drm_private *priv = dev->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(dev);
        struct drm_etnaviv_gem_submit *args = data;
        struct drm_etnaviv_gem_submit_reloc *relocs;
        struct drm_etnaviv_gem_submit_pmr *pmrs;
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_gpu.c 
b/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
index c5a6d5809e2b..070650ac38ed 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
@@ -38,7 +38,7 @@ static const struct platform_device_id gpu_ids[] = {
 
 int etnaviv_gpu_get_param(struct etnaviv_gpu *gpu, u32 param, u64 *value)
 {
-       struct etnaviv_drm_private *priv = gpu->drm->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(gpu->drm);
 
        switch (param) {
        case ETNAVIV_PARAM_GPU_MODEL:
@@ -785,7 +785,7 @@ static void etnaviv_gpu_hw_init(struct etnaviv_gpu *gpu)
 
 int etnaviv_gpu_init(struct etnaviv_gpu *gpu)
 {
-       struct etnaviv_drm_private *priv = gpu->drm->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(gpu->drm);
        dma_addr_t cmdbuf_paddr;
        int ret, i;
 
@@ -1774,7 +1774,7 @@ static const struct thermal_cooling_device_ops 
cooling_ops = {
 int etnaviv_gpu_bind(struct device *dev, struct device *master, void *data)
 {
        struct drm_device *drm = data;
-       struct etnaviv_drm_private *priv = drm->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(drm);
        struct etnaviv_gpu *gpu = dev_get_drvdata(dev);
        int ret;
 
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_mmu.c 
b/drivers/gpu/drm/etnaviv/etnaviv_mmu.c
index 1661d589bf3e..c38272868328 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_mmu.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_mmu.c
@@ -490,7 +490,7 @@ void etnaviv_iommu_dump(struct etnaviv_iommu_context 
*context, void *buf)
 int etnaviv_iommu_global_init(struct etnaviv_gpu *gpu)
 {
        enum etnaviv_iommu_version version = ETNAVIV_IOMMU_V1;
-       struct etnaviv_drm_private *priv = gpu->drm->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(gpu->drm);
        struct etnaviv_iommu_global *global;
        struct device *dev = gpu->drm->dev;
 
@@ -550,7 +550,7 @@ int etnaviv_iommu_global_init(struct etnaviv_gpu *gpu)
 
 void etnaviv_iommu_global_fini(struct etnaviv_gpu *gpu)
 {
-       struct etnaviv_drm_private *priv = gpu->drm->dev_private;
+       struct etnaviv_drm_private *priv = to_etnaviv_priv(gpu->drm);
        struct etnaviv_iommu_global *global = priv->mmu_global;
 
        if (!global)
-- 
2.34.1

Reply via email to