From: Artem Bityutskiy Date: Mon, 18 Aug 2008 15:54:57 +0000 (+0300) Subject: twl3040-gpio: fix task softlockup warning X-Git-Tag: v2.6.27-omap1~302 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=0cbe44841b1b5b99afb011b84300b2a30f14df0f;p=linux-2.6-omap-h63xx.git twl3040-gpio: fix task softlockup warning This patch fixes the following annoying warning: INFO: task twl4030 gpio:283 blocked for more than 120 seconds. "echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message. twl4030 gpio D c027e9dc 0 283 2 [] (schedule+0x0/0x314) from [] (kthread+0x3c/0x80) [] (kthread+0x0/0x80) from [] (do_exit+0x0/0x664) r5:00000000 r4:00000000 Which is printed every 120 seconds by the softlockup code (see 'check_hung_task()' function, introduced by on Jan 2008 by commit 82a1fcb90287052aabfa235e7ffc693ea003fe69). The reason is that the "twl4030 gpio" kthread is created but is not started immediatelly. And in fact it may never start, because TWL3040 interrupts may never happen and hence, the 'twl4030_gpio_unmask_irqchip()' function is never run. This makes the softlockup detection code unhappy. Fix this by running the "twl4030 gpio" kernel thread in at the end of the 'gpio_twl4030_init()' initialization function. Since the 'gpio_pending_unmask' global variable is 0 at that time, the tread ('twl4030_gpio_unmask_thread()') will effectively do nothing and go sleep. This makes the softlocup detection code happy. Signed-off-by: Artem Bityutskiy Signed-off-by: Tony Lindgren --- diff --git a/drivers/i2c/chips/twl4030-gpio.c b/drivers/i2c/chips/twl4030-gpio.c index 494124cc43c..4d89abcc5ea 100644 --- a/drivers/i2c/chips/twl4030-gpio.c +++ b/drivers/i2c/chips/twl4030-gpio.c @@ -748,6 +748,7 @@ static int __init gpio_twl4030_init(void) &twl4030_gpio_module_irq_chip); set_irq_chained_handler(TWL4030_MODIRQ_GPIO, do_twl4030_gpio_module_irq); + wake_up_process(gpio_unmask_thread); } printk(KERN_INFO "TWL4030 GPIO Demux: IRQ Range %d to %d,"