提交 5faf9801 编写于 作者: M Martyn Welch 提交者: Bartosz Golaszewski

gpio: pca953x: Swap if statements to save later complexity

A later patch in the series adds support for a further chip type that
shares some similarity with the PCA953X_TYPE. In order to keep the logic
simple, swap over the if and else portions where checks are made against
PCA953X_TYPE and instead check for PCA957X_TYPE.
Signed-off-by: NMartyn Welch <martyn.welch@collabora.com>
Reviewed-by: NLinus Walleij <linus.walleij@linaro.org>
Reviewed-by: NAndy Shevchenko <andy.shevchenko@gmail.com>
Signed-off-by: NBartosz Golaszewski <brgl@bgdev.pl>
上级 b122624a
...@@ -294,13 +294,13 @@ static bool pca953x_readable_register(struct device *dev, unsigned int reg) ...@@ -294,13 +294,13 @@ static bool pca953x_readable_register(struct device *dev, unsigned int reg)
struct pca953x_chip *chip = dev_get_drvdata(dev); struct pca953x_chip *chip = dev_get_drvdata(dev);
u32 bank; u32 bank;
if (PCA_CHIP_TYPE(chip->driver_data) == PCA953X_TYPE) { if (PCA_CHIP_TYPE(chip->driver_data) == PCA957X_TYPE) {
bank = PCA953x_BANK_INPUT | PCA953x_BANK_OUTPUT |
PCA953x_BANK_POLARITY | PCA953x_BANK_CONFIG;
} else {
bank = PCA957x_BANK_INPUT | PCA957x_BANK_OUTPUT | bank = PCA957x_BANK_INPUT | PCA957x_BANK_OUTPUT |
PCA957x_BANK_POLARITY | PCA957x_BANK_CONFIG | PCA957x_BANK_POLARITY | PCA957x_BANK_CONFIG |
PCA957x_BANK_BUSHOLD; PCA957x_BANK_BUSHOLD;
} else {
bank = PCA953x_BANK_INPUT | PCA953x_BANK_OUTPUT |
PCA953x_BANK_POLARITY | PCA953x_BANK_CONFIG;
} }
if (chip->driver_data & PCA_PCAL) { if (chip->driver_data & PCA_PCAL) {
...@@ -317,12 +317,12 @@ static bool pca953x_writeable_register(struct device *dev, unsigned int reg) ...@@ -317,12 +317,12 @@ static bool pca953x_writeable_register(struct device *dev, unsigned int reg)
struct pca953x_chip *chip = dev_get_drvdata(dev); struct pca953x_chip *chip = dev_get_drvdata(dev);
u32 bank; u32 bank;
if (PCA_CHIP_TYPE(chip->driver_data) == PCA953X_TYPE) { if (PCA_CHIP_TYPE(chip->driver_data) == PCA957X_TYPE) {
bank = PCA953x_BANK_OUTPUT | PCA953x_BANK_POLARITY |
PCA953x_BANK_CONFIG;
} else {
bank = PCA957x_BANK_OUTPUT | PCA957x_BANK_POLARITY | bank = PCA957x_BANK_OUTPUT | PCA957x_BANK_POLARITY |
PCA957x_BANK_CONFIG | PCA957x_BANK_BUSHOLD; PCA957x_BANK_CONFIG | PCA957x_BANK_BUSHOLD;
} else {
bank = PCA953x_BANK_OUTPUT | PCA953x_BANK_POLARITY |
PCA953x_BANK_CONFIG;
} }
if (chip->driver_data & PCA_PCAL) if (chip->driver_data & PCA_PCAL)
...@@ -337,10 +337,10 @@ static bool pca953x_volatile_register(struct device *dev, unsigned int reg) ...@@ -337,10 +337,10 @@ static bool pca953x_volatile_register(struct device *dev, unsigned int reg)
struct pca953x_chip *chip = dev_get_drvdata(dev); struct pca953x_chip *chip = dev_get_drvdata(dev);
u32 bank; u32 bank;
if (PCA_CHIP_TYPE(chip->driver_data) == PCA953X_TYPE) if (PCA_CHIP_TYPE(chip->driver_data) == PCA957X_TYPE)
bank = PCA953x_BANK_INPUT;
else
bank = PCA957x_BANK_INPUT; bank = PCA957x_BANK_INPUT;
else
bank = PCA953x_BANK_INPUT;
if (chip->driver_data & PCA_PCAL) if (chip->driver_data & PCA_PCAL)
bank |= PCAL9xxx_BANK_IRQ_STAT; bank |= PCAL9xxx_BANK_IRQ_STAT;
...@@ -1071,13 +1071,12 @@ static int pca953x_probe(struct i2c_client *client, ...@@ -1071,13 +1071,12 @@ static int pca953x_probe(struct i2c_client *client,
/* initialize cached registers from their original values. /* initialize cached registers from their original values.
* we can't share this chip with another i2c master. * we can't share this chip with another i2c master.
*/ */
if (PCA_CHIP_TYPE(chip->driver_data) == PCA957X_TYPE) {
if (PCA_CHIP_TYPE(chip->driver_data) == PCA953X_TYPE) {
chip->regs = &pca953x_regs;
ret = device_pca95xx_init(chip, invert);
} else {
chip->regs = &pca957x_regs; chip->regs = &pca957x_regs;
ret = device_pca957x_init(chip, invert); ret = device_pca957x_init(chip, invert);
} else {
chip->regs = &pca953x_regs;
ret = device_pca95xx_init(chip, invert);
} }
if (ret) if (ret)
goto err_exit; goto err_exit;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册