[Intel-gfx] [PATCH 02/33] drm/i915: Introduce struct intel_gt as replacement for anonymous i915->gt
Jani Nikula
jani.nikula at linux.intel.com
Wed Jun 19 13:48:30 UTC 2019
On Wed, 19 Jun 2019, Tvrtko Ursulin <tvrtko.ursulin at linux.intel.com> wrote:
> From: Tvrtko Ursulin <tvrtko.ursulin at intel.com>
>
> We have long been slighlty annoyed by the anonymous i915->gt.
>
> Promote it to a separate structure and give it its own header.
>
> This is a first step towards cleaning up the separation between i915 and gt.
>
> Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin at intel.com>
> Reviewed-by: Chris Wilson <chris at chris-wilson.co.uk>
> ---
> drivers/gpu/drm/i915/gt/intel_gt_types.h | 53 ++++++++++++++++++++++++
> drivers/gpu/drm/i915/i915_drv.h | 34 +--------------
> 2 files changed, 55 insertions(+), 32 deletions(-)
> create mode 100644 drivers/gpu/drm/i915/gt/intel_gt_types.h
>
> diff --git a/drivers/gpu/drm/i915/gt/intel_gt_types.h b/drivers/gpu/drm/i915/gt/intel_gt_types.h
> new file mode 100644
> index 000000000000..dcdb18e0dd84
> --- /dev/null
> +++ b/drivers/gpu/drm/i915/gt/intel_gt_types.h
> @@ -0,0 +1,53 @@
> +/*
> + * SPDX-License-Identifier: MIT
> + *
> + * Copyright © 2019 Intel Corporation
> + */
http://patchwork.freedesktop.org/patch/msgid/20190615043142.GA1890@nishad
BR,
Jani.
> +
> +#ifndef __INTEL_GT_TYPES__
> +#define __INTEL_GT_TYPES__
> +
> +#include <linux/ktime.h>
> +#include <linux/list.h>
> +#include <linux/mutex.h>
> +#include <linux/notifier.h>
> +#include <linux/spinlock.h>
> +#include <linux/types.h>
> +
> +#include "i915_vma.h"
> +#include "intel_wakeref.h"
> +
> +struct intel_gt {
> + struct i915_gt_timelines {
> + struct mutex mutex; /* protects list, tainted by GPU */
> + struct list_head active_list;
> +
> + /* Pack multiple timelines' seqnos into the same page */
> + spinlock_t hwsp_lock;
> + struct list_head hwsp_free_list;
> + } timelines;
> +
> + struct list_head active_rings;
> +
> + struct intel_wakeref wakeref;
> +
> + struct list_head closed_vma;
> + spinlock_t closed_lock; /* guards the list of closed_vma */
> +
> + /**
> + * Is the GPU currently considered idle, or busy executing
> + * userspace requests? Whilst idle, we allow runtime power
> + * management to power down the hardware and display clocks.
> + * In order to reduce the effect on performance, there
> + * is a slight delay before we do so.
> + */
> + intel_wakeref_t awake;
> +
> + struct blocking_notifier_head pm_notifications;
> +
> + ktime_t last_init_time;
> +
> + struct i915_vma *scratch;
> +};
> +
> +#endif /* __INTEL_GT_TYPES_H__ */
> diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h
> index bc909ec5d9c3..be433894ea28 100644
> --- a/drivers/gpu/drm/i915/i915_drv.h
> +++ b/drivers/gpu/drm/i915/i915_drv.h
> @@ -72,6 +72,7 @@
>
> #include "gt/intel_lrc.h"
> #include "gt/intel_engine.h"
> +#include "gt/intel_gt_types.h"
> #include "gt/intel_workarounds.h"
>
> #include "intel_device_info.h"
> @@ -1824,38 +1825,7 @@ struct drm_i915_private {
> } perf;
>
> /* Abstract the submission mechanism (legacy ringbuffer or execlists) away */
> - struct {
> - struct i915_gt_timelines {
> - struct mutex mutex; /* protects list, tainted by GPU */
> - struct list_head active_list;
> -
> - /* Pack multiple timelines' seqnos into the same page */
> - spinlock_t hwsp_lock;
> - struct list_head hwsp_free_list;
> - } timelines;
> -
> - struct list_head active_rings;
> -
> - struct intel_wakeref wakeref;
> -
> - struct list_head closed_vma;
> - spinlock_t closed_lock; /* guards the list of closed_vma */
> -
> - /**
> - * Is the GPU currently considered idle, or busy executing
> - * userspace requests? Whilst idle, we allow runtime power
> - * management to power down the hardware and display clocks.
> - * In order to reduce the effect on performance, there
> - * is a slight delay before we do so.
> - */
> - intel_wakeref_t awake;
> -
> - struct blocking_notifier_head pm_notifications;
> -
> - ktime_t last_init_time;
> -
> - struct i915_vma *scratch;
> - } gt;
> + struct intel_gt gt;
>
> struct {
> struct notifier_block pm_notifier;
--
Jani Nikula, Intel Open Source Graphics Center
More information about the Intel-gfx
mailing list