From: "Ville Syrjälä" <ville.syrjala@linux.intel.com>
To: Paulo Zanoni <paulo.r.zanoni@intel.com>
Cc: intel-gfx@lists.freedesktop.org
Subject: Re: [PATCH 1/3] drm/i915: refactor the IRQ init/reset macros
Date: Tue, 9 Apr 2019 21:10:35 +0300 [thread overview]
Message-ID: <20190409181035.GV3888@intel.com> (raw)
In-Reply-To: <20190409003729.20857-2-paulo.r.zanoni@intel.com>
On Mon, Apr 08, 2019 at 05:37:27PM -0700, Paulo Zanoni wrote:
> The whole point of having macros here is for the token pasting
> necessary to automatically have IMR, IIR and IER selected. We don't
> really need or want all the inlining that happens as a consequence.
> The good thing about the current code is that it works regardless of
> the relative offsets between these registers (they change after gen3).
Did you mean "after gen4"? The DE/GT split happened at ilk, and I
guess that's when the four registers also got reshuffled for some
reason. Ignoring the funkyness of vlv/chv or course :)
>
> One thing which we can do is to split the logic of what we do with
> imr/ier/iir to functions separate from the macros that pick them.
> That's what we do in this commit. This allows us to get rid of the
> gen8 duplicates and also all the inlining:
>
> add/remove: 2/0 grow/shrink: 0/21 up/down: 383/-6006 (-5623)
> Function old new delta
> gen3_irq_reset - 233 +233
> gen3_irq_init - 150 +150
> i8xx_irq_postinstall 459 442 -17
> gen11_irq_postinstall 804 744 -60
> ironlake_irq_postinstall 450 353 -97
> vlv_display_irq_postinstall 348 245 -103
> i965_irq_postinstall 378 275 -103
> i915_irq_postinstall 333 228 -105
> gen8_irq_power_well_post_enable 374 210 -164
> ironlake_irq_reset 397 218 -179
> vlv_display_irq_reset 616 433 -183
> i965_irq_reset 374 180 -194
> cherryview_irq_reset 379 185 -194
> i915_irq_reset 407 209 -198
> ibx_irq_reset 332 133 -199
> gen5_gt_irq_postinstall 533 332 -201
> gen8_irq_power_well_pre_disable 434 204 -230
> gen8_gt_irq_postinstall 469 196 -273
> gen8_de_irq_postinstall 1200 805 -395
> gen5_gt_irq_reset 471 76 -395
> gen8_gt_irq_reset 775 99 -676
> gen8_irq_reset 1100 333 -767
> gen11_irq_reset 1959 686 -1273
> Total: Before=2262051, After=2256428, chg -0.25%
>
> Signed-off-by: Paulo Zanoni <paulo.r.zanoni@intel.com>
> ---
> drivers/gpu/drm/i915/i915_irq.c | 123 +++++++++++++++++++-------------
> 1 file changed, 73 insertions(+), 50 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c
> index 6454ddc37f8b..a1e7944fb5d0 100644
> --- a/drivers/gpu/drm/i915/i915_irq.c
> +++ b/drivers/gpu/drm/i915/i915_irq.c
> @@ -136,36 +136,45 @@ static const u32 hpd_icp[HPD_NUM_PINS] = {
> [HPD_PORT_F] = SDE_TC4_HOTPLUG_ICP
> };
>
> -/* IIR can theoretically queue up two events. Be paranoid. */
> -#define GEN8_IRQ_RESET_NDX(type, which) do { \
> - I915_WRITE(GEN8_##type##_IMR(which), 0xffffffff); \
> - POSTING_READ(GEN8_##type##_IMR(which)); \
> - I915_WRITE(GEN8_##type##_IER(which), 0); \
> - I915_WRITE(GEN8_##type##_IIR(which), 0xffffffff); \
> - POSTING_READ(GEN8_##type##_IIR(which)); \
> - I915_WRITE(GEN8_##type##_IIR(which), 0xffffffff); \
> - POSTING_READ(GEN8_##type##_IIR(which)); \
> -} while (0)
> -
> -#define GEN3_IRQ_RESET(type) do { \
> - I915_WRITE(type##IMR, 0xffffffff); \
> - POSTING_READ(type##IMR); \
> - I915_WRITE(type##IER, 0); \
> - I915_WRITE(type##IIR, 0xffffffff); \
> - POSTING_READ(type##IIR); \
> - I915_WRITE(type##IIR, 0xffffffff); \
> - POSTING_READ(type##IIR); \
> -} while (0)
> -
> -#define GEN2_IRQ_RESET(type) do { \
> - I915_WRITE16(type##IMR, 0xffff); \
> - POSTING_READ16(type##IMR); \
> - I915_WRITE16(type##IER, 0); \
> - I915_WRITE16(type##IIR, 0xffff); \
> - POSTING_READ16(type##IIR); \
> - I915_WRITE16(type##IIR, 0xffff); \
> - POSTING_READ16(type##IIR); \
> -} while (0)
> +static void gen3_irq_reset(struct drm_i915_private *dev_priv, i915_reg_t imr,
> + i915_reg_t iir, i915_reg_t ier)
> +{
> + I915_WRITE(imr, 0xffffffff);
> + POSTING_READ(imr);
> +
> + I915_WRITE(ier, 0);
> +
> + /* IIR can theoretically queue up two events. Be paranoid. */
> + I915_WRITE(iir, 0xffffffff);
> + POSTING_READ(iir);
> + I915_WRITE(iir, 0xffffffff);
> + POSTING_READ(iir);
> +}
> +
> +static void gen2_irq_reset(struct drm_i915_private *dev_priv, i915_reg_t imr,
> + i915_reg_t iir, i915_reg_t ier)
> +{
> + I915_WRITE16(imr, 0xffff);
> + POSTING_READ16(imr);
> +
> + I915_WRITE16(ier, 0);
> +
> + /* IIR can theoretically queue up two events. Be paranoid. */
> + I915_WRITE16(iir, 0xffff);
> + POSTING_READ16(iir);
> + I915_WRITE16(iir, 0xffff);
> + POSTING_READ16(iir);
> +}
> +
> +#define GEN8_IRQ_RESET_NDX(type, which) \
> + gen3_irq_reset(dev_priv, GEN8_##type##_IMR(which), \
> + GEN8_##type##_IIR(which), GEN8_##type##_IER(which))
> +
> +#define GEN3_IRQ_RESET(type) \
> + gen3_irq_reset(dev_priv, type##IMR, type##IIR, type##IER)
> +
> +#define GEN2_IRQ_RESET(type) \
> + gen2_irq_reset(dev_priv, type##IMR, type##IIR, type##IER)
>
> /*
> * We should clear IMR at preinstall/uninstall, and just check at postinstall.
> @@ -202,26 +211,40 @@ static void gen2_assert_iir_is_zero(struct drm_i915_private *dev_priv,
> POSTING_READ16(reg);
> }
>
> -#define GEN8_IRQ_INIT_NDX(type, which, imr_val, ier_val) do { \
> - gen3_assert_iir_is_zero(dev_priv, GEN8_##type##_IIR(which)); \
> - I915_WRITE(GEN8_##type##_IER(which), (ier_val)); \
> - I915_WRITE(GEN8_##type##_IMR(which), (imr_val)); \
> - POSTING_READ(GEN8_##type##_IMR(which)); \
> -} while (0)
> -
> -#define GEN3_IRQ_INIT(type, imr_val, ier_val) do { \
> - gen3_assert_iir_is_zero(dev_priv, type##IIR); \
> - I915_WRITE(type##IER, (ier_val)); \
> - I915_WRITE(type##IMR, (imr_val)); \
> - POSTING_READ(type##IMR); \
> -} while (0)
> -
> -#define GEN2_IRQ_INIT(type, imr_val, ier_val) do { \
> - gen2_assert_iir_is_zero(dev_priv, type##IIR); \
> - I915_WRITE16(type##IER, (ier_val)); \
> - I915_WRITE16(type##IMR, (imr_val)); \
> - POSTING_READ16(type##IMR); \
> -} while (0)
> +static void gen3_irq_init(struct drm_i915_private *dev_priv, i915_reg_t imr,
> + i915_reg_t iir, i915_reg_t ier, u32 imr_val,
> + u32 ier_val)
Maybe we should order these more like this
foo(imr, imr_value, ier, ier_value, iir) ?
Could make a bit more obvious which values goes to which register. But
I suppose as long as they're always wrapped in those macros it doesn't
really matter.
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> +{
> + gen3_assert_iir_is_zero(dev_priv, iir);
> +
> + I915_WRITE(ier, ier_val);
> + I915_WRITE(imr, imr_val);
> + POSTING_READ(imr);
> +}
> +
> +static void gen2_irq_init(struct drm_i915_private *dev_priv, i915_reg_t imr,
> + i915_reg_t iir, i915_reg_t ier, u32 imr_val,
> + u32 ier_val)
> +{
> + gen2_assert_iir_is_zero(dev_priv, iir);
> +
> + I915_WRITE16(ier, ier_val);
> + I915_WRITE16(imr, imr_val);
> + POSTING_READ16(imr);
> +}
> +
> +#define GEN8_IRQ_INIT_NDX(type, which, imr_val, ier_val) \
> + gen3_irq_init(dev_priv, GEN8_##type##_IMR(which), \
> + GEN8_##type##_IIR(which), GEN8_##type##_IER(which), \
> + imr_val, ier_val)
> +
> +#define GEN3_IRQ_INIT(type, imr_val, ier_val) \
> + gen3_irq_init(dev_priv, type##IMR, type##IIR, type##IER, imr_val, \
> + ier_val)
> +
> +#define GEN2_IRQ_INIT(type, imr_val, ier_val) \
> + gen2_irq_init(dev_priv, type##IMR, type##IIR, type##IER, imr_val, \
> + ier_val)
>
> static void gen6_rps_irq_handler(struct drm_i915_private *dev_priv, u32 pm_iir);
> static void gen9_guc_irq_handler(struct drm_i915_private *dev_priv, u32 pm_iir);
> --
> 2.20.1
>
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx@lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/intel-gfx
--
Ville Syrjälä
Intel
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx
next prev parent reply other threads:[~2019-04-09 18:10 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-04-09 0:37 [PATCH 0/3] IRQ initialization debloat and conversion to uncore Paulo Zanoni
2019-04-09 0:37 ` [PATCH 1/3] drm/i915: refactor the IRQ init/reset macros Paulo Zanoni
2019-04-09 18:10 ` Ville Syrjälä [this message]
2019-04-10 20:45 ` Paulo Zanoni
2019-04-09 0:37 ` [PATCH 2/3] drm/i915: convert the IRQ initialization functions to intel_uncore Paulo Zanoni
2019-04-09 0:37 ` [PATCH 3/3] drm/i915: fully convert the IRQ initialization macros " Paulo Zanoni
2019-04-09 20:21 ` Ville Syrjälä
2019-04-09 0:44 ` ✗ Fi.CI.CHECKPATCH: warning for IRQ initialization debloat and conversion to uncore Patchwork
2019-04-09 17:34 ` Paulo Zanoni
2019-04-09 18:20 ` Ville Syrjälä
2019-04-10 22:53 ` Paulo Zanoni
2019-04-11 11:04 ` Ville Syrjälä
2019-04-09 1:07 ` ✓ Fi.CI.BAT: success " Patchwork
2019-04-09 7:32 ` ✓ Fi.CI.IGT: " 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=20190409181035.GV3888@intel.com \
--to=ville.syrjala@linux.intel.com \
--cc=intel-gfx@lists.freedesktop.org \
--cc=paulo.r.zanoni@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.