gpio/omap: avoid cpu checks during module ena/disable
Remove cpu-is checks while enabling/disabling OMAP GPIO module during a gpio request/free. Signed-off-by: Charulatha V <charu@ti.com> Reviewed-by: Santosh Shilimkar <santosh.shilimkar@ti.com> Acked-by: Tony Lindgren <tony@atomide.com> Reviewed-by: Kevin Hilman <khilman@ti.com> Signed-off-by: Kevin Hilman <khilman@ti.com>
This commit is contained in:
Родитель
803a24343f
Коммит
c8eef65a2f
|
@ -88,6 +88,7 @@ static int omap2_gpio_dev_init(struct omap_hwmod *oh, void *unused)
|
||||||
pdata->regs->clr_irqenable = OMAP24XX_GPIO_CLEARIRQENABLE1;
|
pdata->regs->clr_irqenable = OMAP24XX_GPIO_CLEARIRQENABLE1;
|
||||||
pdata->regs->debounce = OMAP24XX_GPIO_DEBOUNCE_VAL;
|
pdata->regs->debounce = OMAP24XX_GPIO_DEBOUNCE_VAL;
|
||||||
pdata->regs->debounce_en = OMAP24XX_GPIO_DEBOUNCE_EN;
|
pdata->regs->debounce_en = OMAP24XX_GPIO_DEBOUNCE_EN;
|
||||||
|
pdata->regs->ctrl = OMAP24XX_GPIO_CTRL;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
pdata->bank_type = METHOD_GPIO_44XX;
|
pdata->bank_type = METHOD_GPIO_44XX;
|
||||||
|
@ -104,6 +105,7 @@ static int omap2_gpio_dev_init(struct omap_hwmod *oh, void *unused)
|
||||||
pdata->regs->clr_irqenable = OMAP4_GPIO_IRQSTATUSCLR0;
|
pdata->regs->clr_irqenable = OMAP4_GPIO_IRQSTATUSCLR0;
|
||||||
pdata->regs->debounce = OMAP4_GPIO_DEBOUNCINGTIME;
|
pdata->regs->debounce = OMAP4_GPIO_DEBOUNCINGTIME;
|
||||||
pdata->regs->debounce_en = OMAP4_GPIO_DEBOUNCENABLE;
|
pdata->regs->debounce_en = OMAP4_GPIO_DEBOUNCENABLE;
|
||||||
|
pdata->regs->ctrl = OMAP4_GPIO_CTRL;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
WARN(1, "Invalid gpio bank_type\n");
|
WARN(1, "Invalid gpio bank_type\n");
|
||||||
|
|
|
@ -188,6 +188,7 @@ struct omap_gpio_reg_offs {
|
||||||
u16 clr_irqenable;
|
u16 clr_irqenable;
|
||||||
u16 debounce;
|
u16 debounce;
|
||||||
u16 debounce_en;
|
u16 debounce_en;
|
||||||
|
u16 ctrl;
|
||||||
|
|
||||||
bool irqenable_inv;
|
bool irqenable_inv;
|
||||||
};
|
};
|
||||||
|
|
|
@ -83,6 +83,7 @@ struct gpio_bank {
|
||||||
|
|
||||||
#define GPIO_INDEX(bank, gpio) (gpio % bank->width)
|
#define GPIO_INDEX(bank, gpio) (gpio % bank->width)
|
||||||
#define GPIO_BIT(bank, gpio) (1 << GPIO_INDEX(bank, gpio))
|
#define GPIO_BIT(bank, gpio) (1 << GPIO_INDEX(bank, gpio))
|
||||||
|
#define GPIO_MOD_CTRL_BIT BIT(0)
|
||||||
|
|
||||||
static void _set_gpio_direction(struct gpio_bank *bank, int gpio, int is_input)
|
static void _set_gpio_direction(struct gpio_bank *bank, int gpio, int is_input)
|
||||||
{
|
{
|
||||||
|
@ -577,22 +578,18 @@ static int omap_gpio_request(struct gpio_chip *chip, unsigned offset)
|
||||||
__raw_writel(__raw_readl(reg) | (1 << offset), reg);
|
__raw_writel(__raw_readl(reg) | (1 << offset), reg);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (!cpu_class_is_omap1()) {
|
if (bank->regs->ctrl && !bank->mod_usage) {
|
||||||
if (!bank->mod_usage) {
|
void __iomem *reg = bank->base + bank->regs->ctrl;
|
||||||
void __iomem *reg = bank->base;
|
u32 ctrl;
|
||||||
u32 ctrl;
|
|
||||||
|
|
||||||
if (cpu_is_omap24xx() || cpu_is_omap34xx())
|
ctrl = __raw_readl(reg);
|
||||||
reg += OMAP24XX_GPIO_CTRL;
|
/* Module is enabled, clocks are not gated */
|
||||||
else if (cpu_is_omap44xx())
|
ctrl &= ~GPIO_MOD_CTRL_BIT;
|
||||||
reg += OMAP4_GPIO_CTRL;
|
__raw_writel(ctrl, reg);
|
||||||
ctrl = __raw_readl(reg);
|
|
||||||
/* Module is enabled, clocks are not gated */
|
|
||||||
ctrl &= 0xFFFFFFFE;
|
|
||||||
__raw_writel(ctrl, reg);
|
|
||||||
}
|
|
||||||
bank->mod_usage |= 1 << offset;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bank->mod_usage |= 1 << offset;
|
||||||
|
|
||||||
spin_unlock_irqrestore(&bank->lock, flags);
|
spin_unlock_irqrestore(&bank->lock, flags);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -625,22 +622,18 @@ static void omap_gpio_free(struct gpio_chip *chip, unsigned offset)
|
||||||
__raw_writel(1 << offset, reg);
|
__raw_writel(1 << offset, reg);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (!cpu_class_is_omap1()) {
|
bank->mod_usage &= ~(1 << offset);
|
||||||
bank->mod_usage &= ~(1 << offset);
|
|
||||||
if (!bank->mod_usage) {
|
|
||||||
void __iomem *reg = bank->base;
|
|
||||||
u32 ctrl;
|
|
||||||
|
|
||||||
if (cpu_is_omap24xx() || cpu_is_omap34xx())
|
if (bank->regs->ctrl && !bank->mod_usage) {
|
||||||
reg += OMAP24XX_GPIO_CTRL;
|
void __iomem *reg = bank->base + bank->regs->ctrl;
|
||||||
else if (cpu_is_omap44xx())
|
u32 ctrl;
|
||||||
reg += OMAP4_GPIO_CTRL;
|
|
||||||
ctrl = __raw_readl(reg);
|
ctrl = __raw_readl(reg);
|
||||||
/* Module is disabled, clocks are gated */
|
/* Module is disabled, clocks are gated */
|
||||||
ctrl |= 1;
|
ctrl |= GPIO_MOD_CTRL_BIT;
|
||||||
__raw_writel(ctrl, reg);
|
__raw_writel(ctrl, reg);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
_reset_gpio(bank, bank->chip.base + offset);
|
_reset_gpio(bank, bank->chip.base + offset);
|
||||||
spin_unlock_irqrestore(&bank->lock, flags);
|
spin_unlock_irqrestore(&bank->lock, flags);
|
||||||
}
|
}
|
||||||
|
|
Загрузка…
Ссылка в новой задаче