hwrng: pasemi - Migrate to managed API
authorPrasannaKumar Muralidharan <prasannatsmkumar@gmail.com>
Sun, 4 Sep 2016 18:13:08 +0000 (23:43 +0530)
committerHerbert Xu <herbert@gondor.apana.org.au>
Wed, 7 Sep 2016 13:09:35 +0000 (21:09 +0800)
Use devm_ioremap and devm_hwrng_register instead of ioremap and
hwrng_register. This removes unregistering and error handling code.

Changes in v2:
Remove hardcoded resource size in ioremap, use resource struct obtained
by calling platform_get_resource.

Removing hardcoded resource size was suggested by LABBE Corentin.

CC: Darren Stevens <darren@stevens-zone.net>
Suggested-by: LABBE Corentin <clabbe.montjoie@gmail.com>
Signed-off-by: PrasannaKumar Muralidharan <prasannatsmkumar@gmail.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
drivers/char/hw_random/pasemi-rng.c

index 699b7259f5d71e14e79b73f6943f352c0c0cbc18..b4e32f7ab6afa83885198e652d5998dd14845f7e 100644 (file)
@@ -95,42 +95,20 @@ static struct hwrng pasemi_rng = {
        .data_read      = pasemi_rng_data_read,
 };
 
-static int rng_probe(struct platform_device *ofdev)
+static int rng_probe(struct platform_device *pdev)
 {
        void __iomem *rng_regs;
-       struct device_node *rng_np = ofdev->dev.of_node;
-       struct resource res;
-       int err = 0;
+       struct resource *res;
 
-       err = of_address_to_resource(rng_np, 0, &res);
-       if (err)
-               return -ENODEV;
-
-       rng_regs = ioremap(res.start, 0x100);
-
-       if (!rng_regs)
-               return -ENOMEM;
+       res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
+       rng_regs = devm_ioremap_resource(&pdev->dev, res);
+       if (IS_ERR(rng_regs))
+               return PTR_ERR(rng_regs);
 
        pasemi_rng.priv = (unsigned long)rng_regs;
 
        pr_info("Registering PA Semi RNG\n");
-
-       err = hwrng_register(&pasemi_rng);
-
-       if (err)
-               iounmap(rng_regs);
-
-       return err;
-}
-
-static int rng_remove(struct platform_device *dev)
-{
-       void __iomem *rng_regs = (void __iomem *)pasemi_rng.priv;
-
-       hwrng_unregister(&pasemi_rng);
-       iounmap(rng_regs);
-
-       return 0;
+       return devm_hwrng_register(&pdev->dev, &pasemi_rng);
 }
 
 static const struct of_device_id rng_match[] = {
@@ -146,7 +124,6 @@ static struct platform_driver rng_driver = {
                .of_match_table = rng_match,
        },
        .probe          = rng_probe,
-       .remove         = rng_remove,
 };
 
 module_platform_driver(rng_driver);