ARM: PNX4008: convert watchdog to use clk API enable/disable calls

clk_set_rate() is not supposed to be used to turn clocks on and off.
That's what clk_enable/clk_disable is for.

Acked-by: Wim Van Sebroeck <wim@iguana.be>
Acked-by: Vitaly Wool <vitalywool@gmail.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
This commit is contained in:
Russell King 2009-11-20 13:04:14 +00:00
parent 9bb787f435
commit 24fd1edaac
2 changed files with 26 additions and 15 deletions

View File

@ -740,10 +740,10 @@ static struct clk wdt_ck = {
.name = "wdt_ck", .name = "wdt_ck",
.parent = &per_ck, .parent = &per_ck,
.flags = NEEDS_INITIALIZATION, .flags = NEEDS_INITIALIZATION,
.round_rate = &on_off_round_rate,
.set_rate = &on_off_set_rate,
.enable_shift = 0, .enable_shift = 0,
.enable_reg = TIMCLKCTRL_REG, .enable_reg = TIMCLKCTRL_REG,
.enable = clk_reg_enable,
.disable = clk_reg_disable,
}; };
/* These clocks are visible outside this module /* These clocks are visible outside this module

View File

@ -96,9 +96,6 @@ static void wdt_enable(void)
{ {
spin_lock(&io_lock); spin_lock(&io_lock);
if (wdt_clk)
clk_set_rate(wdt_clk, 1);
/* stop counter, initiate counter reset */ /* stop counter, initiate counter reset */
__raw_writel(RESET_COUNT, WDTIM_CTRL(wdt_base)); __raw_writel(RESET_COUNT, WDTIM_CTRL(wdt_base));
/*wait for reset to complete. 100% guarantee event */ /*wait for reset to complete. 100% guarantee event */
@ -125,19 +122,25 @@ static void wdt_disable(void)
spin_lock(&io_lock); spin_lock(&io_lock);
__raw_writel(0, WDTIM_CTRL(wdt_base)); /*stop counter */ __raw_writel(0, WDTIM_CTRL(wdt_base)); /*stop counter */
if (wdt_clk)
clk_set_rate(wdt_clk, 0);
spin_unlock(&io_lock); spin_unlock(&io_lock);
} }
static int pnx4008_wdt_open(struct inode *inode, struct file *file) static int pnx4008_wdt_open(struct inode *inode, struct file *file)
{ {
int ret;
if (test_and_set_bit(WDT_IN_USE, &wdt_status)) if (test_and_set_bit(WDT_IN_USE, &wdt_status))
return -EBUSY; return -EBUSY;
clear_bit(WDT_OK_TO_CLOSE, &wdt_status); clear_bit(WDT_OK_TO_CLOSE, &wdt_status);
ret = clk_enable(wdt_clk);
if (ret) {
clear_bit(WDT_IN_USE, &wdt_status);
return ret;
}
wdt_enable(); wdt_enable();
return nonseekable_open(inode, file); return nonseekable_open(inode, file);
@ -225,6 +228,7 @@ static int pnx4008_wdt_release(struct inode *inode, struct file *file)
printk(KERN_WARNING "WATCHDOG: Device closed unexpectdly\n"); printk(KERN_WARNING "WATCHDOG: Device closed unexpectdly\n");
wdt_disable(); wdt_disable();
clk_disable(wdt_clk);
clear_bit(WDT_IN_USE, &wdt_status); clear_bit(WDT_IN_USE, &wdt_status);
clear_bit(WDT_OK_TO_CLOSE, &wdt_status); clear_bit(WDT_OK_TO_CLOSE, &wdt_status);
@ -279,19 +283,27 @@ static int __devinit pnx4008_wdt_probe(struct platform_device *pdev)
release_resource(wdt_mem); release_resource(wdt_mem);
kfree(wdt_mem); kfree(wdt_mem);
goto out; goto out;
} else }
clk_set_rate(wdt_clk, 1);
ret = clk_enable(wdt_clk);
if (ret) {
release_resource(wdt_mem);
kfree(wdt_mem);
goto out;
}
ret = misc_register(&pnx4008_wdt_miscdev); ret = misc_register(&pnx4008_wdt_miscdev);
if (ret < 0) { if (ret < 0) {
printk(KERN_ERR MODULE_NAME "cannot register misc device\n"); printk(KERN_ERR MODULE_NAME "cannot register misc device\n");
release_resource(wdt_mem); release_resource(wdt_mem);
kfree(wdt_mem); kfree(wdt_mem);
clk_set_rate(wdt_clk, 0); clk_disable(wdt_clk);
clk_put(wdt_clk);
} else { } else {
boot_status = (__raw_readl(WDTIM_RES(wdt_base)) & WDOG_RESET) ? boot_status = (__raw_readl(WDTIM_RES(wdt_base)) & WDOG_RESET) ?
WDIOF_CARDRESET : 0; WDIOF_CARDRESET : 0;
wdt_disable(); /*disable for now */ wdt_disable(); /*disable for now */
clk_disable(wdt_clk);
set_bit(WDT_DEVICE_INITED, &wdt_status); set_bit(WDT_DEVICE_INITED, &wdt_status);
} }
@ -302,11 +314,10 @@ out:
static int __devexit pnx4008_wdt_remove(struct platform_device *pdev) static int __devexit pnx4008_wdt_remove(struct platform_device *pdev)
{ {
misc_deregister(&pnx4008_wdt_miscdev); misc_deregister(&pnx4008_wdt_miscdev);
if (wdt_clk) {
clk_set_rate(wdt_clk, 0); clk_disable(wdt_clk);
clk_put(wdt_clk); clk_put(wdt_clk);
wdt_clk = NULL;
}
if (wdt_mem) { if (wdt_mem) {
release_resource(wdt_mem); release_resource(wdt_mem);
kfree(wdt_mem); kfree(wdt_mem);