Commit 5f78584b authored by David Brownell's avatar David Brownell Committed by Kevin Hilman

bugfix for reboot

Fix the following bug, which was reported after a command line "reboot":

 WARNING: at kernel/lockdep.c:2280 lockdep_trace_alloc+0x40/0x50()
 Modules linked in:
 [<c002d910>] (unwind_backtrace+0x0/0xdc) from [<c003bba8>] (warn_slowpath+0x68/0x8c)
 [<c003bba8>] (warn_slowpath+0x68/0x8c) from [<c005ecf0>] (lockdep_trace_alloc+0x40/0x50)
 [<c005ecf0>] (lockdep_trace_alloc+0x40/0x50) from [<c0091e14>] (__kmalloc+0x58/0x110)
 [<c0091e14>] (__kmalloc+0x58/0x110) from [<c0165044>] (kvasprintf+0x38/0x58)
 [<c0165044>] (kvasprintf+0x38/0x58) from [<c015e794>] (kobject_set_name_vargs+0x14/0x54)
 [<c015e794>] (kobject_set_name_vargs+0x14/0x54) from [<c019b9ac>] (dev_set_name+0x20/0x2c)
 [<c019b9ac>] (dev_set_name+0x20/0x2c) from [<c0031804>] (davinci_watchdog_reset+0x1c/0xb0)
 [<c0031804>] (davinci_watchdog_reset+0x1c/0xb0) from [<c0029304>] (arm_machine_restart+0x24/0x50)
 [<c0029304>] (arm_machine_restart+0x24/0x50) from [<c0028d84>] (machine_restart+0x18/0x20)
 [<c0028d84>] (machine_restart+0x18/0x20) from [<c004ba80>] (sys_reboot+0xe0/0x1c4)
 [<c004ba80>] (sys_reboot+0xe0/0x1c4) from [<c0027d40>] (ret_fast_syscall+0x0/0x2c)

The issue is that dev_set_name() may no longer be called with IRQs disabled.
Trivial fix:  don't cons up a fake watchdog device, just use the real one.
Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
parent ed400fa2
...@@ -96,4 +96,7 @@ int davinci_clk_associate(struct device *dev, const char *logical_clockname, ...@@ -96,4 +96,7 @@ int davinci_clk_associate(struct device *dev, const char *logical_clockname,
const char *physical_clockname); const char *physical_clockname);
int davinci_clk_init(struct davinci_clk *clocks); int davinci_clk_init(struct davinci_clk *clocks);
extern struct platform_device davinci_wdt_device;
#endif #endif
...@@ -228,7 +228,7 @@ static struct resource wdt_resources[] = { ...@@ -228,7 +228,7 @@ static struct resource wdt_resources[] = {
}, },
}; };
static struct platform_device davinci_wdt_device = { struct platform_device davinci_wdt_device = {
.name = "watchdog", .name = "watchdog",
.id = -1, .id = -1,
.num_resources = ARRAY_SIZE(wdt_resources), .num_resources = ARRAY_SIZE(wdt_resources),
......
...@@ -19,6 +19,7 @@ ...@@ -19,6 +19,7 @@
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/err.h> #include <linux/err.h>
#include <linux/device.h> #include <linux/device.h>
#include <linux/platform_device.h>
#include <mach/hardware.h> #include <mach/hardware.h>
#include <asm/system.h> #include <asm/system.h>
...@@ -403,15 +404,14 @@ struct sys_timer davinci_timer = { ...@@ -403,15 +404,14 @@ struct sys_timer davinci_timer = {
/* reset board using watchdog timer */ /* reset board using watchdog timer */
void davinci_watchdog_reset(void) { void davinci_watchdog_reset(void)
{
u32 tgcr, wdtcr; u32 tgcr, wdtcr;
struct davinci_soc_info *soc_info = davinci_get_soc_info(); struct davinci_soc_info *soc_info = davinci_get_soc_info();
void __iomem *base = soc_info->wdt_base; void __iomem *base = soc_info->wdt_base;
struct device dev;
struct clk *wd_clk; struct clk *wd_clk;
dev_set_name(&dev, "watchdog"); wd_clk = clk_get(&davinci_wdt_device.dev, NULL);
wd_clk = clk_get(&dev, NULL);
if (WARN_ON(IS_ERR(wd_clk))) if (WARN_ON(IS_ERR(wd_clk)))
return; return;
clk_enable(wd_clk); clk_enable(wd_clk);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment