* BANK 4 - 0x0104  0x0110  0x011C  0x0128  0x0134  0x0140  0x014C
  * BANK 5 - 0x0108  0x0114  0x0120  0x012C  0x0138  0x0144  0x0150
  *
+ * BANK 6 - 0x0200  0x020C  0x0218  0x0224  0x0230  0x023C  0x0248
+ *
  * NOTE:
  *   BANK 3 is only available on PXA27x and later processors.
- *   BANK 4 and 5 are only available on PXA935
+ *   BANK 4 and 5 are only available on PXA935, PXA1928
+ *   BANK 6 is only available on PXA1928
  */
 
 #define GPLR_OFFSET    0x00
 #define GAFR_OFFSET    0x54
 #define ED_MASK_OFFSET 0x9C    /* GPIO edge detection for AP side */
 
-#define BANK_OFF(n)    (((n) < 3) ? (n) << 2 : 0x100 + (((n) - 3) << 2))
+#define BANK_OFF(n)    (((n) < 3) ? (n) << 2 : ((n) > 5 ? 0x200 : 0x100)       \
+                       + (((n) % 3) << 2))
 
 int pxa_last_gpio;
 static int irq_base;
        PXA93X_GPIO,
        MMP_GPIO = 0x10,
        MMP2_GPIO,
+       PXA1928_GPIO,
 };
 
 struct pxa_gpio_id {
        .gpio_nums      = 192,
 };
 
+static struct pxa_gpio_id pxa1928_id = {
+       .type           = PXA1928_GPIO,
+       .gpio_nums      = 224,
+};
+
 #define for_each_gpio_chip(i, c)                       \
        for (i = 0, c = &pxa_gpio_chips[0]; i <= pxa_last_gpio; i += 32, c++)
 
        case PXA93X_GPIO:
        case MMP_GPIO:
        case MMP2_GPIO:
+       case PXA1928_GPIO:
                gpio_type = pxa_id->type;
                count = pxa_id->gpio_nums - 1;
                break;
        { .compatible = "marvell,pxa93x-gpio",  .data = &pxa93x_id, },
        { .compatible = "marvell,mmp-gpio",     .data = &mmp_id, },
        { .compatible = "marvell,mmp2-gpio",    .data = &mmp2_id, },
+       { .compatible = "marvell,pxa1928-gpio", .data = &pxa1928_id, },
        {}
 };
 
        { "pxa93x-gpio",        (unsigned long)&pxa93x_id },
        { "mmp-gpio",           (unsigned long)&mmp_id },
        { "mmp2-gpio",          (unsigned long)&mmp2_id },
+       { "pxa1928-gpio",       (unsigned long)&pxa1928_id },
        { },
 };