From: Ian Molton <ian.molton@codethink.co.uk>
To: Jingoo Han <jg1.han@samsung.com>,
'Brian Norris' <computersforpeace@gmail.com>
Cc: linux-mtd@lists.infradead.org, 'David Woodhouse' <dwmw2@infradead.org>
Subject: Re: [PATCH V3 8/8] mtd: tmio_nand: Use devm_*() functions
Date: Wed, 08 Jan 2014 10:31:43 +0000 [thread overview]
Message-ID: <52CD290F.6050103@codethink.co.uk> (raw)
In-Reply-To: <008001cf01dc$37ae5ac0$a70b1040$%han@samsung.com>
On 26/12/13 01:45, Jingoo Han wrote:
> Use devm_*() functions to make cleanup paths simpler.
This patch seems to have resulted in a combination of both goto and
multiple-return exit patch styles.
I see no point in using goto, if you're going to use multiple returns
and it'll make introducing errors more likely in future.
please pick just one method :-)
-Ian
> Signed-off-by: Jingoo Han <jg1.han@samsung.com>
> ---
> No change since v2.
>
> drivers/mtd/nand/tmio_nand.c | 46 ++++++++++++------------------------------
> 1 file changed, 13 insertions(+), 33 deletions(-)
>
> diff --git a/drivers/mtd/nand/tmio_nand.c b/drivers/mtd/nand/tmio_nand.c
> index a3747c9..fb8fd35 100644
> --- a/drivers/mtd/nand/tmio_nand.c
> +++ b/drivers/mtd/nand/tmio_nand.c
> @@ -371,11 +371,9 @@ static int tmio_probe(struct platform_device *dev)
> if (data == NULL)
> dev_warn(&dev->dev, "NULL platform data!\n");
>
> - tmio = kzalloc(sizeof *tmio, GFP_KERNEL);
> - if (!tmio) {
> - retval = -ENOMEM;
> - goto err_kzalloc;
> - }
> + tmio = devm_kzalloc(&dev->dev, sizeof(*tmio), GFP_KERNEL);
> + if (!tmio)
> + return -ENOMEM;
>
> tmio->dev = dev;
>
> @@ -385,22 +383,18 @@ static int tmio_probe(struct platform_device *dev)
> mtd->priv = nand_chip;
> mtd->name = "tmio-nand";
>
> - tmio->ccr = ioremap(ccr->start, resource_size(ccr));
> - if (!tmio->ccr) {
> - retval = -EIO;
> - goto err_iomap_ccr;
> - }
> + tmio->ccr = devm_ioremap(&dev->dev, ccr->start, resource_size(ccr));
> + if (!tmio->ccr)
> + return -EIO;
>
> tmio->fcr_base = fcr->start & 0xfffff;
> - tmio->fcr = ioremap(fcr->start, resource_size(fcr));
> - if (!tmio->fcr) {
> - retval = -EIO;
> - goto err_iomap_fcr;
> - }
> + tmio->fcr = devm_ioremap(&dev->dev, fcr->start, resource_size(fcr));
> + if (!tmio->fcr)
> + return -EIO;
>
> retval = tmio_hw_init(dev, tmio);
> if (retval)
> - goto err_hwinit;
> + return retval;
>
> /* Set address of NAND IO lines */
> nand_chip->IO_ADDR_R = tmio->fcr;
> @@ -428,7 +422,8 @@ static int tmio_probe(struct platform_device *dev)
> /* 15 us command delay time */
> nand_chip->chip_delay = 15;
>
> - retval = request_irq(irq, &tmio_irq, 0, dev_name(&dev->dev), tmio);
> + retval = devm_request_irq(&dev->dev, irq, &tmio_irq, 0,
> + dev_name(&dev->dev), tmio);
> if (retval) {
> dev_err(&dev->dev, "request_irq error %d\n", retval);
> goto err_irq;
> @@ -440,7 +435,7 @@ static int tmio_probe(struct platform_device *dev)
> /* Scan to find existence of the device */
> if (nand_scan(mtd, 1)) {
> retval = -ENODEV;
> - goto err_scan;
> + goto err_irq;
> }
> /* Register the partitions */
> retval = mtd_device_parse_register(mtd, NULL, NULL,
> @@ -451,18 +446,8 @@ static int tmio_probe(struct platform_device *dev)
>
> nand_release(mtd);
>
> -err_scan:
> - if (tmio->irq)
> - free_irq(tmio->irq, tmio);
> err_irq:
> tmio_hw_stop(dev, tmio);
> -err_hwinit:
> - iounmap(tmio->fcr);
> -err_iomap_fcr:
> - iounmap(tmio->ccr);
> -err_iomap_ccr:
> - kfree(tmio);
> -err_kzalloc:
> return retval;
> }
>
> @@ -471,12 +456,7 @@ static int tmio_remove(struct platform_device *dev)
> struct tmio_nand *tmio = platform_get_drvdata(dev);
>
> nand_release(&tmio->mtd);
> - if (tmio->irq)
> - free_irq(tmio->irq, tmio);
> tmio_hw_stop(dev, tmio);
> - iounmap(tmio->fcr);
> - iounmap(tmio->ccr);
> - kfree(tmio);
> return 0;
> }
>
>
next prev parent reply other threads:[~2014-01-08 10:32 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-12-26 1:40 [PATCH V3 1/8] mtd: docg3: Use devm_*() functions Jingoo Han
2013-12-26 1:41 ` [PATCH V3 2/8] mtd: ixp4xx: " Jingoo Han
2013-12-26 1:42 ` [PATCH V3 3/8] mtd: lantiq-flash: Use devm_kzalloc() Jingoo Han
2013-12-26 1:43 ` [PATCH V3 4/8] mtd: denali_dt: Use devm_clk_get() Jingoo Han
2013-12-26 1:44 ` [PATCH V3 5/8] mtd: lpc32xx_slc: Use devm_*() functions Jingoo Han
2013-12-26 10:30 ` Roland Stigge
2013-12-26 1:44 ` [PATCH V3 6/8] mtd: nuc900_nand: " Jingoo Han
2013-12-26 1:45 ` [PATCH V3 7/8] mtd: plat_nand: " Jingoo Han
2013-12-26 1:45 ` [PATCH V3 8/8] mtd: tmio_nand: " Jingoo Han
2014-01-08 10:31 ` Ian Molton [this message]
2014-01-03 1:24 ` [PATCH V3 1/8] mtd: docg3: " Brian Norris
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=52CD290F.6050103@codethink.co.uk \
--to=ian.molton@codethink.co.uk \
--cc=computersforpeace@gmail.com \
--cc=dwmw2@infradead.org \
--cc=jg1.han@samsung.com \
--cc=linux-mtd@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).