All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jani Nikula <jani.nikula@intel.com>
To: Matthew Auld <matthew.auld@intel.com>,
	Tvrtko Ursulin <tvrtko.ursulin@linux.intel.com>,
	intel-gfx@lists.freedesktop.org
Subject: Re: [Intel-gfx] [PATCH] drm/i915: move i915_coherent_map_type() to i915_gem_pages.c and un-inline
Date: Mon, 26 Sep 2022 13:05:49 +0300	[thread overview]
Message-ID: <87wn9q30xu.fsf@intel.com> (raw)
In-Reply-To: <e05a2c6d-74fa-476d-8590-677bc330d731@intel.com>

On Tue, 20 Sep 2022, Matthew Auld <matthew.auld@intel.com> wrote:
> On 15/09/2022 08:49, Tvrtko Ursulin wrote:
>> 
>> On 14/09/2022 17:35, Jani Nikula wrote:
>>> The inline function has no place in i915_drv.h. Move it away, un-inline,
>>> and untangle some header dependencies while at it.
>>>
>>> Cc: Matthew Auld <matthew.auld@intel.com>
>>> Cc: Tvrtko Ursulin <tvrtko.ursulin@linux.intel.com>
>>> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
>>>
>>> ---
>>>
>>> I don't know where this belongs, I just know it doesn't belong in
>>> i915_drv.h.
>> 
>> Don't know either.. it straddles the line between objects and platforms 
>> by definition. Maybe Matt will have an idea or opinion.
>
> gem_pages.c seems like a good enough spot to me.
>
> Acked-by: Matthew Auld <matthew.auld@intel.com>

Thanks, pushed to drm-intel-gt-next.

BR,
Jani.

