All of lore.kernel.org
 help / color / mirror / Atom feed
From: Roland Stigge <stigge@antcom.de>
To: Wolfram Sang <w.sang@pengutronix.de>
Cc: linux-watchdog@vger.kernel.org, Wim Van Sebroeck <wim@iguana.be>
Subject: Re: [PATCH 1/4] watchdog: pnx4008: cleanup resource handling using managed devices
Date: Thu, 02 Feb 2012 21:04:10 +0100	[thread overview]
Message-ID: <4F2AEC3A.7000304@antcom.de> (raw)
In-Reply-To: <1328204891-32551-2-git-send-email-w.sang@pengutronix.de>

On 02/02/2012 06:48 PM, Wolfram Sang wrote:
> The resource handling in this driver was flaky: IO_ADDRESS instead of
> ioremap (and no unmapping), an unneeded static resource, no central exit
> path for error cases. Fix this by converting the driver to use managed
> resources. Also use dev_*-messages instead of printk while we are here.
> 
> Signed-off-by: Wolfram Sang <w.sang@pengutronix.de>
> ---
>  drivers/watchdog/pnx4008_wdt.c |   74 ++++++++++++++-------------------------
>  1 files changed, 27 insertions(+), 47 deletions(-)
> 
> diff --git a/drivers/watchdog/pnx4008_wdt.c b/drivers/watchdog/pnx4008_wdt.c
> index 8e210aa..322a392 100644
> --- a/drivers/watchdog/pnx4008_wdt.c
> +++ b/drivers/watchdog/pnx4008_wdt.c
> @@ -89,7 +89,6 @@ static unsigned long wdt_status;
>  
>  static unsigned long boot_status;
>  
> -static struct resource	*wdt_mem;
>  static void __iomem	*wdt_base;
>  struct clk		*wdt_clk;
>  
> @@ -253,61 +252,46 @@ static struct miscdevice pnx4008_wdt_miscdev = {
>  
>  static int __devinit pnx4008_wdt_probe(struct platform_device *pdev)
>  {
> -	int ret = 0, size;
> +	struct resource *r;
> +	int ret = 0;
>  
>  	if (heartbeat < 1 || heartbeat > MAX_HEARTBEAT)
>  		heartbeat = DEFAULT_HEARTBEAT;
>  
> -	printk(KERN_INFO MODULE_NAME
> -		"PNX4008 Watchdog Timer: heartbeat %d sec\n", heartbeat);
> -
> -	wdt_mem = platform_get_resource(pdev, IORESOURCE_MEM, 0);
> -	if (wdt_mem == NULL) {
> -		printk(KERN_INFO MODULE_NAME
> -			"failed to get memory region resouce\n");
> -		return -ENOENT;
> -	}
> -
> -	size = resource_size(wdt_mem);
> -
> -	if (!request_mem_region(wdt_mem->start, size, pdev->name)) {
> -		printk(KERN_INFO MODULE_NAME "failed to get memory region\n");
> -		return -ENOENT;
> -	}
> -	wdt_base = (void __iomem *)IO_ADDRESS(wdt_mem->start);
> +	r = platform_get_resource(pdev, IORESOURCE_MEM, 0);
> +	wdt_base = devm_request_and_ioremap(&pdev->dev, r);
> +	if (!wdt_base)
> +		return -EADDRINUSE;
>  
>  	wdt_clk = clk_get(&pdev->dev, NULL);
> -	if (IS_ERR(wdt_clk)) {
> -		ret = PTR_ERR(wdt_clk);
> -		release_mem_region(wdt_mem->start, size);
> -		wdt_mem = NULL;
> -		goto out;
> -	}
> +	if (IS_ERR(wdt_clk))
> +		return PTR_ERR(wdt_clk);
>  
>  	ret = clk_enable(wdt_clk);
> -	if (ret) {
> -		release_mem_region(wdt_mem->start, size);
> -		wdt_mem = NULL;
> -		clk_put(wdt_clk);
> -		goto out;
> -	}
> +	if (ret)
> +		goto put_clk;
>  
>  	ret = misc_register(&pnx4008_wdt_miscdev);
>  	if (ret < 0) {
> -		printk(KERN_ERR MODULE_NAME "cannot register misc device\n");
> -		release_mem_region(wdt_mem->start, size);
> -		wdt_mem = NULL;
> -		clk_disable(wdt_clk);
> -		clk_put(wdt_clk);
> -	} else {
> -		boot_status = (__raw_readl(WDTIM_RES(wdt_base)) & WDOG_RESET) ?
> -		    WDIOF_CARDRESET : 0;
> -		wdt_disable();		/*disable for now */
> -		clk_disable(wdt_clk);
> -		set_bit(WDT_DEVICE_INITED, &wdt_status);
> +		dev_err(&pdev->dev, "cannot register misc device\n");
> +		goto disable_clk;
>  	}
>  
> -out:
> +	boot_status = (__raw_readl(WDTIM_RES(wdt_base)) &
> +		WDOG_RESET) ? WDIOF_CARDRESET : 0;
> +	wdt_disable();		/*disable for now */
> +	clk_disable(wdt_clk);
> +	set_bit(WDT_DEVICE_INITED, &wdt_status);
> +
> +	dev_info(&pdev->dev, "PNX4008 Watchdog Timer: heartbeat %d sec\n",
> +			heartbeat);
> +
> +	return 0;
> +
> + disable_clk:
> +	clk_disable(wdt_clk);
> + put_clk:
> +	clk_put(wdt_clk);
>  	return ret;
>  }
>  
> @@ -318,10 +302,6 @@ static int __devexit pnx4008_wdt_remove(struct platform_device *pdev)
>  	clk_disable(wdt_clk);
>  	clk_put(wdt_clk);
>  
> -	if (wdt_mem) {
> -		release_mem_region(wdt_mem->start, resource_size(wdt_mem));
> -		wdt_mem = NULL;
> -	}
>  	return 0;
>  }
>  

Tested-by: Roland Stigge <stigge@antcom.de>

  reply	other threads:[~2012-02-02 20:11 UTC|newest]

Thread overview: 13+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-02-02 17:48 [PATCH 0/4] pnx4008: convert to watchdog framework Wolfram Sang
2012-02-02 17:48 ` [PATCH 1/4] watchdog: pnx4008: cleanup resource handling using managed devices Wolfram Sang
2012-02-02 20:04   ` Roland Stigge [this message]
2012-02-02 17:48 ` [PATCH 2/4] watchdog: pnx4008: don't use __raw_-accessors Wolfram Sang
2012-02-02 20:04   ` Roland Stigge
2012-02-02 17:48 ` [PATCH 3/4] watchdog: dev: don't enforce set_timeout() Wolfram Sang
2012-02-02 20:04   ` Roland Stigge
2012-03-14 18:40   ` Wolfram Sang
2012-03-15 21:18     ` Wim Van Sebroeck
2012-02-02 17:48 ` [PATCH 4/4] watchdog: pnx4008: convert driver to use the watchdog framework Wolfram Sang
2012-02-02 20:04   ` Roland Stigge
2012-02-02 20:02 ` [PATCH 0/4] pnx4008: convert to " Roland Stigge
2012-02-02 20:23   ` Wolfram Sang

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=4F2AEC3A.7000304@antcom.de \
    --to=stigge@antcom.de \
    --cc=linux-watchdog@vger.kernel.org \
    --cc=w.sang@pengutronix.de \
    --cc=wim@iguana.be \
    /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.