Commit ca3ffe91 authored by Leed Aguilar's avatar Leed Aguilar Committed by Linus Walleij

gpio/pca953x: increase variables size to support 24 bit of data

Increase variable size from u16 to u32 to allocate 24 bit of data required for
the TCA6424 I/O expander device type.
Signed-off-by: default avatarLeed Aguilar <leed.aguilar@ti.com>
Signed-off-by: default avatarChandrabhanu Mahapatra <cmahapatra@ti.com>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 6a7b36aa
...@@ -78,10 +78,10 @@ struct pca953x_chip { ...@@ -78,10 +78,10 @@ struct pca953x_chip {
#ifdef CONFIG_GPIO_PCA953X_IRQ #ifdef CONFIG_GPIO_PCA953X_IRQ
struct mutex irq_lock; struct mutex irq_lock;
uint16_t irq_mask; u32 irq_mask;
uint16_t irq_stat; u32 irq_stat;
uint16_t irq_trig_raise; u32 irq_trig_raise;
uint16_t irq_trig_fall; u32 irq_trig_fall;
int irq_base; int irq_base;
#endif #endif
...@@ -353,8 +353,8 @@ static void pca953x_irq_bus_lock(struct irq_data *d) ...@@ -353,8 +353,8 @@ static void pca953x_irq_bus_lock(struct irq_data *d)
static void pca953x_irq_bus_sync_unlock(struct irq_data *d) static void pca953x_irq_bus_sync_unlock(struct irq_data *d)
{ {
struct pca953x_chip *chip = irq_data_get_irq_chip_data(d); struct pca953x_chip *chip = irq_data_get_irq_chip_data(d);
uint16_t new_irqs; u32 new_irqs;
uint16_t level; u32 level;
/* Look for any newly setup interrupt */ /* Look for any newly setup interrupt */
new_irqs = chip->irq_trig_fall | chip->irq_trig_raise; new_irqs = chip->irq_trig_fall | chip->irq_trig_raise;
...@@ -372,8 +372,8 @@ static void pca953x_irq_bus_sync_unlock(struct irq_data *d) ...@@ -372,8 +372,8 @@ static void pca953x_irq_bus_sync_unlock(struct irq_data *d)
static int pca953x_irq_set_type(struct irq_data *d, unsigned int type) static int pca953x_irq_set_type(struct irq_data *d, unsigned int type)
{ {
struct pca953x_chip *chip = irq_data_get_irq_chip_data(d); struct pca953x_chip *chip = irq_data_get_irq_chip_data(d);
uint16_t level = d->irq - chip->irq_base; u32 level = d->irq - chip->irq_base;
uint16_t mask = 1 << level; u32 mask = 1 << level;
if (!(type & IRQ_TYPE_EDGE_BOTH)) { if (!(type & IRQ_TYPE_EDGE_BOTH)) {
dev_err(&chip->client->dev, "irq %d: unsupported type %d\n", dev_err(&chip->client->dev, "irq %d: unsupported type %d\n",
...@@ -403,12 +403,12 @@ static struct irq_chip pca953x_irq_chip = { ...@@ -403,12 +403,12 @@ static struct irq_chip pca953x_irq_chip = {
.irq_set_type = pca953x_irq_set_type, .irq_set_type = pca953x_irq_set_type,
}; };
static uint16_t pca953x_irq_pending(struct pca953x_chip *chip) static u32 pca953x_irq_pending(struct pca953x_chip *chip)
{ {
u32 cur_stat; u32 cur_stat;
uint16_t old_stat; u32 old_stat;
uint16_t pending; u32 pending;
uint16_t trigger; u32 trigger;
int ret, offset = 0; int ret, offset = 0;
switch (chip->chip_type) { switch (chip->chip_type) {
...@@ -444,8 +444,8 @@ static uint16_t pca953x_irq_pending(struct pca953x_chip *chip) ...@@ -444,8 +444,8 @@ static uint16_t pca953x_irq_pending(struct pca953x_chip *chip)
static irqreturn_t pca953x_irq_handler(int irq, void *devid) static irqreturn_t pca953x_irq_handler(int irq, void *devid)
{ {
struct pca953x_chip *chip = devid; struct pca953x_chip *chip = devid;
uint16_t pending; u32 pending;
uint16_t level; u32 level;
pending = pca953x_irq_pending(chip); pending = pca953x_irq_pending(chip);
......
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