From: Tvrtko Ursulin <tvrtko.ursu...@intel.com>

We soon want to start answering questions like how much GPU time is the
context belonging to a client which exited still using.

To enable this we start tracking all context belonging to a client on a
separate list.

Signed-off-by: Tvrtko Ursulin <tvrtko.ursu...@intel.com>
Reviewed-by: Aravind Iddamsetty <aravind.iddamse...@intel.com>
Reviewed-by: Chris Wilson <ch...@chris-wilson.co.uk>
Signed-off-by: Chris Wilson <ch...@chris-wilson.co.uk>
---
 drivers/gpu/drm/i915/gem/i915_gem_context.c       | 12 ++++++++++++
 drivers/gpu/drm/i915/gem/i915_gem_context_types.h |  3 +++
 drivers/gpu/drm/i915/i915_drm_client.c            |  3 +++
 drivers/gpu/drm/i915/i915_drm_client.h            |  5 +++++
 4 files changed, 23 insertions(+)

diff --git a/drivers/gpu/drm/i915/gem/i915_gem_context.c 
b/drivers/gpu/drm/i915/gem/i915_gem_context.c
index b8d8366a2cce..1595a608de92 100644
--- a/drivers/gpu/drm/i915/gem/i915_gem_context.c
+++ b/drivers/gpu/drm/i915/gem/i915_gem_context.c
@@ -573,6 +573,7 @@ static void set_closed_name(struct i915_gem_context *ctx)
 static void context_close(struct i915_gem_context *ctx)
 {
        struct i915_address_space *vm;
+       struct i915_drm_client *client;
 
        /* Flush any concurrent set_engines() */
        mutex_lock(&ctx->engines_mutex);
@@ -601,6 +602,13 @@ static void context_close(struct i915_gem_context *ctx)
        list_del(&ctx->link);
        spin_unlock(&ctx->i915->gem.contexts.lock);
 
+       client = ctx->client;
+       if (client) {
+               spin_lock(&client->ctx_lock);
+               list_del_rcu(&ctx->client_link);
+               spin_unlock(&client->ctx_lock);
+       }
+
        mutex_unlock(&ctx->mutex);
 
        /*
@@ -943,6 +951,10 @@ static int gem_context_register(struct i915_gem_context 
*ctx,
 
        ctx->client = client;
 
+       spin_lock(&client->ctx_lock);
+       list_add_tail_rcu(&ctx->client_link, &client->ctx_list);
+       spin_unlock(&client->ctx_lock);
+
        spin_lock(&i915->gem.contexts.lock);
        list_add_tail(&ctx->link, &i915->gem.contexts.list);
        spin_unlock(&i915->gem.contexts.lock);
diff --git a/drivers/gpu/drm/i915/gem/i915_gem_context_types.h 
b/drivers/gpu/drm/i915/gem/i915_gem_context_types.h
index eb098f2896c5..8ea3fe3e7414 100644
--- a/drivers/gpu/drm/i915/gem/i915_gem_context_types.h
+++ b/drivers/gpu/drm/i915/gem/i915_gem_context_types.h
@@ -102,6 +102,9 @@ struct i915_gem_context {
        /** client: struct i915_drm_client */
        struct i915_drm_client *client;
 
+       /** link: &drm_client.context_list */
+       struct list_head client_link;
+
        /**
         * @ref: reference count
         *
diff --git a/drivers/gpu/drm/i915/i915_drm_client.c 
b/drivers/gpu/drm/i915/i915_drm_client.c
index 0b7a70ed61d0..1e5db7753276 100644
--- a/drivers/gpu/drm/i915/i915_drm_client.c
+++ b/drivers/gpu/drm/i915/i915_drm_client.c
@@ -100,6 +100,9 @@ i915_drm_client_add(struct i915_drm_clients *clients, 
struct task_struct *task)
 
        kref_init(&client->kref);
        mutex_init(&client->update_lock);
+       spin_lock_init(&client->ctx_lock);
+       INIT_LIST_HEAD(&client->ctx_list);
+
        client->clients = clients;
        INIT_RCU_WORK(&client->rcu, __rcu_i915_drm_client_free);
 
diff --git a/drivers/gpu/drm/i915/i915_drm_client.h 
b/drivers/gpu/drm/i915/i915_drm_client.h
index db82180f5859..b2b69d6985e4 100644
--- a/drivers/gpu/drm/i915/i915_drm_client.h
+++ b/drivers/gpu/drm/i915/i915_drm_client.h
@@ -7,10 +7,12 @@
 #define __I915_DRM_CLIENT_H__
 
 #include <linux/kref.h>
+#include <linux/list.h>
 #include <linux/mutex.h>
 #include <linux/pid.h>
 #include <linux/rcupdate.h>
 #include <linux/sched.h>
+#include <linux/spinlock.h>
 #include <linux/xarray.h>
 
 #include "gt/intel_engine_types.h"
@@ -42,6 +44,9 @@ struct i915_drm_client {
        struct i915_drm_client_name __rcu *name;
        bool closed;
 
+       spinlock_t ctx_lock; /* For add/remove from ctx_list. */
+       struct list_head ctx_list; /* List of contexts belonging to client. */
+
        struct i915_drm_clients *clients;
 
        /**
-- 
2.30.2

Reply via email to