Commit 2c0aafdf authored by Arturas Moskvinas's avatar Arturas Moskvinas Committed by Linus Walleij

pinctrl: mcp23s08: Check only GPIOs which have interrupts enabled

GPINTEN register contains information about GPIOs with enabled
interrupts no need to check other GPIOs for changes.
Signed-off-by: default avatarArturas Moskvinas <arturas.moskvinas@gmail.com>
Link: https://lore.kernel.org/r/20240201141406.32484-2-arturas.moskvinas@gmail.comSigned-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 8e4cc358
...@@ -375,7 +375,8 @@ mcp23s08_direction_output(struct gpio_chip *chip, unsigned offset, int value) ...@@ -375,7 +375,8 @@ mcp23s08_direction_output(struct gpio_chip *chip, unsigned offset, int value)
static irqreturn_t mcp23s08_irq(int irq, void *data) static irqreturn_t mcp23s08_irq(int irq, void *data)
{ {
struct mcp23s08 *mcp = data; struct mcp23s08 *mcp = data;
int intcap, intcon, intf, i, gpio, gpio_orig, intcap_mask, defval; int intcap, intcon, intf, i, gpio, gpio_orig, intcap_mask, defval, gpinten;
unsigned long int enabled_interrupts;
unsigned int child_irq; unsigned int child_irq;
bool intf_set, intcap_changed, gpio_bit_changed, bool intf_set, intcap_changed, gpio_bit_changed,
defval_changed, gpio_set; defval_changed, gpio_set;
...@@ -395,6 +396,9 @@ static irqreturn_t mcp23s08_irq(int irq, void *data) ...@@ -395,6 +396,9 @@ static irqreturn_t mcp23s08_irq(int irq, void *data)
if (mcp_read(mcp, MCP_INTCON, &intcon)) if (mcp_read(mcp, MCP_INTCON, &intcon))
goto unlock; goto unlock;
if (mcp_read(mcp, MCP_GPINTEN, &gpinten))
goto unlock;
if (mcp_read(mcp, MCP_DEFVAL, &defval)) if (mcp_read(mcp, MCP_DEFVAL, &defval))
goto unlock; goto unlock;
...@@ -410,9 +414,12 @@ static irqreturn_t mcp23s08_irq(int irq, void *data) ...@@ -410,9 +414,12 @@ static irqreturn_t mcp23s08_irq(int irq, void *data)
"intcap 0x%04X intf 0x%04X gpio_orig 0x%04X gpio 0x%04X\n", "intcap 0x%04X intf 0x%04X gpio_orig 0x%04X gpio 0x%04X\n",
intcap, intf, gpio_orig, gpio); intcap, intf, gpio_orig, gpio);
for (i = 0; i < mcp->chip.ngpio; i++) { enabled_interrupts = gpinten;
/* We must check all of the inputs on the chip, for_each_set_bit(i, &enabled_interrupts, mcp->chip.ngpio) {
* otherwise we may not notice a change on >=2 pins. /*
* We must check all of the inputs with enabled interrupts
* on the chip, otherwise we may not notice a change
* on more than one pin.
* *
* On at least the mcp23s17, INTCAP is only updated * On at least the mcp23s17, INTCAP is only updated
* one byte at a time(INTCAPA and INTCAPB are * one byte at a time(INTCAPA and INTCAPB are
......
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