From mboxrd@z Thu Jan 1 00:00:00 1970 From: u.kleine-koenig@pengutronix.de (Uwe =?iso-8859-1?Q?Kleine-K=F6nig?=) Date: Tue, 9 Oct 2012 09:45:49 +0200 Subject: [PATCH] video: imxfb: Do not crash on reboot In-Reply-To: <1349703336-8105-1-git-send-email-fabio.estevam@freescale.com> References: <1349703336-8105-1-git-send-email-fabio.estevam@freescale.com> Message-ID: <20121009074549.GG18531@pengutronix.de> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On Mon, Oct 08, 2012 at 10:35:36AM -0300, Fabio Estevam wrote: > Issuing a "reboot" command after the LCD times out causes the following > warnings: > > Requesting system reboot > ------------[ cut here ]------------ > WARNING: at drivers/clk/clk.c:471 clk_disable+0x24/0x50() > Modules linked in: > [] (unwind_backtrace+0x0/0xf4) from [] (warn_slowpath_common+0x48/0x60) > [] (warn_slowpath_common+0x48/0x60) from [] (warn_slowpath_null+0x1c/0x24) > [] (warn_slowpath_null+0x1c/0x24) from [] (clk_disable+0x24/0x50) > [] (clk_disable+0x24/0x50) from [] (imxfb_disable_controller+0x48/0x7c) > [] (imxfb_disable_controller+0x48/0x7c) from [] (platform_drv_shutdown+0x18/0x1c) > [] (platform_drv_shutdown+0x18/0x1c) from [] (device_shutdown+0x48/0x14c) > [] (device_shutdown+0x48/0x14c) from [] (kernel_restart_prepare+0x2c/0x3c) > [] (kernel_restart_prepare+0x2c/0x3c) from [] (kernel_restart+0xc/0x48) > [] (kernel_restart+0xc/0x48) from [] (sys_reboot+0xc0/0x1bc) > [] (sys_reboot+0xc0/0x1bc) from [] (ret_fast_syscall+0x0/0x2c) > ---[ end trace da6b502ca79c854f ]--- > ------------[ cut here ]------------ > WARNING: at drivers/clk/clk.c:380 clk_unprepare+0x1c/0x2c() > Modules linked in: > [] (unwind_backtrace+0x0/0xf4) from [] (warn_slowpath_common+0x48/0x60) > [] (warn_slowpath_common+0x48/0x60) from [] (warn_slowpath_null+0x1c/0x24) > [] (warn_slowpath_null+0x1c/0x24) from [] (clk_unprepare+0x1c/0x2c) > [] (clk_unprepare+0x1c/0x2c) from [] (imxfb_disable_controller+0x50/0x7c) > [] (imxfb_disable_controller+0x50/0x7c) from [] (platform_drv_shutdown+0x18/0x1c) > [] (platform_drv_shutdown+0x18/0x1c) from [] (device_shutdown+0x48/0x14c) > [] (device_shutdown+0x48/0x14c) from [] (kernel_restart_prepare+0x2c/0x3c) > [] (kernel_restart_prepare+0x2c/0x3c) from [] (kernel_restart+0xc/0x48) > [] (kernel_restart+0xc/0x48) from [] (sys_reboot+0xc0/0x1bc) > [] (sys_reboot+0xc0/0x1bc) from [] (ret_fast_syscall+0x0/0x2c) > ---[ end trace da6b502ca79c8550 ]--- > ------------[ cut here ]------------ > > This happens because "reboot" triggers imxfb_shutdown(), which calls > imxfb_disable_controller with the clocks already disabled. > > To prevent this, add a clock enabled status so that we can check if the clocks > are enabled before disabling them. > > Signed-off-by: Fabio Estevam > --- > drivers/video/imxfb.c | 19 +++++++++++++------ > 1 file changed, 13 insertions(+), 6 deletions(-) > > diff --git a/drivers/video/imxfb.c b/drivers/video/imxfb.c > index f3363b2..6acf98a 100644 > --- a/drivers/video/imxfb.c > +++ b/drivers/video/imxfb.c > @@ -134,6 +134,7 @@ struct imxfb_info { > struct clk *clk_ipg; > struct clk *clk_ahb; > struct clk *clk_per; > + int enabled; I didn't really know the driver, but I wonder if the name "enabled" is a tad too generic. Maybe better "clks_enabled"? Uwe -- Pengutronix e.K. | Uwe Kleine-K?nig | Industrial Linux Solutions | http://www.pengutronix.de/ |