[PATCH V3 4/4] mmc: pwrseq_simple: Add support for a reset GPIO pin
Sascha Hauer
s.hauer at pengutronix.de
Fri Jan 16 04:45:11 PST 2015
On Fri, Jan 16, 2015 at 01:37:41PM +0100, Ulf Hansson wrote:
> On 16 January 2015 at 12:34, Tomeu Vizoso <tomeu.vizoso at collabora.com> wrote:
> > On 16 January 2015 at 11:47, Ulf Hansson <ulf.hansson at linaro.org> wrote:
> >>
> >> int mmc_pwrseq_simple_alloc(struct mmc_host *host, struct device *dev)
> >> {
> >> struct mmc_pwrseq_simple *pwrseq;
> >> + int ret = 0;
> >>
> >> pwrseq = kzalloc(sizeof(struct mmc_pwrseq_simple), GFP_KERNEL);
> >> if (!pwrseq)
> >> return -ENOMEM;
> >>
> >> + pwrseq->reset_gpio = gpiod_get_index(dev, "reset", 0, GPIOD_OUT_HIGH);
> >> + if (IS_ERR(pwrseq->reset_gpio) &&
> >> + PTR_ERR(pwrseq->reset_gpio) != -ENOENT &&
> >> + PTR_ERR(pwrseq->reset_gpio) != -ENOSYS) {
> >> + ret = PTR_ERR(pwrseq->reset_gpio);
> >> + goto free;
> >> + }
> >> +
> >> pwrseq->pwrseq.ops = &mmc_pwrseq_simple_ops;
> >> host->pwrseq = &pwrseq->pwrseq;
> >>
> >> return 0;
> >> +free:
> >> + kfree(&pwrseq);
> >
> > Hi Ulf,
> >
> > this kfree looks a bit fishy (there's one more instance of it in
> > mmc_pwrseq_simple_free).
>
> This is the error path, which means I need to clean up data that I
> have allocated.
I think Tomeu meant that the '&' must be removed.
Sascha
--
Pengutronix e.K. | |
Industrial Linux Solutions | http://www.pengutronix.de/ |
Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 |
Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |
More information about the linux-arm-kernel
mailing list