diff options
Diffstat (limited to 'drivers/i2c/busses/i2c-sh_mobile.c')
-rw-r--r-- | drivers/i2c/busses/i2c-sh_mobile.c | 23 |
1 files changed, 13 insertions, 10 deletions
diff --git a/drivers/i2c/busses/i2c-sh_mobile.c b/drivers/i2c/busses/i2c-sh_mobile.c index 598c49acaeb5..2707f5e17158 100644 --- a/drivers/i2c/busses/i2c-sh_mobile.c +++ b/drivers/i2c/busses/i2c-sh_mobile.c | |||
@@ -538,15 +538,17 @@ static int sh_mobile_i2c_hook_irqs(struct platform_device *dev, int hook) | |||
538 | { | 538 | { |
539 | struct resource *res; | 539 | struct resource *res; |
540 | int ret = -ENXIO; | 540 | int ret = -ENXIO; |
541 | int q, m; | 541 | int n, k = 0; |
542 | int k = 0; | ||
543 | int n = 0; | ||
544 | 542 | ||
545 | while ((res = platform_get_resource(dev, IORESOURCE_IRQ, k))) { | 543 | while ((res = platform_get_resource(dev, IORESOURCE_IRQ, k))) { |
546 | for (n = res->start; hook && n <= res->end; n++) { | 544 | for (n = res->start; hook && n <= res->end; n++) { |
547 | if (request_irq(n, sh_mobile_i2c_isr, IRQF_DISABLED, | 545 | if (request_irq(n, sh_mobile_i2c_isr, IRQF_DISABLED, |
548 | dev_name(&dev->dev), dev)) | 546 | dev_name(&dev->dev), dev)) { |
547 | for (n--; n >= res->start; n--) | ||
548 | free_irq(n, dev); | ||
549 | |||
549 | goto rollback; | 550 | goto rollback; |
551 | } | ||
550 | } | 552 | } |
551 | k++; | 553 | k++; |
552 | } | 554 | } |
@@ -554,16 +556,17 @@ static int sh_mobile_i2c_hook_irqs(struct platform_device *dev, int hook) | |||
554 | if (hook) | 556 | if (hook) |
555 | return k > 0 ? 0 : -ENOENT; | 557 | return k > 0 ? 0 : -ENOENT; |
556 | 558 | ||
557 | k--; | ||
558 | ret = 0; | 559 | ret = 0; |
559 | 560 | ||
560 | rollback: | 561 | rollback: |
561 | for (q = k; k >= 0; k--) { | 562 | k--; |
562 | for (m = n; m >= res->start; m--) | 563 | |
563 | free_irq(m, dev); | 564 | while (k >= 0) { |
565 | res = platform_get_resource(dev, IORESOURCE_IRQ, k); | ||
566 | for (n = res->start; n <= res->end; n++) | ||
567 | free_irq(n, dev); | ||
564 | 568 | ||
565 | res = platform_get_resource(dev, IORESOURCE_IRQ, k - 1); | 569 | k--; |
566 | m = res->end; | ||
567 | } | 570 | } |
568 | 571 | ||
569 | return ret; | 572 | return ret; |