Browse Source

MLK-16219 pca953x_gpio: Clear the polarity invert register at init

The pca953x_gpio driver uses default value of polarity inversion register.
For some devices like PCA9557 and MAX7310, their polarity inversion register
default value is 0xf0. So for high 4 ports, when reading their values,
the values are inverted as the actual level.

This patch clears the polarity inversion register to 0 at init. So that the port read
and write values are aligned.

Signed-off-by: Ye Li <ye.li@nxp.com>
Acked-by: Fugang Duan <fugang.duan@nxp.com>
Acked-by: Peng Fan <peng.fan@nxp.com>
(cherry picked from commit cb20ff23c8)
Ye Li 3 years ago
parent
commit
a4f66fcc00
1 changed files with 29 additions and 0 deletions
  1. +29
    -0
      drivers/gpio/pca953x_gpio.c

+ 29
- 0
drivers/gpio/pca953x_gpio.c View File

@ -132,6 +132,26 @@ static int pca953x_read_regs(struct udevice *dev, int reg, u8 *val)
return ret;
}
static int pca953x_write_regs(struct udevice *dev, int reg, u8 *val)
{
struct pca953x_info *info = dev_get_platdata(dev);
int ret = 0;
if (info->gpio_count <= 8) {
ret = dm_i2c_write(dev, reg, val, 1);
} else if (info->gpio_count <= 16) {
ret = dm_i2c_write(dev, reg << 1, val, info->bank_count);
} else if (info->gpio_count == 40) {
/* Auto increment */
ret = dm_i2c_write(dev, (reg << 3) | 0x80, val, info->bank_count);
} else {
dev_err(dev, "Unsupported now\n");
return -EINVAL;
}
return ret;
}
static int pca953x_is_output(struct udevice *dev, int offset)
{
struct pca953x_info *info = dev_get_platdata(dev);
@ -254,6 +274,7 @@ static int pca953x_probe(struct udevice *dev)
int addr;
ulong driver_data;
int ret;
u8 val[MAX_BANK];
if (!info) {
dev_err(dev, "platdata not ready\n");
@ -299,6 +320,14 @@ static int pca953x_probe(struct udevice *dev)
return ret;
}
/* Clear the polarity registers to no invert */
memset(val, 0, MAX_BANK);
ret = pca953x_write_regs(dev, PCA953X_INVERT, &val);
if (ret) {
dev_err(dev, "Error writing invert register\n");
return ret;
}
snprintf(name, sizeof(name), "gpio@%x_", info->addr);
str = strdup(name);
if (!str)


Loading…
Cancel
Save