All of lore.kernel.org
 help / color / mirror / Atom feed
From: Viresh Kumar <viresh.kumar@linaro.org>
To: David Gstir <david@sigma-star.at>
Cc: linux-kernel@vger.kernel.org, daniel.lezcano@linaro.org,
	tglx@linutronix.de, richard@nod.at, stable@vger.kernel.org,
	Andres Salomon <dilinger@queued.net>
Subject: Re: [PATCH] clockevents/drivers/cs5535: Un-break driver with 'set-state' interface
Date: Mon, 2 Jan 2017 15:04:54 +0530	[thread overview]
Message-ID: <20170102093454.GF13679@vireshk-i7> (raw)
In-Reply-To: <20161228215603.6600-1-david@sigma-star.at>

On 28-12-16, 22:56, David Gstir wrote:
> Since migrating to the 'set-state' interface the cs5535 driver causes a
> crash after loading: Right after initialization, the IRQ handler
> (mfgpt_tick) is triggered with clock event device in detached state. This
> state not properly handled and causes a crash through NULL pointer
> dereference upon calling the clockevent's event_handler.
> 
> This patch fixes this by handling the detached state the same way the
> shutdown state is handled.
> 
> Fixes: 8f9327cbb6e8 ("clockevents/drivers/cs5535: Migrate to new 'set-state' interface")
> Cc: stable@vger.kernel.org
> Cc: Andres Salomon <dilinger@queued.net>
> Cc: Viresh Kumar <viresh.kumar@linaro.org>
> Signed-off-by: David Gstir <david@sigma-star.at>
> ---
>  drivers/clocksource/cs5535-clockevt.c | 3 ++-
>  1 file changed, 2 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/clocksource/cs5535-clockevt.c b/drivers/clocksource/cs5535-clockevt.c
> index 9a7e37cf56b0..649e0cd90805 100644
> --- a/drivers/clocksource/cs5535-clockevt.c
> +++ b/drivers/clocksource/cs5535-clockevt.c
> @@ -117,7 +117,8 @@ static irqreturn_t mfgpt_tick(int irq, void *dev_id)
>  	/* Turn off the clock (and clear the event) */
>  	disable_timer(cs5535_event_clock);
>  
> -	if (clockevent_state_shutdown(&cs5535_clockevent))
> +	if (clockevent_state_shutdown(&cs5535_clockevent) ||
> +			clockevent_state_detached(&cs5535_clockevent))
>  		return IRQ_HANDLED;
>  
>  	/* Clear the counter */

Sorry for breaking it, but it looks we have unearthed a bug because of
my patch.

I wouldn't enable the IRQ unless the clockevents core has asked for
it, i.e. by calling set_state_periodic() or set_state_oneshot().

The driver is currently enabling the IRQ from its init code and that's
where the problem is IMHO.

-- 
viresh

  reply	other threads:[~2017-01-02  9:34 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-12-28 21:56 [PATCH] clockevents/drivers/cs5535: Un-break driver with 'set-state' interface David Gstir
2017-01-02  9:34 ` Viresh Kumar [this message]
     [not found]   ` <0d828ca5-4bc1-213b-f8ce-d4cfbbe9e619@linaro.org>
2017-01-04 14:22     ` David Gstir

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=20170102093454.GF13679@vireshk-i7 \
    --to=viresh.kumar@linaro.org \
    --cc=daniel.lezcano@linaro.org \
    --cc=david@sigma-star.at \
    --cc=dilinger@queued.net \
    --cc=linux-kernel@vger.kernel.org \
    --cc=richard@nod.at \
    --cc=stable@vger.kernel.org \
    --cc=tglx@linutronix.de \
    /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.