gpio/omap: use flag to identify wakeup domain
authorCharulatha V <charu@ti.com>
Thu, 5 May 2011 14:45:16 +0000 (20:15 +0530)
committerTarun Kanti DebBarma <tarun.kanti@ti.com>
Mon, 6 Feb 2012 08:43:40 +0000 (14:13 +0530)
In omap3, save/restore context is implemented for GPIO banks 2-6 as GPIO bank1
is in wakeup domain. Instead of identifying bank's power domain by bank id,
use 'loses_context' flag which is filled by pwrdm_can_ever_lose_context()
during dev_init.

For getting the powerdomain pointer, omap_hwmod_get_pwrdm() is used.
omap_device_get_pwrdm() could not be used as the pwrdm information needs to be
filled in pdata, whereas omap_device_get_pwrdm() could be used only after
omap_device_build() call.

Signed-off-by: Charulatha V <charu@ti.com>
Reviewed-by: Santosh Shilimkar <santosh.shilimkar@ti.com>
Reviewed-by: Kevin Hilman <khilman@ti.com>
Signed-off-by: Kevin Hilman <khilman@ti.com>
arch/arm/mach-omap2/gpio.c
arch/arm/plat-omap/include/plat/gpio.h
drivers/gpio/gpio-omap.c

index 07ac648507465a226ea33b88653063ce157daec7..076be342ad28ad6efbc0fa48c55088879be45e6d 100644 (file)
@@ -24,6 +24,8 @@
 #include <plat/omap_hwmod.h>
 #include <plat/omap_device.h>
 
+#include "powerdomain.h"
+
 static int omap2_gpio_dev_init(struct omap_hwmod *oh, void *unused)
 {
        struct platform_device *pdev;
@@ -31,6 +33,7 @@ static int omap2_gpio_dev_init(struct omap_hwmod *oh, void *unused)
        struct omap_gpio_dev_attr *dev_attr;
        char *name = "omap_gpio";
        int id;
+       struct powerdomain *pwrdm;
 
        /*
         * extract the device id from name field available in the
@@ -99,6 +102,9 @@ static int omap2_gpio_dev_init(struct omap_hwmod *oh, void *unused)
                return -EINVAL;
        }
 
+       pwrdm = omap_hwmod_get_pwrdm(oh);
+       pdata->loses_context = pwrdm_can_ever_lose_context(pwrdm);
+
        pdev = omap_device_build(name, id - 1, oh, pdata,
                                sizeof(*pdata), NULL, 0, false);
        kfree(pdata);
index acf1c779629eab390d2bd0b283723372aa4e2237..6eb035c0cc16c1c7ee763554ee4915b39a42ec67 100644 (file)
@@ -198,6 +198,7 @@ struct omap_gpio_platform_data {
        int bank_width;         /* GPIO bank width */
        int bank_stride;        /* Only needed for omap1 MPUIO */
        bool dbck_flag;         /* dbck required or not - True for OMAP3&4 */
+       bool loses_context;     /* whether the bank would ever lose context */
 
        struct omap_gpio_reg_offs *regs;
 };
index 6ea7390e78014d44491bbef9fc54866a1cc015b9..07efa15c35492237a3a9c99dd28bbb3d49d01a7a 100644 (file)
@@ -56,6 +56,7 @@ struct gpio_bank {
        u32 dbck_enable_mask;
        struct device *dev;
        bool dbck_flag;
+       bool loses_context;
        int stride;
        u32 width;
        u16 id;
@@ -1181,7 +1182,7 @@ static int __devinit omap_gpio_probe(struct platform_device *pdev)
        bank->dbck_flag = pdata->dbck_flag;
        bank->stride = pdata->bank_stride;
        bank->width = pdata->bank_width;
-
+       bank->loses_context = pdata->loses_context;
        bank->regs = pdata->regs;
 
        if (bank->regs->set_dataout && bank->regs->clr_dataout)
@@ -1337,8 +1338,7 @@ void omap2_gpio_prepare_for_idle(int off_mode)
                u32 l1 = 0, l2 = 0;
                int j;
 
-               /* TODO: Do not use cpu_is_omap34xx */
-               if ((cpu_is_omap34xx()) && (bank->id == 0))
+               if (!bank->loses_context)
                        continue;
 
                for (j = 0; j < hweight_long(bank->dbck_enable_mask); j++)
@@ -1405,8 +1405,7 @@ void omap2_gpio_resume_after_idle(void)
                u32 l = 0, gen, gen0, gen1;
                int j;
 
-               /* TODO: Do not use cpu_is_omap34xx */
-               if ((cpu_is_omap34xx()) && (bank->id == 0))
+               if (!bank->loses_context)
                        continue;
 
                for (j = 0; j < hweight_long(bank->dbck_enable_mask); j++)
@@ -1505,7 +1504,7 @@ void omap_gpio_save_context(void)
        list_for_each_entry(bank, &omap_gpio_list, node) {
                i++;
 
-               if (bank->id == 0)
+               if (!bank->loses_context)
                        continue;
 
                gpio_context[i].irqenable1 =
@@ -1539,7 +1538,7 @@ void omap_gpio_restore_context(void)
        list_for_each_entry(bank, &omap_gpio_list, node) {
                i++;
 
-               if (bank->id == 0)
+               if (!bank->loses_context)
                        continue;
 
                __raw_writel(gpio_context[i].irqenable1,