From: Sean Anderson <seanga2@gmail.com>
To: u-boot@lists.denx.de
Subject: [PATCH v1 5/8] gpio: dw: Return output value when direction is out
Date: Thu, 5 Mar 2020 13:53:25 -0500 [thread overview]
Message-ID: <20200305185328.951011-6-seanga2@gmail.com> (raw)
In-Reply-To: <20200305185328.951011-1-seanga2@gmail.com>
dm_gpio_ops.get_value can be called when the gpio is either input or
output. The current dw code always returns the input value, which is
invalid if the direction is set to out.
Signed-off-by: Sean Anderson <seanga2@gmail.com>
---
This patch was previously submitted as part of
https://patchwork.ozlabs.org/project/uboot/list/?series=161576
drivers/gpio/dwapb_gpio.c | 19 ++++++++++++-------
1 file changed, 12 insertions(+), 7 deletions(-)
diff --git a/drivers/gpio/dwapb_gpio.c b/drivers/gpio/dwapb_gpio.c
index 09abab5c39..058c5fbfbf 100644
--- a/drivers/gpio/dwapb_gpio.c
+++ b/drivers/gpio/dwapb_gpio.c
@@ -64,13 +64,6 @@ static int dwapb_gpio_direction_output(struct udevice *dev, unsigned pin,
return 0;
}
-static int dwapb_gpio_get_value(struct udevice *dev, unsigned pin)
-{
- struct gpio_dwapb_platdata *plat = dev_get_platdata(dev);
- return !!(readl(plat->base + GPIO_EXT_PORT(plat->bank)) & (1 << pin));
-}
-
-
static int dwapb_gpio_set_value(struct udevice *dev, unsigned pin, int val)
{
struct gpio_dwapb_platdata *plat = dev_get_platdata(dev);
@@ -96,6 +89,18 @@ static int dwapb_gpio_get_function(struct udevice *dev, unsigned offset)
return GPIOF_INPUT;
}
+static int dwapb_gpio_get_value(struct udevice *dev, unsigned pin)
+{
+ struct gpio_dwapb_platdata *plat = dev_get_platdata(dev);
+ u32 value;
+
+ if (dwapb_gpio_get_function(dev, pin) == GPIOF_OUTPUT)
+ value = readl(plat->base + GPIO_SWPORT_DR(plat->bank));
+ else
+ value = readl(plat->base + GPIO_EXT_PORT(plat->bank));
+ return !!(value & BIT(pin));
+}
+
static const struct dm_gpio_ops gpio_dwapb_ops = {
.direction_input = dwapb_gpio_direction_input,
.direction_output = dwapb_gpio_direction_output,
--
2.25.0
next prev parent reply other threads:[~2020-03-05 18:53 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-03-05 18:53 [PATCH v1 0/8] riscv: Add FPIOA and GPIO support for Kendryte K210 Sean Anderson
2020-03-05 18:53 ` [PATCH v1 1/8] pinctrl: Add support for Kendryte K210 FPIOA Sean Anderson
2020-03-05 18:53 ` [PATCH v1 2/8] gpio: sifive: Use generic reg read function Sean Anderson
2020-03-05 18:53 ` [PATCH v1 3/8] gpio: dw: Fix warnings about casting int to pointer Sean Anderson
2020-03-05 18:53 ` [PATCH v1 4/8] gpio: dw: Add a trailing underscore to generated name Sean Anderson
2020-03-05 18:53 ` Sean Anderson [this message]
2020-03-05 18:53 ` [PATCH v1 6/8] led: gpio: Default to using node name if label is absent Sean Anderson
2020-03-05 18:53 ` [PATCH v1 7/8] riscv: Add pinmux and gpio bindings for Kendryte K210 Sean Anderson
2020-03-05 18:53 ` [PATCH v1 8/8] riscv: Add FPIOA and GPIO support " Sean Anderson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20200305185328.951011-6-seanga2@gmail.com \
--to=seanga2@gmail.com \
--cc=u-boot@lists.denx.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox