public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Roger Quadros <rogerq@ti.com>
To: Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>
Cc: <tj@kernel.org>, <sergei.shtylyov@cogentembedded.com>,
	<kishon@ti.com>, <linux-ide@vger.kernel.org>,
	<linux-kernel@vger.kernel.org>, Balaji T K <balajitk@ti.com>
Subject: Re: [PATCH v2 2/2] ata: ahci_platform: runtime resume the device before use
Date: Fri, 18 Oct 2013 15:24:00 +0300	[thread overview]
Message-ID: <52612860.6020104@ti.com> (raw)
In-Reply-To: <1662147.qHgNzWWiSr@amdc1032>

Hi,

On 10/17/2013 05:15 PM, Bartlomiej Zolnierkiewicz wrote:
> 
> Hi,
> 
> On Wednesday, October 16, 2013 02:42:53 PM Roger Quadros wrote:
>> On OMAP platforms the device needs to be runtime resumed before
>> it can be accessed. The OMAP HWMOD framework takes care of
>> enabling the module and its resources based on the
>> device's runtime PM state.
>>
>> In this patch we runtime resume during .probe() and runtime suspend
>> during .remove() (i.e. ahci_host_stop()).
>>
>> We also update the runtime PM state during .resume().
>>
>> Signed-off-by: Roger Quadros <rogerq@ti.com>
>> Signed-off-by: Balaji T K <balajitk@ti.com>
>> ---
>>  drivers/ata/ahci_platform.c |   12 ++++++++++++
>>  1 file changed, 12 insertions(+)
>>
>> diff --git a/drivers/ata/ahci_platform.c b/drivers/ata/ahci_platform.c
>> index 5a0f1418..0da3b95 100644
>> --- a/drivers/ata/ahci_platform.c
>> +++ b/drivers/ata/ahci_platform.c
>> @@ -23,6 +23,7 @@
>>  #include <linux/platform_device.h>
>>  #include <linux/libata.h>
>>  #include <linux/ahci_platform.h>
>> +#include <linux/pm_runtime.h>
>>  #include "ahci.h"
>>  
>>  static void ahci_host_stop(struct ata_host *host);
>> @@ -141,6 +142,9 @@ static int ahci_probe(struct platform_device *pdev)
>>  		}
>>  	}
>>  
>> +	pm_runtime_enable(dev);
>> +	pm_runtime_get_sync(dev);
>> +
>>  	hpriv->phy = devm_phy_get(dev, "sata-phy");
>>  	if (IS_ERR(hpriv->phy)) {
>>  		dev_dbg(dev, "can't get sata-phy\n");
>> @@ -268,6 +272,9 @@ static void ahci_host_stop(struct ata_host *host)
>>  		clk_disable_unprepare(hpriv->clk);
>>  		clk_put(hpriv->clk);
>>  	}
>> +
>> +	pm_runtime_put_sync(dev);
>> +	pm_runtime_disable(dev);
> 
> It would be better to add proper .remove callback (i.e. named
> ahci_remove_one) and put this code there so it matches .probe
> callback.

After ahci host is started (i.e. probe succeeded), ahci_host_stop() is called
when the device resources are freed via devres management. So, we don't really
need to do this again in the .remove callback.

If we want to do all that in .remove then everything that is done in ahci_host_stop()
must be done in .remove() and ahci_host_stop() becomes a nop.

cheers,
-roger

> 
>>  }
>>  
>>  #ifdef CONFIG_PM_SLEEP
>> @@ -339,6 +346,11 @@ static int ahci_resume(struct device *dev)
>>  
>>  	ata_host_resume(host);
>>  
>> +	/* We resumed so update PM runtime state */
>> +	pm_runtime_disable(dev);
>> +	pm_runtime_set_active(dev);
>> +	pm_runtime_enable(dev);
>> +
>>  	return 0;
>>  
>>  disable_unprepare_clk:
> 
> Best regards,
> --
> Bartlomiej Zolnierkiewicz
> Samsung R&D Institute Poland
> Samsung Electronics
> 


      reply	other threads:[~2013-10-18 12:24 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-10-16 11:42 [PATCH v2 0/2] ata: ahci_platform: Add PHY support and OMAP support Roger Quadros
2013-10-16 11:42 ` [PATCH v2 1/2] ata: ahci_platform: Manage SATA PHY Roger Quadros
2013-10-17 13:57   ` Bartlomiej Zolnierkiewicz
2013-10-18  7:31     ` Roger Quadros
2013-10-16 11:42 ` [PATCH v2 2/2] ata: ahci_platform: runtime resume the device before use Roger Quadros
2013-10-17 14:15   ` Bartlomiej Zolnierkiewicz
2013-10-18 12:24     ` Roger Quadros [this message]

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=52612860.6020104@ti.com \
    --to=rogerq@ti.com \
    --cc=b.zolnierkie@samsung.com \
    --cc=balajitk@ti.com \
    --cc=kishon@ti.com \
    --cc=linux-ide@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=sergei.shtylyov@cogentembedded.com \
    --cc=tj@kernel.org \
    /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