From mboxrd@z Thu Jan 1 00:00:00 1970 From: Ricardo Ribalda Delgado Subject: [PATCH] gpio-pca953x: Fix read for chips with more than 8 gpios Date: Wed, 14 Aug 2013 23:29:09 +0200 Message-ID: <1376515749-9704-1-git-send-email-ricardo.ribalda@gmail.com> Return-path: Received: from mail-lb0-f172.google.com ([209.85.217.172]:52555 "EHLO mail-lb0-f172.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933204Ab3HNV3P (ORCPT ); Wed, 14 Aug 2013 17:29:15 -0400 Received: by mail-lb0-f172.google.com with SMTP id o7so106873lbv.17 for ; Wed, 14 Aug 2013 14:29:14 -0700 (PDT) Sender: linux-gpio-owner@vger.kernel.org List-Id: linux-gpio@vger.kernel.org To: linux-gpio@vger.kernel.org Cc: Ricardo Ribalda Delgado pca953x_read_single returns ONLY the value of the 8 inputs of the same bank. off can have a value from 0 to 15, therefore we have to find the offset of that gpio within that bank. Without this patch gpios 8-15 will always be read as zero. Signed-off-by: Ricardo Ribalda Delgado --- drivers/gpio/gpio-pca953x.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/gpio/gpio-pca953x.c b/drivers/gpio/gpio-pca953x.c index 426c51d..1a7ab13 100644 --- a/drivers/gpio/gpio-pca953x.c +++ b/drivers/gpio/gpio-pca953x.c @@ -308,7 +308,7 @@ static int pca953x_gpio_get_value(struct gpio_chip *gc, unsigned off) return 0; } - return (reg_val & (1u << off)) ? 1 : 0; + return (reg_val & (1u << (off % BANK_SZ))) ? 1 : 0; } static void pca953x_gpio_set_value(struct gpio_chip *gc, unsigned off, int val) -- 1.7.10.4