Merge branch 'for-upstream/mali-dp' of git://linux-arm.org/linux-ld into drm-next
authorDave Airlie <airlied@redhat.com>
Thu, 31 Jan 2019 23:51:23 +0000 (09:51 +1000)
committerDave Airlie <airlied@redhat.com>
Fri, 1 Feb 2019 00:01:50 +0000 (10:01 +1000)
This pull includes the new Arm "komeda" DRM driver. It is currently hosted
in the same repo as the other "mali-dp" driver because it is the next
iteration of the IP.

Signed-off-by: Dave Airlie <airlied@redhat.com>
From: Liviu Dudau <Liviu.Dudau@arm.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20190131173600.GN25147@e110455-lin.cambridge.arm.com
1  2 
MAINTAINERS
drivers/gpu/drm/arm/display/komeda/komeda_private_obj.c
include/uapi/drm/drm_fourcc.h

diff --cc MAINTAINERS
Simple merge
index 0000000000000000000000000000000000000000,9edfd6ab0c1281a6ed700fb6a86a5746e20ab16f..f1c9e3fefa86b4f8722d201475c1961603690836
mode 000000,100644..100644
--- /dev/null
@@@ -1,0 -1,88 +1,88 @@@
 -      drm_atomic_private_obj_init(&pipe->obj, &st->obj,
+ // SPDX-License-Identifier: GPL-2.0
+ /*
+  * (C) COPYRIGHT 2018 ARM Limited. All rights reserved.
+  * Author: James.Qian.Wang <james.qian.wang@arm.com>
+  *
+  */
+ #include "komeda_dev.h"
+ #include "komeda_kms.h"
+ static struct drm_private_state *
+ komeda_pipeline_atomic_duplicate_state(struct drm_private_obj *obj)
+ {
+       struct komeda_pipeline_state *st;
+       st = kmemdup(obj->state, sizeof(*st), GFP_KERNEL);
+       if (!st)
+               return NULL;
+       st->active_comps = 0;
+       __drm_atomic_helper_private_obj_duplicate_state(obj, &st->obj);
+       return &st->obj;
+ }
+ static void
+ komeda_pipeline_atomic_destroy_state(struct drm_private_obj *obj,
+                                    struct drm_private_state *state)
+ {
+       kfree(priv_to_pipe_st(state));
+ }
+ static const struct drm_private_state_funcs komeda_pipeline_obj_funcs = {
+       .atomic_duplicate_state = komeda_pipeline_atomic_duplicate_state,
+       .atomic_destroy_state   = komeda_pipeline_atomic_destroy_state,
+ };
+ static int komeda_pipeline_obj_add(struct komeda_kms_dev *kms,
+                                  struct komeda_pipeline *pipe)
+ {
+       struct komeda_pipeline_state *st;
+       st = kzalloc(sizeof(*st), GFP_KERNEL);
+       if (!st)
+               return -ENOMEM;
+       st->pipe = pipe;
++      drm_atomic_private_obj_init(&kms->base, &pipe->obj, &st->obj,
+                                   &komeda_pipeline_obj_funcs);
+       return 0;
+ }
+ int komeda_kms_add_private_objs(struct komeda_kms_dev *kms,
+                               struct komeda_dev *mdev)
+ {
+       struct komeda_pipeline *pipe;
+       int i, err;
+       for (i = 0; i < mdev->n_pipelines; i++) {
+               pipe = mdev->pipelines[i];
+               err = komeda_pipeline_obj_add(kms, pipe);
+               if (err)
+                       return err;
+               /* Add component */
+       }
+       return 0;
+ }
+ void komeda_kms_cleanup_private_objs(struct komeda_dev *mdev)
+ {
+       struct komeda_pipeline *pipe;
+       struct komeda_component *c;
+       int i, id;
+       for (i = 0; i < mdev->n_pipelines; i++) {
+               pipe = mdev->pipelines[i];
+               dp_for_each_set_bit(id, pipe->avail_comps) {
+                       c = komeda_pipeline_get_component(pipe, id);
+                       drm_atomic_private_obj_fini(&c->obj);
+               }
+               drm_atomic_private_obj_fini(&pipe->obj);
+       }
+ }
Simple merge