girq->parent_handler = ep93xx_gpio_ab_irq_handler;
                girq->num_parents = 1;
-               girq->parents = devm_kcalloc(dev, 1,
+               girq->parents = devm_kcalloc(dev, girq->num_parents,
                                             sizeof(*girq->parents),
                                             GFP_KERNEL);
                if (!girq->parents)
                 */
                girq->parent_handler = ep93xx_gpio_f_irq_handler;
                girq->num_parents = 8;
-               girq->parents = devm_kcalloc(dev, 8,
+               girq->parents = devm_kcalloc(dev, girq->num_parents,
                                             sizeof(*girq->parents),
                                             GFP_KERNEL);
                if (!girq->parents)
                        return -ENOMEM;
                /* Pick resources 1..8 for these IRQs */
-               for (i = 1; i <= 8; i++)
-                       girq->parents[i - 1] = platform_get_irq(pdev, i);
-               for (i = 0; i < 8; i++) {
+               for (i = 0; i < girq->num_parents; i++) {
+                       girq->parents[i] = platform_get_irq(pdev, i + 1);
                        gpio_irq = EP93XX_GPIO_F_IRQ_BASE + i;
                        irq_set_chip_data(gpio_irq, &epg->gc[5]);
                        irq_set_chip_and_handler(gpio_irq,