>
>> 
>> Regards,
>> 
>> Tvrtko
>> 
>>> I first tried moving it as inline, but it's really annoying as an inline
>>> because it needs to pull in i915_drv.h, i915_gem_lmem.h, and
>>> i915_gem_object_types.h.
>>> ---
>>>   drivers/gpu/drm/i915/display/intel_dpt.c           |  1 +
>>>   drivers/gpu/drm/i915/gem/i915_gem_object.h         |  4 ++++
>>>   drivers/gpu/drm/i915/gem/i915_gem_pages.c          | 12 ++++++++++++
>>>   drivers/gpu/drm/i915/gem/selftests/i915_gem_mman.c |  1 +
>>>   drivers/gpu/drm/i915/gt/intel_gsc.c                |  1 +
>>>   drivers/gpu/drm/i915/gt/intel_migrate.c            |  1 +
>>>   drivers/gpu/drm/i915/gt/selftest_migrate.c         |  1 +
>>>   drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c         |  1 +
>>>   drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c  |  1 +
>>>   drivers/gpu/drm/i915/i915_drv.h                    | 13 -------------
>>>   drivers/gpu/drm/i915/selftests/i915_gem_gtt.c      |  1 +
>>>   11 files changed, 24 insertions(+), 13 deletions(-)
>>>
>>> diff --git a/drivers/gpu/drm/i915/display/intel_dpt.c 
>>> b/drivers/gpu/drm/i915/display/intel_dpt.c
>>> index ac587647e1f5..ad1a37b515fb 100644
>>> --- a/drivers/gpu/drm/i915/display/intel_dpt.c
>>> +++ b/drivers/gpu/drm/i915/display/intel_dpt.c
>>> @@ -5,6 +5,7 @@
>>>   #include "gem/i915_gem_domain.h"
>>>   #include "gem/i915_gem_internal.h"
>>> +#include "gem/i915_gem_lmem.h"
>>>   #include "gt/gen8_ppgtt.h"
>>>   #include "i915_drv.h"
>>> diff --git a/drivers/gpu/drm/i915/gem/i915_gem_object.h 
>>> b/drivers/gpu/drm/i915/gem/i915_gem_object.h
>>> index 7317d4102955..a3b7551a57fc 100644
>>> --- a/drivers/gpu/drm/i915/gem/i915_gem_object.h
>>> +++ b/drivers/gpu/drm/i915/gem/i915_gem_object.h
>>> @@ -482,6 +482,10 @@ void *__must_check i915_gem_object_pin_map(struct 
>>> drm_i915_gem_object *obj,
>>>   void *__must_check i915_gem_object_pin_map_unlocked(struct 
>>> drm_i915_gem_object *obj,
>>>                               enum i915_map_type type);
>>> +enum i915_map_type i915_coherent_map_type(struct drm_i915_private *i915,
>>> +                      struct drm_i915_gem_object *obj,
>>> +                      bool always_coherent);
>>> +
>>>   void __i915_gem_object_flush_map(struct drm_i915_gem_object *obj,
>>>                    unsigned long offset,
>>>                    unsigned long size);
>>> diff --git a/drivers/gpu/drm/i915/gem/i915_gem_pages.c 
>>> b/drivers/gpu/drm/i915/gem/i915_gem_pages.c
>>> index 4df50b049cea..16f845663ff2 100644
>>> --- a/drivers/gpu/drm/i915/gem/i915_gem_pages.c
>>> +++ b/drivers/gpu/drm/i915/gem/i915_gem_pages.c
>>> @@ -466,6 +466,18 @@ void *i915_gem_object_pin_map_unlocked(struct 
>>> drm_i915_gem_object *obj,
>>>       return ret;
>>>   }
>>> +enum i915_map_type i915_coherent_map_type(struct drm_i915_private *i915,
>>> +                      struct drm_i915_gem_object *obj,
>>> +                      bool always_coherent)
>>> +{
>>> +    if (i915_gem_object_is_lmem(obj))
>>> +        return I915_MAP_WC;
>>> +    if (HAS_LLC(i915) || always_coherent)
>>> +        return I915_MAP_WB;
>>> +    else
>>> +        return I915_MAP_WC;
>>> +}
>>> +
>>>   void __i915_gem_object_flush_map(struct drm_i915_gem_object *obj,
>>>                    unsigned long offset,
>>>                    unsigned long size)
>>> diff --git a/drivers/gpu/drm/i915/gem/selftests/i915_gem_mman.c 
>>> b/drivers/gpu/drm/i915/gem/selftests/i915_gem_mman.c
>>> index b73c91aa5450..1cae24349a96 100644
>>> --- a/drivers/gpu/drm/i915/gem/selftests/i915_gem_mman.c
>>> +++ b/drivers/gpu/drm/i915/gem/selftests/i915_gem_mman.c
>>> @@ -8,6 +8,7 @@
>>>   #include <linux/prime_numbers.h>
>>>   #include "gem/i915_gem_internal.h"
>>> +#include "gem/i915_gem_lmem.h"
>>>   #include "gem/i915_gem_region.h"
>>>   #include "gem/i915_gem_ttm.h"
>>>   #include "gem/i915_gem_ttm_move.h"
>>> diff --git a/drivers/gpu/drm/i915/gt/intel_gsc.c 
>>> b/drivers/gpu/drm/i915/gt/intel_gsc.c
>>> index 7af6db3194dd..d56f75b605d8 100644
>>> --- a/drivers/gpu/drm/i915/gt/intel_gsc.c
>>> +++ b/drivers/gpu/drm/i915/gt/intel_gsc.c
>>> @@ -7,6 +7,7 @@
>>>   #include <linux/mei_aux.h>
>>>   #include "i915_drv.h"
>>>   #include "i915_reg.h"
>>> +#include "gem/i915_gem_lmem.h"
>>>   #include "gem/i915_gem_region.h"
>>>   #include "gt/intel_gsc.h"
>>>   #include "gt/intel_gt.h"
>>> diff --git a/drivers/gpu/drm/i915/gt/intel_migrate.c 
>>> b/drivers/gpu/drm/i915/gt/intel_migrate.c
>>> index aaaf1906026c..b405a04135ca 100644
>>> --- a/drivers/gpu/drm/i915/gt/intel_migrate.c
>>> +++ b/drivers/gpu/drm/i915/gt/intel_migrate.c
>>> @@ -10,6 +10,7 @@
>>>   #include "intel_gtt.h"
>>>   #include "intel_migrate.h"
>>>   #include "intel_ring.h"
>>> +#include "gem/i915_gem_lmem.h"
>>>   struct insert_pte_data {
>>>       u64 offset;
>>> diff --git a/drivers/gpu/drm/i915/gt/selftest_migrate.c 
>>> b/drivers/gpu/drm/i915/gt/selftest_migrate.c
>>> index 2b0c87999949..0dc5309c90a4 100644
>>> --- a/drivers/gpu/drm/i915/gt/selftest_migrate.c
>>> +++ b/drivers/gpu/drm/i915/gt/selftest_migrate.c
>>> @@ -6,6 +6,7 @@
>>>   #include <linux/sort.h>
>>>   #include "gem/i915_gem_internal.h"
>>> +#include "gem/i915_gem_lmem.h"
>>>   #include "selftests/i915_random.h"
>>> diff --git a/drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c 
>>> b/drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c
>>> index 74cbe8eaf531..657f0beb8e06 100644
>>> --- a/drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c
>>> +++ b/drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c
>>> @@ -5,6 +5,7 @@
>>>   #include <linux/bsearch.h>
>>> +#include "gem/i915_gem_lmem.h"
>>>   #include "gt/intel_engine_regs.h"
>>>   #include "gt/intel_gt.h"
>>>   #include "gt/intel_gt_mcr.h"
>>> diff --git a/drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c 
>>> b/drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c
>>> index 22ba66e48a9b..ca6f47496869 100644
>>> --- a/drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c
>>> +++ b/drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c
>>> @@ -6,6 +6,7 @@
>>>   #include <linux/circ_buf.h>
>>>   #include "gem/i915_gem_context.h"
>>> +#include "gem/i915_gem_lmem.h"
>>>   #include "gt/gen8_engine_cs.h"
>>>   #include "gt/intel_breadcrumbs.h"
>>>   #include "gt/intel_context.h"
>>> diff --git a/drivers/gpu/drm/i915/i915_drv.h 
>>> b/drivers/gpu/drm/i915/i915_drv.h
>>> index 9f9372931fd2..524b5ee495be 100644
>>> --- a/drivers/gpu/drm/i915/i915_drv.h
>>> +++ b/drivers/gpu/drm/i915/i915_drv.h
>>> @@ -40,7 +40,6 @@
>>>   #include "display/intel_display_core.h"
>>>   #include "gem/i915_gem_context_types.h"
>>> -#include "gem/i915_gem_lmem.h"
>>>   #include "gem/i915_gem_shrinker.h"
>>>   #include "gem/i915_gem_stolen.h"
>>> @@ -985,16 +984,4 @@ mkwrite_device_info(struct drm_i915_private 
>>> *dev_priv)
>>>       return (struct intel_device_info *)INTEL_INFO(dev_priv);
>>>   }
>>> -static inline enum i915_map_type
>>> -i915_coherent_map_type(struct drm_i915_private *i915,
>>> -               struct drm_i915_gem_object *obj, bool always_coherent)
>>> -{
>>> -    if (i915_gem_object_is_lmem(obj))
>>> -        return I915_MAP_WC;
>>> -    if (HAS_LLC(i915) || always_coherent)
>>> -        return I915_MAP_WB;
>>> -    else
>>> -        return I915_MAP_WC;
>>> -}
>>> -
>>>   #endif
>>> diff --git a/drivers/gpu/drm/i915/selftests/i915_gem_gtt.c 
>>> b/drivers/gpu/drm/i915/selftests/i915_gem_gtt.c
>>> index e050a2de5fd1..ea2cf1080979 100644
>>> --- a/drivers/gpu/drm/i915/selftests/i915_gem_gtt.c
>>> +++ b/drivers/gpu/drm/i915/selftests/i915_gem_gtt.c
>>> @@ -27,6 +27,7 @@
>>>   #include "gem/i915_gem_context.h"
>>>   #include "gem/i915_gem_internal.h"
>>> +#include "gem/i915_gem_lmem.h"
>>>   #include "gem/i915_gem_region.h"
>>>   #include "gem/selftests/mock_context.h"
>>>   #include "gt/intel_context.h"

-- 
Jani Nikula, Intel Open Source Graphics Center

  reply	other threads:[~2022-09-26 10:06 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-09-14 16:35 [Intel-gfx] [PATCH] drm/i915: move i915_coherent_map_type() to i915_gem_pages.c and un-inline Jani Nikula
2022-09-14 18:33 ` [Intel-gfx] ✗ Fi.CI.SPARSE: warning for " Patchwork
2022-09-14 18:52 ` [Intel-gfx] ✓ Fi.CI.BAT: success " Patchwork
2022-09-15  7:49 ` [Intel-gfx] [PATCH] " Tvrtko Ursulin
2022-09-20 16:59   ` Matthew Auld
2022-09-26 10:05     ` Jani Nikula [this message]
2022-09-15 11:30 ` [Intel-gfx] ✗ Fi.CI.IGT: failure for " Patchwork

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=87wn9q30xu.fsf@intel.com \
    --to=jani.nikula@intel.com \
    --cc=intel-gfx@lists.freedesktop.org \
    --cc=matthew.auld@intel.com \
    --cc=tvrtko.ursulin@linux.intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.