aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLinus Walleij <linus.walleij@linaro.org>2017-10-20 09:45:34 -0400
committerLinus Walleij <linus.walleij@linaro.org>2017-10-25 05:25:39 -0400
commitd74423687f9d70417bfec68121cbd35f79bb170f (patch)
treec65c4dbc651ca3f00ff6eab9053f98c9df914124
parent5c7b0c4e7d5cd9850a93b8a1ea092baf4c8b3cd0 (diff)
gpio: brcmstb: Do not use gc->pin2mask()
The pin2mask() accessor only shuffles BIT ORDER in big endian systems, i.e. the bitstuffing is swizzled big endian so "bit 0" is bit 7 or bit 15 or bit 31 or so. The brcmstb only uses big endian BYTE ORDER which will be taken car of by the ->write_reg() callback. Just use BIT(offset) to assign the bit. Acked-by: Gregory Fong <gregory.0xf0@gmail.com> Reviewed-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
-rw-r--r--drivers/gpio/gpio-brcmstb.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/gpio/gpio-brcmstb.c b/drivers/gpio/gpio-brcmstb.c
index 27e92e57adae..9b8fcca7ad17 100644
--- a/drivers/gpio/gpio-brcmstb.c
+++ b/drivers/gpio/gpio-brcmstb.c
@@ -20,6 +20,7 @@
20#include <linux/irqchip/chained_irq.h> 20#include <linux/irqchip/chained_irq.h>
21#include <linux/interrupt.h> 21#include <linux/interrupt.h>
22#include <linux/reboot.h> 22#include <linux/reboot.h>
23#include <linux/bitops.h>
23 24
24#define GIO_BANK_SIZE 0x20 25#define GIO_BANK_SIZE 0x20
25#define GIO_ODEN(bank) (((bank) * GIO_BANK_SIZE) + 0x00) 26#define GIO_ODEN(bank) (((bank) * GIO_BANK_SIZE) + 0x00)
@@ -68,16 +69,15 @@ static void brcmstb_gpio_set_imask(struct brcmstb_gpio_bank *bank,
68{ 69{
69 struct gpio_chip *gc = &bank->gc; 70 struct gpio_chip *gc = &bank->gc;
70 struct brcmstb_gpio_priv *priv = bank->parent_priv; 71 struct brcmstb_gpio_priv *priv = bank->parent_priv;
71 u32 mask = gc->pin2mask(gc, offset);
72 u32 imask; 72 u32 imask;
73 unsigned long flags; 73 unsigned long flags;
74 74
75 spin_lock_irqsave(&gc->bgpio_lock, flags); 75 spin_lock_irqsave(&gc->bgpio_lock, flags);
76 imask = gc->read_reg(priv->reg_base + GIO_MASK(bank->id)); 76 imask = gc->read_reg(priv->reg_base + GIO_MASK(bank->id));
77 if (enable) 77 if (enable)
78 imask |= mask; 78 imask |= BIT(offset);
79 else 79 else
80 imask &= ~mask; 80 imask &= ~BIT(offset);
81 gc->write_reg(priv->reg_base + GIO_MASK(bank->id), imask); 81 gc->write_reg(priv->reg_base + GIO_MASK(bank->id), imask);
82 spin_unlock_irqrestore(&gc->bgpio_lock, flags); 82 spin_unlock_irqrestore(&gc->bgpio_lock, flags);
83} 83}