Commit 6a7b36aa authored by Chandrabhanu Mahapatra's avatar Chandrabhanu Mahapatra Committed by Linus Walleij

GPIO: PCA953X: Increase size of invert variable to support 24 bit

TCA6424 is a low voltage 24 bit I2C and SMBus I/O expander of pca953x family
similar to its 16 bit predecessor TCA6416. It comes with three 8-bit active
Input, Output, Polarity Inversion and Configuration registers each. The polarity
of Input ports can be reversed by setting the appropiate bit in Polarity
Inversion registers.

The variables corresponding to Input, Output and Configuration registers have
already been updated to support 24 bit values. This patch thus updates the
invert variable of PCA953X platform data to support 24 bit.
Signed-off-by: default avatarChandrabhanu Mahapatra <cmahapatra@ti.com>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 34672013
...@@ -568,7 +568,7 @@ static void pca953x_irq_teardown(struct pca953x_chip *chip) ...@@ -568,7 +568,7 @@ static void pca953x_irq_teardown(struct pca953x_chip *chip)
* WARNING: This is DEPRECATED and will be removed eventually! * WARNING: This is DEPRECATED and will be removed eventually!
*/ */
static void static void
pca953x_get_alt_pdata(struct i2c_client *client, int *gpio_base, int *invert) pca953x_get_alt_pdata(struct i2c_client *client, int *gpio_base, u32 *invert)
{ {
struct device_node *node; struct device_node *node;
const __be32 *val; const __be32 *val;
...@@ -596,13 +596,13 @@ pca953x_get_alt_pdata(struct i2c_client *client, int *gpio_base, int *invert) ...@@ -596,13 +596,13 @@ pca953x_get_alt_pdata(struct i2c_client *client, int *gpio_base, int *invert)
} }
#else #else
static void static void
pca953x_get_alt_pdata(struct i2c_client *client, int *gpio_base, int *invert) pca953x_get_alt_pdata(struct i2c_client *client, int *gpio_base, u32 *invert)
{ {
*gpio_base = -1; *gpio_base = -1;
} }
#endif #endif
static int __devinit device_pca953x_init(struct pca953x_chip *chip, int invert) static int __devinit device_pca953x_init(struct pca953x_chip *chip, u32 invert)
{ {
int ret; int ret;
...@@ -621,7 +621,7 @@ static int __devinit device_pca953x_init(struct pca953x_chip *chip, int invert) ...@@ -621,7 +621,7 @@ static int __devinit device_pca953x_init(struct pca953x_chip *chip, int invert)
return ret; return ret;
} }
static int __devinit device_pca957x_init(struct pca953x_chip *chip, int invert) static int __devinit device_pca957x_init(struct pca953x_chip *chip, u32 invert)
{ {
int ret; int ret;
u32 val = 0; u32 val = 0;
...@@ -657,8 +657,9 @@ static int __devinit pca953x_probe(struct i2c_client *client, ...@@ -657,8 +657,9 @@ static int __devinit pca953x_probe(struct i2c_client *client,
{ {
struct pca953x_platform_data *pdata; struct pca953x_platform_data *pdata;
struct pca953x_chip *chip; struct pca953x_chip *chip;
int irq_base=0, invert=0; int irq_base = 0;
int ret; int ret;
u32 invert = 0;
chip = kzalloc(sizeof(struct pca953x_chip), GFP_KERNEL); chip = kzalloc(sizeof(struct pca953x_chip), GFP_KERNEL);
if (chip == NULL) if (chip == NULL)
......
...@@ -11,7 +11,7 @@ struct pca953x_platform_data { ...@@ -11,7 +11,7 @@ struct pca953x_platform_data {
unsigned gpio_base; unsigned gpio_base;
/* initial polarity inversion setting */ /* initial polarity inversion setting */
uint16_t invert; u32 invert;
/* interrupt base */ /* interrupt base */
int irq_base; int irq_base;
......
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