All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jani Nikula <jani.nikula@intel.com>
To: Jiri Kosina <jkosina@suse.cz>, Dave Airlie <airlied@linux.ie>,
	Daniel Vetter <daniel.vetter@ffwll.ch>,
	Linus Torvalds <torvalds@linux-foundation.org>
Cc: linux-kernel@vger.kernel.org,
	DRI mailing list <dri-devel@lists.freedesktop.org>
Subject: Re: [git pull] drm next tree
Date: Fri, 07 Feb 2014 13:10:25 +0200	[thread overview]
Message-ID: <87a9e318m6.fsf@intel.com> (raw)
In-Reply-To: <alpine.LNX.2.00.1402071052470.24838@pobox.suse.cz>

On Fri, 07 Feb 2014, Jiri Kosina <jkosina@suse.cz> wrote:
> On Thu, 30 Jan 2014, Jiri Kosina wrote:
>
>> >   git://people.freedesktop.org/~airlied/linux drm-next
>> [ ... snip ... ]
>> > Daniel Vetter (59):
>> [ ... snip ... ]
>> >       drm/i915: dp aux irq support for g4x/vlv
>> 
>> This commit causes all kinds of havoc on my ThinkPad x200s. It results in
> [ ... snip ... ]
>
> Not having received any response, I suggest the following for 3.14

Daniel, it's your commit this bisects to...

If we end up having to revert, I'd just touch the has_aux_irq part, for
example:

diff --git a/drivers/gpu/drm/i915/intel_dp.c b/drivers/gpu/drm/i915/intel_dp.c
index 5ede4e8..464c047 100644
--- a/drivers/gpu/drm/i915/intel_dp.c
+++ b/drivers/gpu/drm/i915/intel_dp.c
@@ -404,7 +404,7 @@ intel_dp_aux_ch(struct intel_dp *intel_dp,
 	int i, ret, recv_bytes;
 	uint32_t status;
 	int try, precharge, clock = 0;
-	bool has_aux_irq = true;
+	bool has_aux_irq = INTEL_INFO(dev)->gen >= 5;
 	uint32_t timeout;

 	/* dp aux is extremely sensitive to irq latency, hence request the

or even INTEL_INFO(dev)->gen != 4.

But up to Daniel.


BR,
Jani.




>
>
>
>
> From: Jiri Kosina <jkosina@suse.cz>
> Subject: [PATCH] Revert "drm/i915: dp aux irq support for g4x/vlv"
>
> This reverts commit 4aeebd7443e36b0a40032e518a9338f48bd27efc.
>
> Conflicts:
>
> 	drivers/gpu/drm/i915/i915_reg.h
>
> This commit causes all kinds of havoc on my ThinkPad x200s. It results in
>
>  irq 16: nobody cared (try booting with the "irqpoll" option)
>  CPU: 0 PID: 0 Comm: swapper/0 Not tainted 3.12.0-00854-g4aeebd7 #1
>  Hardware name: LENOVO 7470BN2/7470BN2, BIOS 6DET38WW (2.02 ) 12/19/2008
>   ffff8800795186c0 ffff88007c203e08 ffffffff81582503 ffff88007c203e38
>   ffffffff810a6a98 ffff88007c203e88 ffff880079518600 0000000000000000
>   0000000000000010 ffff88007c203e78 ffffffff810a6d43 00000010ffc4af9d
>  Call Trace:
>   <IRQ>  [<ffffffff81582503>] dump_stack+0x7a/0x97
>   [<ffffffff810a6a98>] __report_bad_irq+0x38/0xf0
>   [<ffffffff810a6d43>] note_interrupt+0x1f3/0x240
>   [<ffffffff810a42d2>] handle_irq_event_percpu+0x142/0x220
>   [<ffffffff810a43f9>] handle_irq_event+0x49/0x70
>   [<ffffffff810a7561>] handle_fasteoi_irq+0x61/0x100
>   [<ffffffff81004a89>] handle_irq+0x59/0x150
>   [<ffffffff81052b6e>] ? _local_bh_enable+0xe/0x10
>   [<ffffffff81052bf1>] ? irq_enter+0x81/0x90
>   [<ffffffff8100403b>] do_IRQ+0x5b/0xe0
>   [<ffffffff81588aaf>] common_interrupt+0x6f/0x6f
>   <EOI>  [<ffffffff81588b5c>] ? retint_restore_args+0xe/0xe
>   [<ffffffff8146c767>] ? poll_idle+0x47/0x90
>   [<ffffffff8146c740>] ? poll_idle+0x20/0x90
>   [<ffffffff810acd96>] ? ktime_get+0x56/0xd0
>   [<ffffffff8146c7f0>] cpuidle_enter_state+0x40/0xd0
>   [<ffffffff8146cc0a>] cpuidle_idle_call+0x10a/0x160
>   [<ffffffff8100b7b9>] arch_cpu_idle+0x9/0x30
>   [<ffffffff810a370b>] cpu_idle_loop+0x8b/0x270
>   [<ffffffff810a390e>] cpu_startup_entry+0x1e/0x20
>   [<ffffffff8157a0c3>] rest_init+0xd3/0xe0
>   [<ffffffff81579ff0>] ? csum_partial_copy_generic+0x170/0x170
>   [<ffffffff81ad905c>] start_kernel+0x3b3/0x461
>   [<ffffffff81ad8a96>] ? repair_env_string+0x58/0x58
>   [<ffffffff81ad84d1>] x86_64_start_reservations+0x1b/0x32
>   [<ffffffff81ad8622>] x86_64_start_kernel+0x13a/0x141
>  handlers:
>  [<ffffffffa00acbc0>] usb_hcd_irq [usbcore]
>  Disabling IRQ #16
>
> and things go south afterwards (the machine hangs randomly, I/O is 
> horribly slow, etc).
>
> Signed-off-by: Jiri Kosina <jkosina@suse.cz>
>
> ---
>  drivers/gpu/drm/i915/i915_irq.c |    7 -------
>  drivers/gpu/drm/i915/i915_reg.h |    5 -----
>  drivers/gpu/drm/i915/intel_dp.c |    2 +-
>  3 files changed, 1 insertions(+), 13 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c
> index 17d8fcb..b7fae5b 100644
> --- a/drivers/gpu/drm/i915/i915_irq.c
> +++ b/drivers/gpu/drm/i915/i915_irq.c
> @@ -1480,9 +1480,6 @@ static irqreturn_t valleyview_irq_handler(int irq, void *arg)
>  
>  			intel_hpd_irq_handler(dev, hotplug_trigger, hpd_status_i915);
>  
> -			if (hotplug_status & DP_AUX_CHANNEL_MASK_INT_STATUS_G4X)
> -				dp_aux_irq_handler(dev);
> -
>  			I915_WRITE(PORT_HOTPLUG_STAT, hotplug_status);
>  			I915_READ(PORT_HOTPLUG_STAT);
>  		}
> @@ -3670,10 +3667,6 @@ static irqreturn_t i965_irq_handler(int irq, void *arg)
>  			intel_hpd_irq_handler(dev, hotplug_trigger,
>  					      IS_G4X(dev) ? hpd_status_g4x : hpd_status_i915);
>  
> -			if (IS_G4X(dev) &&
> -			    (hotplug_status & DP_AUX_CHANNEL_MASK_INT_STATUS_G4X))
> -				dp_aux_irq_handler(dev);
> -
>  			I915_WRITE(PORT_HOTPLUG_STAT, hotplug_status);
>  			I915_READ(PORT_HOTPLUG_STAT);
>  		}
> diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h
> index a48b7ca..94b4cd5 100644
> --- a/drivers/gpu/drm/i915/i915_reg.h
> +++ b/drivers/gpu/drm/i915/i915_reg.h
> @@ -2139,11 +2139,6 @@
>  #define   CRT_HOTPLUG_MONITOR_COLOR		(3 << 8)
>  #define   CRT_HOTPLUG_MONITOR_MONO		(2 << 8)
>  #define   CRT_HOTPLUG_MONITOR_NONE		(0 << 8)
> -#define   DP_AUX_CHANNEL_D_INT_STATUS_G4X	(1 << 6)
> -#define   DP_AUX_CHANNEL_C_INT_STATUS_G4X	(1 << 5)
> -#define   DP_AUX_CHANNEL_B_INT_STATUS_G4X	(1 << 4)
> -#define   DP_AUX_CHANNEL_MASK_INT_STATUS_G4X	(7 << 4)
> -
>  /* SDVO is different across gen3/4 */
>  #define   SDVOC_HOTPLUG_INT_STATUS_G4X		(1 << 3)
>  #define   SDVOB_HOTPLUG_INT_STATUS_G4X		(1 << 2)
> diff --git a/drivers/gpu/drm/i915/intel_dp.c b/drivers/gpu/drm/i915/intel_dp.c
> index 5ede4e8..464c047 100644
> --- a/drivers/gpu/drm/i915/intel_dp.c
> +++ b/drivers/gpu/drm/i915/intel_dp.c
> @@ -404,7 +404,7 @@ intel_dp_aux_ch(struct intel_dp *intel_dp,
>  	int i, ret, recv_bytes;
>  	uint32_t status;
>  	int try, precharge, clock = 0;
> -	bool has_aux_irq = true;
> +	bool has_aux_irq = INTEL_INFO(dev)->gen >= 5 && !IS_VALLEYVIEW(dev);
>  	uint32_t timeout;
>  
>  	/* dp aux is extremely sensitive to irq latency, hence request the
> -- 
> Jiri Kosina
> SUSE Labs
> _______________________________________________
> dri-devel mailing list
> dri-devel@lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel

-- 
Jani Nikula, Intel Open Source Technology Center

  reply	other threads:[~2014-02-07 11:06 UTC|newest]

Thread overview: 39+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-01-30  2:49 [git pull] drm next tree Dave Airlie
2014-01-30  2:49 ` Dave Airlie
2014-01-30  4:54 ` Linus Torvalds
2014-01-30  4:54   ` Linus Torvalds
2014-01-30 12:33 ` Paul Bolle
2014-01-30 12:33   ` Paul Bolle
2014-02-20 21:02   ` [PATCH] drm/radeon: silence GCC warning on 32 bit Paul Bolle
2014-02-20 21:07     ` Ilia Mirkin
2014-02-20 21:07       ` Ilia Mirkin
2014-02-20 21:24       ` Paul Bolle
2014-02-21  8:20         ` Thierry Reding
2014-02-21  8:20           ` Thierry Reding
2014-03-04  9:34           ` [PATCH v2] " Paul Bolle
2014-03-04  9:34             ` Paul Bolle
2014-03-04 11:42             ` Christian König
2014-03-04 11:42               ` Christian König
2014-03-04 14:52             ` Alex Deucher
2014-03-04 14:52               ` Alex Deucher
2014-01-30 15:55 ` [git pull] drm next tree Jiri Kosina
2014-02-07 10:08   ` Jiri Kosina
2014-02-07 10:08     ` Jiri Kosina
2014-02-07 11:10     ` Jani Nikula [this message]
2014-02-07 13:40       ` Jiri Kosina
2014-02-07 13:40         ` Jiri Kosina
2014-02-07 14:05         ` Daniel Vetter
2014-02-07 14:05           ` Daniel Vetter
2014-02-07 14:15           ` Jiri Kosina
  -- strict thread matches above, loose matches on Subject: below --
2011-03-17  4:09 Dave Airlie
2011-03-17  4:09 ` Dave Airlie
2011-03-23  2:19 ` Linus Torvalds
2011-03-23 12:21   ` Stephen Clark
2011-03-23 14:39     ` Jerome Glisse
2011-03-23 15:22     ` Jesse Barnes
2011-03-23 14:22   ` Alessandro Suardi
2011-03-23 15:29   ` Linus Torvalds
2011-03-23 15:29     ` Linus Torvalds
2011-03-23 15:33     ` Jesse Barnes
2011-03-23 15:33       ` Jesse Barnes
2011-03-24  0:54       ` Linus Torvalds

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=87a9e318m6.fsf@intel.com \
    --to=jani.nikula@intel.com \
    --cc=airlied@linux.ie \
    --cc=daniel.vetter@ffwll.ch \
    --cc=dri-devel@lists.freedesktop.org \
    --cc=jkosina@suse.cz \
    --cc=linux-kernel@vger.kernel.org \
    --cc=torvalds@linux-foundation.org \
    /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.