2
0
mirror of https://github.com/edk2-porting/linux-next.git synced 2025-01-03 11:13:56 +08:00

gpio: pca953x: Factor out common code from device_pca95xx_init()

The PCA957x and PCA953x init functions are almost the same, except for
the different register mapping and one extra write to BKEN register in
case of PCA957x. Factor out the common code.

Signed-off-by: Marek Vasut <marek.vasut+renesas@gmail.com>
Cc: Bartosz Golaszewski <bgolaszewski@baylibre.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
This commit is contained in:
Marek Vasut 2018-12-12 02:39:55 +01:00 committed by Linus Walleij
parent 90adb09799
commit 7a04aaa32c

View File

@ -119,18 +119,21 @@ struct pca953x_reg_config {
int direction; int direction;
int output; int output;
int input; int input;
int invert;
}; };
static const struct pca953x_reg_config pca953x_regs = { static const struct pca953x_reg_config pca953x_regs = {
.direction = PCA953X_DIRECTION, .direction = PCA953X_DIRECTION,
.output = PCA953X_OUTPUT, .output = PCA953X_OUTPUT,
.input = PCA953X_INPUT, .input = PCA953X_INPUT,
.invert = PCA953X_INVERT,
}; };
static const struct pca953x_reg_config pca957x_regs = { static const struct pca953x_reg_config pca957x_regs = {
.direction = PCA957X_CFG, .direction = PCA957X_CFG,
.output = PCA957X_OUT, .output = PCA957X_OUT,
.input = PCA957X_IN, .input = PCA957X_IN,
.invert = PCA957X_INVRT,
}; };
struct pca953x_chip { struct pca953x_chip {
@ -679,13 +682,11 @@ static int pca953x_irq_setup(struct pca953x_chip *chip,
} }
#endif #endif
static int device_pca953x_init(struct pca953x_chip *chip, u32 invert) static int device_pca95xx_init(struct pca953x_chip *chip, u32 invert)
{ {
int ret; int ret;
u8 val[MAX_BANK]; u8 val[MAX_BANK];
chip->regs = &pca953x_regs;
ret = pca953x_read_regs(chip, chip->regs->output, chip->reg_output); ret = pca953x_read_regs(chip, chip->regs->output, chip->reg_output);
if (ret) if (ret)
goto out; goto out;
@ -701,7 +702,7 @@ static int device_pca953x_init(struct pca953x_chip *chip, u32 invert)
else else
memset(val, 0, NBANK(chip)); memset(val, 0, NBANK(chip));
ret = pca953x_write_regs(chip, PCA953X_INVERT, val); ret = pca953x_write_regs(chip, chip->regs->invert, val);
out: out:
return ret; return ret;
} }
@ -711,22 +712,7 @@ static int device_pca957x_init(struct pca953x_chip *chip, u32 invert)
int ret; int ret;
u8 val[MAX_BANK]; u8 val[MAX_BANK];
chip->regs = &pca957x_regs; ret = device_pca95xx_init(chip, invert);
ret = pca953x_read_regs(chip, chip->regs->output, chip->reg_output);
if (ret)
goto out;
ret = pca953x_read_regs(chip, chip->regs->direction,
chip->reg_direction);
if (ret)
goto out;
/* set platform specific polarity inversion */
if (invert)
memset(val, 0xFF, NBANK(chip));
else
memset(val, 0, NBANK(chip));
ret = pca953x_write_regs(chip, PCA957X_INVRT, val);
if (ret) if (ret)
goto out; goto out;
@ -842,10 +828,13 @@ static int pca953x_probe(struct i2c_client *client,
*/ */
pca953x_setup_gpio(chip, chip->driver_data & PCA_GPIO_MASK); pca953x_setup_gpio(chip, chip->driver_data & PCA_GPIO_MASK);
if (PCA_CHIP_TYPE(chip->driver_data) == PCA953X_TYPE) if (PCA_CHIP_TYPE(chip->driver_data) == PCA953X_TYPE) {
ret = device_pca953x_init(chip, invert); chip->regs = &pca953x_regs;
else ret = device_pca95xx_init(chip, invert);
} else {
chip->regs = &pca957x_regs;
ret = device_pca957x_init(chip, invert); ret = device_pca957x_init(chip, invert);
}
if (ret) if (ret)
goto err_exit; goto err_exit;