aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpio/sch_gpio.c
diff options
context:
space:
mode:
authorSamuel Ortiz <sameo@linux.intel.com>2010-03-05 11:14:01 -0500
committerSamuel Ortiz <sameo@linux.intel.com>2010-03-07 16:17:37 -0500
commit8e7aafe41be2a7cd5c181ed68876e9ec55ccdba7 (patch)
tree16ca6cc537102f31ca1e99ec8e609d742dc7226d /drivers/gpio/sch_gpio.c
parentbe9b06b2d80fe661491138c6993f944babb26260 (diff)
gpio: Fix sch_gpio warning
We need to check for gpiochip_remove() errors. Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
Diffstat (limited to 'drivers/gpio/sch_gpio.c')
-rw-r--r--drivers/gpio/sch_gpio.c19
1 files changed, 16 insertions, 3 deletions
diff --git a/drivers/gpio/sch_gpio.c b/drivers/gpio/sch_gpio.c
index 761071ae3596..583521352c16 100644
--- a/drivers/gpio/sch_gpio.c
+++ b/drivers/gpio/sch_gpio.c
@@ -229,7 +229,10 @@ static int __devinit sch_gpio_probe(struct platform_device *pdev)
229 return 0; 229 return 0;
230 230
231err_sch_gpio_resume: 231err_sch_gpio_resume:
232 gpiochip_remove(&sch_gpio_core); 232 err = gpiochip_remove(&sch_gpio_core);
233 if (err)
234 dev_err(&pdev->dev, "%s failed, %d\n",
235 "gpiochip_remove()", err);
233 236
234err_sch_gpio_core: 237err_sch_gpio_core:
235 release_region(res->start, resource_size(res)); 238 release_region(res->start, resource_size(res));
@@ -242,13 +245,23 @@ static int __devexit sch_gpio_remove(struct platform_device *pdev)
242{ 245{
243 struct resource *res; 246 struct resource *res;
244 if (gpio_ba) { 247 if (gpio_ba) {
245 gpiochip_remove(&sch_gpio_core); 248 int err;
246 gpiochip_remove(&sch_gpio_resume); 249
250 err = gpiochip_remove(&sch_gpio_core);
251 if (err)
252 dev_err(&pdev->dev, "%s failed, %d\n",
253 "gpiochip_remove()", err);
254 err = gpiochip_remove(&sch_gpio_resume);
255 if (err)
256 dev_err(&pdev->dev, "%s failed, %d\n",
257 "gpiochip_remove()", err);
247 258
248 res = platform_get_resource(pdev, IORESOURCE_IO, 0); 259 res = platform_get_resource(pdev, IORESOURCE_IO, 0);
249 260
250 release_region(res->start, resource_size(res)); 261 release_region(res->start, resource_size(res));
251 gpio_ba = 0; 262 gpio_ba = 0;
263
264 return err;
252 } 265 }
253 266
254 return 0; 267 return 0;