On Thu, 22 Nov 2012 16:43:07 +0800 chao bi <chao.bi@xxxxxxxxx> wrote: > > When shut down SPI port, it's possible that MRDY has been asserted > and a SPI timer was activated waiting for SRDY assert, in the case, > it needs to delete this timer. > > Signed-off-by: Chen Jun <jun.d.chen@xxxxxxxxx> > Signed-off-by: channing <chao.bi@xxxxxxxxx> > --- > drivers/tty/serial/ifx6x60.c | 5 ++++- > 1 files changed, 4 insertions(+), 1 deletions(-) > > diff --git a/drivers/tty/serial/ifx6x60.c > b/drivers/tty/serial/ifx6x60.c index 5b9bc19..467020b 100644 > --- a/drivers/tty/serial/ifx6x60.c > +++ b/drivers/tty/serial/ifx6x60.c > @@ -552,7 +552,10 @@ static void ifx_port_shutdown(struct tty_port > *port) container_of(port, struct ifx_spi_device, tty_port); > > mrdy_set_low(ifx_dev); > - clear_bit(IFX_SPI_STATE_TIMER_PENDING, &ifx_dev->flags); > + if (test_and_clear_bit(IFX_SPI_STATE_TIMER_PENDING, > + &ifx_dev->flags)) { > + del_timer(&ifx_dev->spi_timer); > + } You don't actually need the test here as far as I can see. Providing a timer has been initialised (init_timer) then running del_timer is safe even if the timer is not currently queued or has completed. Alan -- To unsubscribe from this list: send the line "unsubscribe linux-serial" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html