From: Igor Grinberg <grinberg@compulab.co.il>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH v2 09/11] dm: imx: gpio: Support driver model in MXC gpio driver
Date: Wed, 17 Sep 2014 16:00:16 +0300 [thread overview]
Message-ID: <541985E0.8000502@compulab.co.il> (raw)
In-Reply-To: <1410925884-8767-10-git-send-email-sjg@chromium.org>
On 09/17/14 06:51, Simon Glass wrote:
> Add driver model support with this driver. In this case the platform data
> is in the driver. It would be better to put this into an SOC-specific file,
> but this is best attempted when more boards are moved over to use driver
> model.
>
> Signed-off-by: Simon Glass <sjg@chromium.org>
> ---
>
> Changes in v2:
> - Change 'reserved' to 'requested'
> - Add an internal function to check if a GPIO is requested
> - Tidy up confusing code that creates names for gpio_request()
>
> drivers/gpio/mxc_gpio.c | 302 +++++++++++++++++++++++++++++++++++++++++++++++-
> 1 file changed, 301 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/gpio/mxc_gpio.c b/drivers/gpio/mxc_gpio.c
> index 6a572d5..9435d2f 100644
> --- a/drivers/gpio/mxc_gpio.c
> +++ b/drivers/gpio/mxc_gpio.c
[...]
> +static int mxc_gpio_get_state(struct udevice *dev, unsigned int offset,
> + char *buf, int bufsize)
> +{
> + struct gpio_dev_priv *uc_priv = dev->uclass_priv;
> + struct mxc_bank_info *bank = dev_get_priv(dev);
> + const char *label;
> + bool is_output;
> + int size;
> +
> + label = bank->label[offset];
> + is_output = mxc_gpio_is_output(bank->regs, offset);
> + size = snprintf(buf, bufsize, "%s%d: ",
> + uc_priv->bank_name ? uc_priv->bank_name : "", offset);
> + buf += size;
> + bufsize -= size;
> + snprintf(buf, bufsize, "%s: %d [%c]%s%s",
> + is_output ? "out" : " in",
> + is_output ?
> + mxc_gpio_bank_get_output_value(bank->regs, offset) :
> + mxc_gpio_bank_get_value(bank->regs, offset),
> + *label ? 'x' : ' ',
> + *label ? " " : "",
This is a check if the gpio is requested, right?
I think the new function gpio_is_requested() can be of hand here
instead of open coding this.
> + label);
> +
> + return 0;
> +}
> +
[...]
> +static int mxc_gpio_free(struct udevice *dev, unsigned offset)
> +{
> + struct mxc_bank_info *bank = dev_get_priv(dev);
> + int ret;
> +
> + ret = check_requested(dev, offset, __func__);
> + if (ret)
> + return ret;
In case of not requested gpio,
should we really print the error message and return -EPERM?
Or may be adopt free() behavior and just return silently?
Linux gpiolib gpio_free() uses WARN_ON(extra_checks) for
"not requested" cases, so it shouts only in DEBUG cases.
> + bank->label[offset][0] = '\0';
> +
> + return 0;
> +}
> +
[...]
--
Regards,
Igor.
next prev parent reply other threads:[~2014-09-17 13:00 UTC|newest]
Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-09-17 3:51 [U-Boot] [PATCH v2 0/11] dm: imx: Add driver model support for GPIO and serial on cm_fx6 Simon Glass
2014-09-17 3:51 ` [U-Boot] [PATCH v2 01/11] dm: linker_lists: Add a way to declare multiple objects Simon Glass
2014-09-17 3:51 ` [U-Boot] [PATCH v2 02/11] dm: core: Allow a list of devices to be declared in one step Simon Glass
2014-09-17 3:51 ` [U-Boot] [PATCH v2 03/11] dm: core: Allow device_bind() to used without CONFIG_OF_CONTROL Simon Glass
2014-09-17 3:51 ` [U-Boot] [PATCH v2 04/11] initcall: Display error number when an error occurs Simon Glass
2014-09-17 7:40 ` Igor Grinberg
2014-09-17 3:51 ` [U-Boot] [PATCH v2 05/11] dm: serial: Don't require device tree to configure a console Simon Glass
2014-09-17 3:51 ` [U-Boot] [PATCH v2 06/11] dm: serial: Put common code into separate functions Simon Glass
2014-09-17 3:51 ` [U-Boot] [PATCH v2 07/11] dm: imx: Add error checking to setup_i2c() Simon Glass
2014-09-17 8:37 ` Igor Grinberg
2014-09-17 13:56 ` Simon Glass
2014-09-17 14:16 ` Igor Grinberg
2014-09-17 3:51 ` [U-Boot] [PATCH v2 08/11] dm: imx: Use gpio_request() to request GPIOs Simon Glass
2014-09-17 12:13 ` Igor Grinberg
2014-09-17 14:00 ` Simon Glass
2014-09-17 14:31 ` Igor Grinberg
2014-09-17 14:34 ` Simon Glass
2014-09-18 7:23 ` Igor Grinberg
2014-09-17 3:51 ` [U-Boot] [PATCH v2 09/11] dm: imx: gpio: Support driver model in MXC gpio driver Simon Glass
2014-09-17 13:00 ` Igor Grinberg [this message]
2014-09-17 14:03 ` Simon Glass
2014-09-17 14:34 ` Igor Grinberg
2014-09-17 3:51 ` [U-Boot] [PATCH v2 10/11] dm: imx: serial: Support driver model in the MXC serial driver Simon Glass
2014-09-17 3:51 ` [U-Boot] [PATCH v2 11/11] dm: imx: Move cm_fx6 to use driver model for serial and GPIO Simon Glass
2014-09-17 13:07 ` Igor Grinberg
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=541985E0.8000502@compulab.co.il \
--to=grinberg@compulab.co.il \
--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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.