All of lore.kernel.org
 help / color / mirror / Atom feed
From: Ranjani Sridharan <ranjani.sridharan@linux.intel.com>
To: Takashi Iwai <tiwai@suse.de>
Cc: alsa-devel@alsa-project.org, kai.vehmanen@linux.intel.com
Subject: Re: Question about hdac_ext_link ref_count management
Date: Fri, 22 Jan 2021 08:40:55 -0800	[thread overview]
Message-ID: <9888b27b0dc9399861ecbee23d5d4ea0d844718c.camel@linux.intel.com> (raw)
In-Reply-To: <s5h1red83ic.wl-tiwai@suse.de>

On Fri, 2021-01-22 at 15:12 +0100, Takashi Iwai wrote:
> On Fri, 22 Jan 2021 00:23:53 +0100,
> Ranjani Sridharan wrote:
> > Hi Takashi,
> > 
> > While exploring some power optimizations on Intel platforms, I
> > noticed
> > that the hdac_ext_link ref_count is incremented during codec probe
> > in hdac_hda_codec_probe() and the ref_count is held until the codec
> > device is removed. 
> > 
> > I was wondering if it would be possible to call the get/put for the
> > hdac_ext_link in the codec runtime suspend/resume callbacks so that
> > the
> > link is powered up only when the link is in use. Are there any
> > downsides to doing this? 
> 
> Wouldn't the  snd_hdac_ext_bus_link_power_up() / down() calls do the
> runtime PM stuff?  Maybe we need to revisit those link power
> management.  The ext stuff isn't well m
> and, I'm afraid.
Thanks, Takashi.
It looks like snd_hdac_ext_bus_link_power_up/down() are only called
during snd_hdac_ext_bus_link_get/put(). Actually, in my observation
disabling the CORB/RIRB buffer DMAs is what saves us power and this is
done only if snd_hdac_ext_bus_link_put() is called on all links.

> 
> The get() and put() are obviously for fully enabling and disabling
> the
> device, hence it's not suitable for the runtime PM suspend/resume.
> The power_up() / down() should be adjusted to fit with the runtime PM
> call, if any.

The only additional thing that snd_hdac_ext_bus_link_get/put() does on
top of snd_hdac_ext_bus_link_power_up/down() is to stop the CORB/RIRB
DMA when all the link ref_counts are 0. Do you think it is not
advisable to stop the CORB/RIRB DMA during runtime PM?

Thanks,
Ranjani


  reply	other threads:[~2021-01-22 16:42 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-01-21 23:23 Question about hdac_ext_link ref_count management Ranjani Sridharan
2021-01-22 14:12 ` Takashi Iwai
2021-01-22 16:40   ` Ranjani Sridharan [this message]
2021-01-22 16:50     ` Takashi Iwai
2021-01-22 17:24       ` Ranjani Sridharan
2021-01-22 22:04       ` Ranjani Sridharan

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=9888b27b0dc9399861ecbee23d5d4ea0d844718c.camel@linux.intel.com \
    --to=ranjani.sridharan@linux.intel.com \
    --cc=alsa-devel@alsa-project.org \
    --cc=kai.vehmanen@linux.intel.com \
    --cc=tiwai@suse.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.