[WATCHDOG] ep93xx: watchdog timer driver for TS-72xx SBCs cleanup
authorWim Van Sebroeck <wim@iguana.be>
Wed, 10 Feb 2010 19:34:05 +0000 (19:34 +0000)
committerWim Van Sebroeck <wim@iguana.be>
Sat, 6 Mar 2010 15:12:40 +0000 (15:12 +0000)
Clean-up driver:
* make release the reverse of probe so that both are consistent
* add WDIOC_GETSTATUS & WDIOC_GETBOOTSTATUS ioctls.

Signed-off-by: Wim Van Sebroeck <wim@iguana.be>
drivers/watchdog/ts72xx_wdt.c

index c4a4d37f85afaf4e623af1dd924801a041a11e5f..565a2c3321e556e89015a0a576585259d1c3dc2c 100644 (file)
@@ -307,6 +307,10 @@ static long ts72xx_wdt_ioctl(struct file *file, unsigned int cmd,
                error = copy_to_user(argp, &winfo, sizeof(winfo));
                break;
 
+       case WDIOC_GETSTATUS:
+       case WDIOC_GETBOOTSTATUS:
+               return put_user(0, p);
+
        case WDIOC_KEEPALIVE:
                ts72xx_wdt_kick(wdt);
                break;
@@ -477,14 +481,14 @@ static __devexit int ts72xx_wdt_remove(struct platform_device *pdev)
        error = misc_deregister(&ts72xx_wdt_miscdev);
        platform_set_drvdata(pdev, NULL);
 
-       iounmap(wdt->control_reg);
-       res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
-       release_mem_region(res->start, resource_size(res));
-
        iounmap(wdt->feed_reg);
        res = platform_get_resource(pdev, IORESOURCE_MEM, 1);
        release_mem_region(res->start, resource_size(res));
 
+       iounmap(wdt->control_reg);
+       res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
+       release_mem_region(res->start, resource_size(res));
+
        kfree(wdt);
        return error;
 }