lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <808c8e9d1003010804r331d39a6g9cf520cb27595e75@mail.gmail.com>
Date:	Mon, 1 Mar 2010 10:04:19 -0600
From:	Ben Gardner <gardner.ben@...il.com>
To:	Andrew Morton <akpm@...ux-foundation.org>,
	Andres Salomon <dilinger@...labora.co.uk>
Cc:	linux-kernel@...r.kernel.org,
	David Brownell <dbrownell@...rs.sourceforge.net>,
	Mark Brown <broonie@...nsource.wolfsonmicro.com>
Subject: [PATCH] gpio: cs5535-gpio: fix input direction

gpio: cs5535-gpio: fix input direction

The cs5535-gpio driver's get() function was returning the output value.
This means that the GPIO pins would never work as an input, even if configured
as an input.
The driver should return the READ_BACK value, which is the sensed line value.
To make that work when the direction is 'output', INPUT_ENABLE needs to be set.

In addition, the driver was not disabling OUTPUT_ENABLE when the
direction is set to 'input'. That would cause the GPIO to continue to
drive the pin if the direction was ever set to output.

This issue was noticed when attempting to use the gpiolib driver to read
an external input. I had previously been using the char/cs5535-gpio driver.

This patch should also be applied to 2.6.33.x, as that is the first version
that contains the gpio/cs5535-gpio driver.

Signed-off-by: Ben Gardner <gardner.ben@...il.com>
CC: Andres Salomon <dilinger@...labora.co.uk>
CC: Andrew Morton <akpm@...ux-foundation.org>
CC: David Brownell <dbrownell@...rs.sourceforge.net>
CC: Mark Brown <broonie@...nsource.wolfsonmicro.com>
---
This patch replaces the following patches:
cs5535_gpio-gpio_chipget-should-return-the-input-value.patch
olpc-alsa-fix-cs5535audios-mic-gpio-to-enable-input.patch

References:
http://lkml.org/lkml/2010/2/27/253
http://lkml.org/lkml/2010/2/23/311
http://lkml.org/lkml/2010/2/26/335

 drivers/gpio/cs5535-gpio.c |    4 +++-
 1 files changed, 3 insertions(+), 1 deletions(-)

diff --git a/drivers/gpio/cs5535-gpio.c b/drivers/gpio/cs5535-gpio.c
index 0fdbe94..0c3c498 100644
--- a/drivers/gpio/cs5535-gpio.c
+++ b/drivers/gpio/cs5535-gpio.c
@@ -154,7 +154,7 @@ static int chip_gpio_request(struct gpio_chip *c,
unsigned offset)

 static int chip_gpio_get(struct gpio_chip *chip, unsigned offset)
 {
-	return cs5535_gpio_isset(offset, GPIO_OUTPUT_VAL);
+	return cs5535_gpio_isset(offset, GPIO_READ_BACK);
 }

 static void chip_gpio_set(struct gpio_chip *chip, unsigned offset, int val)
@@ -172,6 +172,7 @@ static int chip_direction_input(struct gpio_chip
*c, unsigned offset)

 	spin_lock_irqsave(&chip->lock, flags);
 	__cs5535_gpio_set(chip, offset, GPIO_INPUT_ENABLE);
+	__cs5535_gpio_clear(chip, offset, GPIO_OUTPUT_ENABLE);
 	spin_unlock_irqrestore(&chip->lock, flags);

 	return 0;
@@ -184,6 +185,7 @@ static int chip_direction_output(struct gpio_chip
*c, unsigned offset, int val)

 	spin_lock_irqsave(&chip->lock, flags);

+	__cs5535_gpio_set(chip, offset, GPIO_INPUT_ENABLE);
 	__cs5535_gpio_set(chip, offset, GPIO_OUTPUT_ENABLE);
 	if (val)
 		__cs5535_gpio_set(chip, offset, GPIO_OUTPUT_VAL);
-- 
1.6.4
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