All of lore.kernel.org
 help / color / mirror / Atom feed
From: Daniel Mack <daniel@caiaq.de>
To: linux-kernel@vger.kernel.org
Cc: Ville Syrjala <syrjala@sci.fi>, Evgeniy Polyakov <johnpol@2ka.mipt.ru>
Subject: Re: [PATCH] w1-gpio: add external pull-up enable callback
Date: Fri, 8 May 2009 22:13:02 +0200	[thread overview]
Message-ID: <20090508201302.GA24080@buzzloop.caiaq.de> (raw)
In-Reply-To: <1241527413-22920-1-git-send-email-daniel@caiaq.de>

(cc Evgeniy Polyakov)

Evgeniy, could you give some feedback on this? Ville Syrjala gave his
Acked-by already.

Thanks,
Daniel


On Tue, May 05, 2009 at 02:43:33PM +0200, Daniel Mack wrote:
> On embedded devices, sleep mode conditions can be tricky to handle,
> Especially when processors tend to pull-down the w1 bus during sleep.
> Bus slaves (such as the ds2760) may interpret this as a reason for
> power-down conditions and entirely switch off the device.
> 
> This patch adds a callback function pointer to let users switch on and
> off the external pull-up resistor. This lets the outside world know
> whether the processor is currently actively driving the bus or not.
> 
> When this callback is not provided, the code behaviour won't change.
> 
> Signed-off-by: Daniel Mack <daniel@caiaq.de>
> Cc: Ville Syrjala <syrjala@sci.fi>
> ---
>  drivers/w1/masters/w1-gpio.c |   35 +++++++++++++++++++++++++++++++++++
>  include/linux/w1-gpio.h      |    1 +
>  2 files changed, 36 insertions(+), 0 deletions(-)
> 
> diff --git a/drivers/w1/masters/w1-gpio.c b/drivers/w1/masters/w1-gpio.c
> index a411702..6f8866d 100644
> --- a/drivers/w1/masters/w1-gpio.c
> +++ b/drivers/w1/masters/w1-gpio.c
> @@ -74,6 +74,9 @@ static int __init w1_gpio_probe(struct platform_device *pdev)
>  	if (err)
>  		goto free_gpio;
>  
> +	if (pdata->enable_external_pullup)
> +		pdata->enable_external_pullup(1);
> +
>  	platform_set_drvdata(pdev, master);
>  
>  	return 0;
> @@ -91,6 +94,9 @@ static int __exit w1_gpio_remove(struct platform_device *pdev)
>  	struct w1_bus_master *master = platform_get_drvdata(pdev);
>  	struct w1_gpio_platform_data *pdata = pdev->dev.platform_data;
>  
> +	if (pdata->enable_external_pullup)
> +		pdata->enable_external_pullup(0);
> +
>  	w1_remove_master_device(master);
>  	gpio_free(pdata->pin);
>  	kfree(master);
> @@ -98,12 +104,41 @@ static int __exit w1_gpio_remove(struct platform_device *pdev)
>  	return 0;
>  }
>  
> +#ifdef CONFIG_PM
> +
> +static int w1_gpio_suspend(struct platform_device *pdev, pm_message_t state)
> +{
> +	struct w1_gpio_platform_data *pdata = pdev->dev.platform_data;
> +
> +	if (pdata->enable_external_pullup)
> +		pdata->enable_external_pullup(0);
> +
> +	return 0;
> +}
> +
> +static int w1_gpio_resume(struct platform_device *pdev)
> +{
> +	struct w1_gpio_platform_data *pdata = pdev->dev.platform_data;
> +
> +	if (pdata->enable_external_pullup)
> +		pdata->enable_external_pullup(1);
> +
> +	return 0;
> +}
> +
> +#else
> +#define w1_gpio_suspend	NULL
> +#define w1_gpio_resume	NULL
> +#endif
> +
>  static struct platform_driver w1_gpio_driver = {
>  	.driver = {
>  		.name	= "w1-gpio",
>  		.owner	= THIS_MODULE,
>  	},
>  	.remove	= __exit_p(w1_gpio_remove),
> +	.suspend = w1_gpio_suspend,
> +	.resume = w1_gpio_resume,
>  };
>  
>  static int __init w1_gpio_init(void)
> diff --git a/include/linux/w1-gpio.h b/include/linux/w1-gpio.h
> index 9797fec..3adeff8 100644
> --- a/include/linux/w1-gpio.h
> +++ b/include/linux/w1-gpio.h
> @@ -18,6 +18,7 @@
>  struct w1_gpio_platform_data {
>  	unsigned int pin;
>  	unsigned int is_open_drain:1;
> +	void (*enable_external_pullup)(int enable);
>  };
>  
>  #endif /* _LINUX_W1_GPIO_H */
> -- 
> 1.6.2.1
> 

  parent reply	other threads:[~2009-05-08 20:13 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-05-05 12:43 [PATCH] w1-gpio: add external pull-up enable callback Daniel Mack
2009-05-06  9:33 ` Ville Syrjälä
2009-05-06  9:34   ` Daniel Mack
2009-05-06 20:28     ` Ville Syrjälä
2009-05-07  1:30       ` Daniel Mack
2009-05-08 18:19         ` Ville Syrjälä
2009-05-08 20:13 ` Daniel Mack [this message]
2009-05-08 20:53   ` Evgeniy Polyakov
2009-05-12 13:56 ` Daniel Mack

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=20090508201302.GA24080@buzzloop.caiaq.de \
    --to=daniel@caiaq.de \
    --cc=johnpol@2ka.mipt.ru \
    --cc=linux-kernel@vger.kernel.org \
    --cc=syrjala@sci.fi \
    /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.