Commit f160a289 authored by Gabor Juhos's avatar Gabor Juhos Committed by John Crispin

MIPS: ath79: simplify ath79_gpio_function_* routines

Make ath79_gpio_function_{en,dis}able to be wrappers
around ath79_gpio_function_setup.
Signed-off-by: default avatarGabor Juhos <juhosg@openwrt.org>
Patchwork: http://patchwork.linux-mips.org/patch/4871/Signed-off-by: default avatarJohn Crispin <blogic@openwrt.org>
parent 8838becd
...@@ -154,46 +154,28 @@ static void __iomem *ath79_gpio_get_function_reg(void) ...@@ -154,46 +154,28 @@ static void __iomem *ath79_gpio_get_function_reg(void)
return ath79_gpio_base + reg; return ath79_gpio_base + reg;
} }
void ath79_gpio_function_enable(u32 mask) void ath79_gpio_function_setup(u32 set, u32 clear)
{ {
void __iomem *reg = ath79_gpio_get_function_reg(); void __iomem *reg = ath79_gpio_get_function_reg();
unsigned long flags; unsigned long flags;
spin_lock_irqsave(&ath79_gpio_lock, flags); spin_lock_irqsave(&ath79_gpio_lock, flags);
__raw_writel(__raw_readl(reg) | mask, reg); __raw_writel((__raw_readl(reg) & ~clear) | set, reg);
/* flush write */ /* flush write */
__raw_readl(reg); __raw_readl(reg);
spin_unlock_irqrestore(&ath79_gpio_lock, flags); spin_unlock_irqrestore(&ath79_gpio_lock, flags);
} }
void ath79_gpio_function_disable(u32 mask) void ath79_gpio_function_enable(u32 mask)
{ {
void __iomem *reg = ath79_gpio_get_function_reg(); ath79_gpio_function_setup(mask, 0);
unsigned long flags;
spin_lock_irqsave(&ath79_gpio_lock, flags);
__raw_writel(__raw_readl(reg) & ~mask, reg);
/* flush write */
__raw_readl(reg);
spin_unlock_irqrestore(&ath79_gpio_lock, flags);
} }
void ath79_gpio_function_setup(u32 set, u32 clear) void ath79_gpio_function_disable(u32 mask)
{ {
void __iomem *reg = ath79_gpio_get_function_reg(); ath79_gpio_function_setup(0, mask);
unsigned long flags;
spin_lock_irqsave(&ath79_gpio_lock, flags);
__raw_writel((__raw_readl(reg) & ~clear) | set, reg);
/* flush write */
__raw_readl(reg);
spin_unlock_irqrestore(&ath79_gpio_lock, flags);
} }
void __init ath79_gpio_init(void) void __init ath79_gpio_init(void)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment