From 6d012787b9fac84b5cfc24cbbf5f7e691bbe5db7 Mon Sep 17 00:00:00 2001 From: Julia Lawall Date: Fri, 23 Dec 2011 18:39:30 +0100 Subject: [PATCH] --- yaml --- r: 280958 b: refs/heads/master c: 30a0dee7806d099c709603e65aa08be0363ea49d h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/usb/host/isp1760-if.c | 13 +++++++++---- 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/[refs] b/[refs] index f5409d85552d..f15696b084db 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 3c8c9316710b83e906e425024153bf0929887b59 +refs/heads/master: 30a0dee7806d099c709603e65aa08be0363ea49d diff --git a/trunk/drivers/usb/host/isp1760-if.c b/trunk/drivers/usb/host/isp1760-if.c index b605224fb9e3..61de62cdb1dd 100644 --- a/trunk/drivers/usb/host/isp1760-if.c +++ b/trunk/drivers/usb/host/isp1760-if.c @@ -56,14 +56,18 @@ static int of_isp1760_probe(struct platform_device *dev) return -ENOMEM; ret = of_address_to_resource(dp, 0, &memory); - if (ret) - return -ENXIO; + if (ret) { + ret = -ENXIO; + goto free_data; + } res_len = resource_size(&memory); res = request_mem_region(memory.start, res_len, dev_name(&dev->dev)); - if (!res) - return -EBUSY; + if (!res) { + ret = -EBUSY; + goto free_data; + } if (of_irq_map_one(dp, 0, &oirq)) { ret = -ENODEV; @@ -125,6 +129,7 @@ static int of_isp1760_probe(struct platform_device *dev) gpio_free(drvdata->rst_gpio); release_reg: release_mem_region(memory.start, res_len); +free_data: kfree(drvdata); return ret; }